当前位置: 首页 > news >正文

Linux系统 C/C++编程基础——基于GTK+的图形用户界面编程

ℹ️大家好,我是练小杰,今天星期三了,距离除夕又少了一天,新年的钟声就快敲响了😆
本文是有关Linux C/C++编程中的基于GTK+的图形用户界面编程知识点,后续会不断添加相关内容 ~~
回顾:【使用make工具和Makefile实现自动编译】
更多Linux 相关内容请点击👉【Linux专栏】

在这里插入图片描述

文章目录

  • GTK+简介
    • GTK+的优势
    • GTK+的应用领域
    • GTK+ 的编程基础
  • 部署GTK+编程环境
    • 安装GTK+ 3开发包
    • 安装构建工具
    • 安装其他必要的库和工具
    • 配置环境变量
    • 测试GTK+编程
    • pkg-config工具
  • Glade辅助设计界面
    • Glade简介
    • 主要特点
    • Glade安装
  • 使用Glade设计图形用户界面
    • 新建一个Glade项目
    • 选择顶层容器
    • 选择显示组件
    • Glade项目
    • GTK+结合Glade进行编程
  • 部署集成开发环境Anjuta
    • Anjuta简介
    • Anjuta 的主要特点
    • Ubuntu系统中安装Anjuta
    • Anjuta常见问题及解决方法
  • Anjuta基本使用(图形界面)
    • Anjuta初始界面
    • 选择项目类型
    • 设置项目基本信息
    • 设置项目选项
    • 项目结构
    • 项目的目录及文件
    • 启动图形界面文件编辑
    • 调用Glade编辑图形界面文件
    • 设置程序参数
    • Anjuta创建的应用程序
    • 制作项目
    • 进行编译

在这里插入图片描述

GTK+简介

  • GTK+是一套跨多种平台的开放源码图形用户界面工具包。
  • GTK+类似于Windows上的MFC和Win32 API、JAVA上的Swing和SWT,是Linux下开发GUI应用程序的主流开发工具之一。
  • GTK+可以用来进行跨平台GUI应用程序的开发。
  • GTK+开发套件基于3个主要的库:GlibPangoATK
  • GNOME桌面环境以GTK+为基础,为GNOME编写的程序使用GTK+作为其工具箱。

GTK+的优势

  • 跨平台性:GTK+支持多种操作系统,包括Linux、Windows和macOS,使得开发者可以使用相同的代码库开发出可在不同平台上运行的应用程序。

  • 开源和免费:GTK+基于LGPL许可证发布,开发者可以自由地使用、修改和分发GTK+,无需支付任何费用。

  • 支持多种编程语言绑定:GTK+提供了多种编程语言的绑定,包括C++、Python、JavaScript、Rust等,方便不同背景的开发者使用。

  • 丰富的组件和功能:GTK+提供了丰富的GUI组件和功能,包括窗口、按钮、文本框、菜单、对话框等基本组件,以及树形视图、图标视图、进度条等高级组件。

GTK+的应用领域

  • 桌面应用程序开发

GTK+是开发Linux和Unix系统下桌面应用程序的主要工具之一,许多流行的开源应用程序,如GIMP、Inkscape、Pidgin等,都是使用GTK+开发的。

  • GNOME桌面环境

GNOME是Linux和Unix系统下流行的桌面环境之一,它使用GTK+作为其主要的GUI开发工具包。

  • 其他案例

GTK+还被用于开发各种其他类型的应用程序,如嵌入式系统、移动应用程序、Web应用程序等。例如,Firefox浏览器的Linux版本使用GTK+作为其GUI开发工具包。

GTK+ 的编程基础

一个基本的GTK+程序通常由以下几个部分组成:

  1. 初始化:设置必要的环境变量和初始化GTK+库。
  2. 创建窗口和控件:创建应用程序的主窗口以及必要的控件。
  3. 信号连接:将控件的信号与处理函数连接起来,以响应用户的操作。
  4. 事件循环:启动GTK+的事件循环,使得应用程序能够响应用户操作。
  5. 清理和退出:在程序退出时释放资源并关闭应用程序

部署GTK+编程环境

安装GTK+ 3开发包

部署GTK+编程环境首先要提供gccg++gdbmake等编译工具,然后要安装核心的GTK+开发包。

  • 安装GTK+ 3开发包,执行命令如下:
sudo apt update
sudo apt install libgtk-3-dev

这里命令是安装最新GTK+开发库及其依赖项。我们也可以从GTK+的官方网站下载源代码并手动编译安装。

  • 检查是否安装了GTK+ 3,查看所安装的具体版本。
pkg-config --modversion gtk+-3.0

安装构建工具

为了编译GTK+应用程序,你需要安装C编译器(如gcc)或者make工具。

sudo apt install build-essential

安装其他必要的库和工具

根据项目需求,我们可能需要安装其他库和工具。以下工具的概念后面会细讲!!

  • pkg-config 用于管理编译时的库依赖
sudo apt install pkg-config
  • Glade 用于可视化设计GTK+用户界面。
sudo apt install glade
  • 调试工具,比如gdb,用于调试GTK+应用程序。
sudo apt install gdb

配置环境变量

一般,包管理器会自动处理环境变量配置。但如果我们从源代码安装GTK+,需要手动配置PKG_CONFIG_PATHLD_LIBRARY_PATH变量。

示例:可以将这些行添加到你的~/.bashrc~/.zshrc文件中,以便每次打开终端时自动设置。

export PKG_CONFIG_PATH=$PKG_CONFIG_PATH:/usr/local/lib/pkgconfig
export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/usr/local/lib

测试GTK+编程

#include <gtk/gtk.h>
int main(int argc,char *argv[])
{
/* 声明GtkWidget构件 */
GtkWidget *window;
GtkWidget *label;/* 调用GTK初始化函数,这在所有的GTK程序中都要调用*/
gtk_init(&argc,&argv);/* 创建主窗口*/
window = gtk_window_new(GTK_WINDOW_TOPLEVEL);/* 为该窗口设置标题*/
gtk_window_set_title(GTK_WINDOW(window),"Hello World");/* 将窗口的destroy信号连接到函数gtk_main_quit
* 当窗口要被销毁时,获得通告,停止主GTK+循环 */
g_signal_connect(window,"destroy",G_CALLBACK(gtk_main_quit),NULL);/* 创建“Hello, World”标签 */
label = gtk_label_new("Hello, World!");/* 将标签加入到主窗口 */
gtk_container_add(GTK_CONTAINER(window),label);/* 显示所有的GtkWidget构件,包括窗口、标签*/
gtk_widget_show_all(window);/* GTK程序必须有一个gtk_main()函数启动主循环,等待事件发生并响应,直到应用结束 */
gtk_main();
return 0;
}

pkg-config工具

  • pkg-config是最为常用的库信息提取工具,通过库提供的一个.pc文件获得库的各种必要信息的,包括版本信息、编译和连接需要的参数等。
  • GTK+及其依赖库支持使用pkg-config工具,通过设置搜索路径来解决寻找库对应的.pc 文件的问题,库的头文件的搜索路径的设置变成了对.pc文件搜索路径的设置。
  • 使用pkg-config 工具提取库的编译和连接参数的两个基本前提:
  1. 库本身在安装时必须提供一个相应的.pc文件;
  2. pkg-config必须知道要到何处去寻找.pc文件。

Glade辅助设计界面

Glade简介

  • Glade 是一个用于创建和编辑 GTK+ 和 GNOME 应用程序用户界面的开源可视化设计工具。
  • 原来 Glade的设计初衷是将界面设计与应用程序代码分离,界面的修改不会影响到应用程序代码。
  • 用Glade设计的用户界面是以XML格式的文件保存的(通常以 .glade.ui 结尾),可以通过GTK+对象GtkBuilder被应用程序动态地载入。

主要特点

  • 可视化设计

通过拖放组件,开发者可以直观地设计用户界面,而无需手动编写大量的布局和控件代码。

  • 支持多种控件

Glade 支持 GTK+ 提供的各种控件,包括窗口、按钮、文本框、树形视图、图标视图等。

  • 实时预览

设计界面时,Glade 提供实时预览功能,开发者可以即时看到界面的效果。

  • 信号和事件处理

Glade 允许开发者为控件添加信号和事件处理函数,简化了界面与业务逻辑的连接。

  • 国际化支持:

Glade 支持界面元素的国际化,可以为不同语言环境设计不同的界面。

  • 集成 GTK+ 版本

Glade 支持最新的 GTK+ 版本,包括 GTK+ 3GTK+ 4,确保开发者可以使用最新的界面组件和功能。

Glade安装

  • Glade需要GTK+ 3支持,所以执行如下命令安装Glade 3工具
sudo apt update
sudo apt install glade

使用Glade设计图形用户界面

  • 启动 Glade,可以在终端中输入命令启动 Glade:
glade

新建一个Glade项目

在这里插入图片描述

选择顶层容器

在这里插入图片描述

选择显示组件

在这里插入图片描述

Glade项目

在这里插入图片描述

GTK+结合Glade进行编程

#include <gtk/gtk.h> 
int main (int argc, char *argv[])
{GtkBuilder      *builder;GtkWidget       *window; gtk_init (&argc, &argv);builder = gtk_builder_new ();gtk_builder_add_from_file (builder, "hello.glade", NULL);window = GTK_WIDGET (gtk_builder_get_object (builder, "window1"));gtk_builder_connect_signals (builder, NULL);g_object_unref (G_OBJECT (builder));        gtk_widget_show_all(window);                gtk_main (); return 0;
}

部署集成开发环境Anjuta

Anjuta简介

Anjuta是一个为GTK+/GNOME编写的集成开发环境,除了支持C和C++编程外,还支持Java、JavaScrip和Python语言的编程。

Anjuta 的主要特点

  • 自身提供强大的源程序编辑功能
  • 借用Glade工具生成GUI界面
  • 内嵌代码级的调试器(调用GDB
  • 使用标准的Linux构建系统工具Autotools
  • 提供应用程序向导帮助程序员快速创建GTK+程序,避免编写重复的代码

Ubuntu系统中安装Anjuta

  • 确认系统安装有Glade和GTK+,可用如下命令
sudo apt update
sudo apt-get install anjuta 
  • 安装完成后,通过终端输入以下命令启动 Anjuta
anjuta &

Anjuta常见问题及解决方法

  • 依赖问题:如果在安装过程中遇到依赖错误,确保所有必要的开发库已安装。可以使用 aptdnf 安装缺失的依赖包。
  • 编译错误:检查编译器和构建系统配置,确保项目设置正确。
  • 调试器问题:确保 GDB 已安装,并且 Anjuta 的调试配置正确。

Anjuta基本使用(图形界面)

Anjuta初始界面

在这里插入图片描述

选择项目类型

在这里插入图片描述

设置项目基本信息

在这里插入图片描述

设置项目选项

在这里插入图片描述

项目结构

在这里插入图片描述

项目的目录及文件

在这里插入图片描述

启动图形界面文件编辑

在这里插入图片描述

调用Glade编辑图形界面文件

在这里插入图片描述

设置程序参数

在这里插入图片描述

Anjuta创建的应用程序

在这里插入图片描述

制作项目

在这里插入图片描述

进行编译

在这里插入图片描述

今天晚上的内容到这里就结束了😆
ℹ️如果想了解更多,点击主页【练小杰的CSDN】
⚠️若博客里的内容有问题,欢迎指正,我会及时修改!!!
明天再见啦,各位🧍大佬们~~

在这里插入图片描述

相关文章:

Linux系统 C/C++编程基础——基于GTK+的图形用户界面编程

ℹ️大家好&#xff0c;我是练小杰&#xff0c;今天星期三了&#xff0c;距离除夕又少了一天&#xff0c;新年的钟声就快敲响了&#x1f606; 本文是有关Linux C/C编程中的基于GTK的图形用户界面编程知识点&#xff0c;后续会不断添加相关内容 ~~ 回顾:【使用make工具和Makefil…...

【Leetcode 每日一题】40. 组合总和 II

问题背景 给定一个候选人编号的集合 c a n d i d a t e s candidates candidates 和一个目标数 t a r g e t target target&#xff0c;找出 c a n d i d a t e s candidates candidates 中所有可以使数字和为 t a r g e t target target 的组合。 c a n d i d a t e s c…...

python 变量范围的定义与用法

文章目录 1. 局部变量&#xff08;Local Scope&#xff09;示例&#xff1a; 2. 嵌套函数变量&#xff08;Enclosing Scope&#xff09;示例&#xff1a;说明&#xff1a; 3. 全局变量&#xff08;Global Scope&#xff09;示例&#xff1a;说明&#xff1a; 4. 内置变量&#…...

TRTC实时对话式AI解决方案,助力人机语音交互极致体验

近年来&#xff0c;AI热度持续攀升&#xff0c;无论是融资规模还是用户热度都大幅增长。2023 年&#xff0c;中国 AI 行业融资规模达2631亿人民币&#xff0c;较2022年上升51%&#xff1b;2024年第二季度&#xff0c;全球 AI 初创企业融资规模为 240 亿美金&#xff0c;较第一季…...

dev c++ ‘unordered_set‘ does not name a type

参考:https://blog.csdn.net/Zaczc/article/details/142531525 启用C11标准步骤 工具->编译选项 勾选编译时加入以下命令 在空白处添加:-stdc11 单击确定&#xff0c;启用成功...

算法每日双题精讲 —— 二分查找(寻找旋转排序数组中的最小值,点名)

&#x1f31f;快来参与讨论&#x1f4ac;&#xff0c;点赞&#x1f44d;、收藏⭐、分享&#x1f4e4;&#xff0c;共创活力社区。 &#x1f31f; 别再犹豫了&#xff01;快来订阅我们的算法每日双题精讲专栏&#xff0c;一起踏上算法学习的精彩之旅吧&#x1f4aa; 在算法的…...

three.js+WebGL踩坑经验合集(4.2):为什么不在可视范围内的3D点投影到2D的结果这么不可靠

上一篇&#xff0c;笔者留下了一个问题&#xff0c;three.js内置的THREE.Vector3.project方法算出来的结果对于超出屏幕可见范围的点来说错得相当离谱。 three.jsWebGL踩坑经验合集(4.1):THREE.Line2的射线检测问题&#xff08;注意本篇说的是Line2&#xff0c;同样也不是阈值…...

Kafka运维宝典 (二)- kafka 查看kafka的运行状态、broker.id不一致导致启动失败问题、topic消息积压量告警监控脚本

Kafka运维宝典 &#xff08;二&#xff09; 文章目录 Kafka运维宝典 &#xff08;二&#xff09;一、kafka broker.id冲突问题1. broker.id 冲突的影响2. 如何发现 broker.id 冲突3. 解决 broker.id 冲突的方法4. broker.id 配置管理5. 集群启动后确认 broker.id 唯一性6. brok…...

全球AI模型百科全书,亚马逊云科技Bedrock上的100多款AI模型

今天小李哥给大家介绍的是亚马逊云科技上的AI模型管理平台Amazon Bedrock上的Marketplace&#xff0c;这是亚马逊云科技在今年re:Invent发布的一个全新功能&#xff0c;将亚马逊的电商基因带到了其云计算平台&#xff0c;让我们能够通过Amazon Bedrock访问100多种流行、新兴和专…...

微信小程序中常见的 跳转方式 及其特点的表格总结(wx.navigateTo 适合需要返回上一页的场景)

文章目录 详细说明总结wx.navigateTo 的特点为什么 wx.navigateTo 最常用&#xff1f;其他跳转方式的使用频率总结 以下是微信小程序中常见的跳转方式及其特点的表格总结&#xff1a; 跳转方式API 方法特点适用场景wx.navigateTowx.navigateTo({ url: 路径 })保留当前页面&…...

【Elasticsearch】index:false

在 Elasticsearch 中&#xff0c;index 参数用于控制是否对某个字段建立索引。当设置 index: false 时&#xff0c;意味着该字段不会被编入倒排索引中&#xff0c;因此不能直接用于搜索查询。然而&#xff0c;这并不意味着该字段完全不可访问或没有其他用途。以下是关于 index:…...

新版IDEA创建数据库表

这是老版本的IDEA创建数据库表&#xff0c;下面可以自己勾选Not null&#xff08;非空),Auto inc&#xff08;自增长),Unique(唯一标识)和Primary key&#xff08;主键) 这是新版的IDEA创建数据库表&#xff0c;Not null和Auto inc可以看得到&#xff0c;但Unique和Primary key…...

输入带空格的字符串,求单词个数

输入带空格的字符串&#xff0c;求单词个数 __ueooe_eui_sjje__ ---->3syue__jdjd____die_ ---->3shuue__dju__kk ---->3 #include <stdio.h> #include <string.h>// 自定义函数来判断字符是否为空白字符 int isSpace(char c) {return c || c \t || …...

C语言程序设计十大排序—希尔排序

文章目录 1.概念✅2.希尔排序&#x1f388;3.代码实现✅3.1 直接写✨3.2 函数✨ 4.总结✅ 1.概念✅ 排序是数据处理的基本操作之一&#xff0c;每次算法竞赛都很多题目用到排序。排序算法是计算机科学中基础且常用的算法&#xff0c;排序后的数据更易于处理和查找。在计算机发展…...

Excel制作合同到期自动提醒!

大家好&#xff0c;我是小鱼。 今天分享一下如何利用Excel制作合同到期提醒表&#xff0c;实现Excel表格自动计算合同到期日和天数&#xff0c;根据合同状态和到期天数自动填充颜色提醒&#xff0c;超实用。先看一下效果&#xff0c;已经到期的合同会自动被填充为红色&#xf…...

“AI质量评估系统:智能守护,让品质无忧

嘿&#xff0c;各位小伙伴们&#xff01;今天咱们来聊聊一个在现代社会中越来越重要的角色——AI质量评估系统。你知道吗&#xff1f;在这个快速发展的时代&#xff0c;产品质量已经成为企业生存和发展的关键。而AI质量评估系统&#xff0c;就像是我们的智能守护神&#xff0c;…...

爬虫基础之爬取某基金网站+数据分析

声明: 本案例仅供学习参考使用&#xff0c;任何不法的活动均与本作者无关 网站:天天基金网(1234567.com.cn) --首批独立基金销售机构-- 东方财富网旗下基金平台! 本案例所需要的模块: 1.requests 2.re(内置) 3.pandas 4.pyecharts 其他均需要 pip install 模块名 爬取步骤: …...

使用 Aryn DocPrep、DocParse 和 Elasticsearch 向量数据库实现高质量 RAG

作者&#xff1a;来自 Elastic Hemant Malik 及 Jonathan Fritz 组织依靠自然语言查询从非结构化数据中获取见解&#xff0c;但要获得高质量的答案&#xff0c;首先要进行有效的数据准备。Aryn DocParse 和 DocPrep通过将复杂文档转换为结构化 JSON 或 markdown 来简化此过程&a…...

Couchbase UI: Server

在 Couchbase UI 中的 Server&#xff08;服务器&#xff09;标签页主要用于管理和监控集群中的各个节点。以下是 Server 标签页的主要内容和功能介绍&#xff1a; 1. 节点列表 显示集群中所有节点的列表&#xff0c;每个节点的详细信息包括&#xff1a; 节点地址&#xff1…...

Web3.0时代的挑战与机遇:以开源2+1链动模式AI智能名片S2B2C商城小程序为例的深度探讨

摘要&#xff1a;Web3.0作为互联网的下一代形态&#xff0c;承载着去中心化、开放性和安全性的重要愿景。然而&#xff0c;其高门槛、用户体验差等问题阻碍了Web3.0的主流化进程。本文旨在深入探讨Web3.0面临的挑战&#xff0c;并提出利用开源21链动模式、AI智能名片及S2B2C商城…...

langchain基础(一)

模型又可分为语言模型&#xff08;擅长文本补全&#xff0c;输入和输出都是字符串&#xff09;和聊天模型&#xff08;擅长对话&#xff0c;输入时消息列表&#xff0c;输出是一个消息&#xff09;两大类。 以调用openai的聊天模型为例&#xff0c;先安装langchain_openai库 1…...

【Android】布局文件layout.xml文件使用控件属性android:layout_weight使布局较为美观,以RadioButton为例

目录 说明举例 说明 简单来说&#xff0c;android:layout_weight为当前控件按比例分配剩余空间。且单个控件该属性的具体数值不重要&#xff0c;而是多个控件的属性值之比发挥作用&#xff0c;例如有2个控件&#xff0c;各自的android:layout_weight的值设为0.5和0.5&#xff0…...

RabbitMQ 架构分析

文章目录 前言一、RabbitMQ架构分析1、Broker2、Vhost3、Producer4、Messages5、Connections6、Channel7、Exchange7、Queue8、Consumer 二、消息路由机制1、Direct Exchange2、Topic Exchange3、Fanout Exchange4、Headers Exchange5、notice5.1、备用交换机&#xff08;Alter…...

Qt Enter和HoverEnter事件

介绍 做PC开发的过程中或多或少都会接触到鼠标的悬停事件&#xff0c;Qt中处理鼠标悬停有Enter和HoverEnter两种事件 相同点 QEvent::Enter对应QEnterEvent&#xff0c;描述的是鼠标进入控件坐标范围之内的行为&#xff0c;QEnterEvent可以抓取鼠标的位置&#xff1b;QEvent…...

大语言模型之prompt工程

前言 随着人工智能的快速发展&#xff0c;我们正慢慢进入AIGC的新时代&#xff0c;其中对自然语言的处理成为了智能化的关键一环&#xff0c;在这个大背景下&#xff0c;“Prompt工程”由此产生&#xff0c;并且正逐渐成为有力的工具... LLM &#xff08;Large Language Mode…...

WPF基础 | WPF 常用控件实战:Button、TextBox 等的基础应用

WPF基础 | WPF 常用控件实战&#xff1a;Button、TextBox 等的基础应用 一、前言二、Button 控件基础2.1 Button 的基本定义与显示2.2 按钮样式设置2.3 按钮大小与布局 三、Button 的交互功能3.1 点击事件处理3.2 鼠标悬停与离开效果3.3 按钮禁用与启用 四、TextBox 控件基础4.…...

[笔记] 极狐GitLab实例 : 手动备份步骤总结

官方备份文档 : 备份和恢复极狐GitLab 一. 要求 为了能够进行备份和恢复&#xff0c;请确保您系统已安装 Rsync。 如果您安装了极狐GitLab&#xff1a; 如果您使用 Omnibus 软件包&#xff0c;则无需额外操作。如果您使用源代码安装&#xff0c;您需要确定是否安装了 rsync。…...

随笔十七、eth0单网卡绑定双ip的问题

在调试语音对讲过程中遇到过一个“奇怪”问题&#xff1a;泰山派作为一端&#xff0c;可以收到对方发来的语音&#xff0c;而对方不能收到泰山派发出的语音。 用wireshark抓包UDP发现&#xff0c;泰山派发送的地址是192.168.1.30&#xff0c;而给泰山派实际设置的静态地址是19…...

逻辑复制parallel并发参数测试

逻辑复制parallel并发参数测试 一、测试结果、测试环境描述 1.1、测试结果 cpu表中有1000万条数据&#xff0c;大小为1652MB,当更新的数据量多于10万条的时候有明显变化&#xff0c;多余30万条的时候相差2倍。 更新的数据量较多时&#xff0c;逻辑复制使用并发参数相比于使用…...

Cursor 帮你写一个小程序

Cursor注册地址 首先下载客户端 点击链接下载 1 打开微信开发者工具创建一个小程序项目 选择TS-基础模版 官方 2 然后使用Cursor打开小程序创建的项目 3 在CHAT聊天框输入自己的需求 比如 小程序功能描述&#xff1a;吃什么助手 项目名称&#xff1a; 吃什么小程序 功能目标…...