当前位置: 首页 > 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商城…...

19c补丁后oracle属主变化,导致不能识别磁盘组

补丁后服务器重启&#xff0c;数据库再次无法启动 ORA01017: invalid username/password; logon denied Oracle 19c 在打上 19.23 或以上补丁版本后&#xff0c;存在与用户组权限相关的问题。具体表现为&#xff0c;Oracle 实例的运行用户&#xff08;oracle&#xff09;和集…...

C++_核心编程_多态案例二-制作饮品

#include <iostream> #include <string> using namespace std;/*制作饮品的大致流程为&#xff1a;煮水 - 冲泡 - 倒入杯中 - 加入辅料 利用多态技术实现本案例&#xff0c;提供抽象制作饮品基类&#xff0c;提供子类制作咖啡和茶叶*//*基类*/ class AbstractDr…...

Admin.Net中的消息通信SignalR解释

定义集线器接口 IOnlineUserHub public interface IOnlineUserHub {/// 在线用户列表Task OnlineUserList(OnlineUserList context);/// 强制下线Task ForceOffline(object context);/// 发布站内消息Task PublicNotice(SysNotice context);/// 接收消息Task ReceiveMessage(…...

linux arm系统烧录

1、打开瑞芯微程序 2、按住linux arm 的 recover按键 插入电源 3、当瑞芯微检测到有设备 4、松开recover按键 5、选择升级固件 6、点击固件选择本地刷机的linux arm 镜像 7、点击升级 &#xff08;忘了有没有这步了 估计有&#xff09; 刷机程序 和 镜像 就不提供了。要刷的时…...

微信小程序 - 手机震动

一、界面 <button type"primary" bindtap"shortVibrate">短震动</button> <button type"primary" bindtap"longVibrate">长震动</button> 二、js逻辑代码 注&#xff1a;文档 https://developers.weixin.qq…...

MODBUS TCP转CANopen 技术赋能高效协同作业

在现代工业自动化领域&#xff0c;MODBUS TCP和CANopen两种通讯协议因其稳定性和高效性被广泛应用于各种设备和系统中。而随着科技的不断进步&#xff0c;这两种通讯协议也正在被逐步融合&#xff0c;形成了一种新型的通讯方式——开疆智能MODBUS TCP转CANopen网关KJ-TCPC-CANP…...

【Zephyr 系列 10】实战项目:打造一个蓝牙传感器终端 + 网关系统(完整架构与全栈实现)

🧠关键词:Zephyr、BLE、终端、网关、广播、连接、传感器、数据采集、低功耗、系统集成 📌目标读者:希望基于 Zephyr 构建 BLE 系统架构、实现终端与网关协作、具备产品交付能力的开发者 📊篇幅字数:约 5200 字 ✨ 项目总览 在物联网实际项目中,**“终端 + 网关”**是…...

sipsak:SIP瑞士军刀!全参数详细教程!Kali Linux教程!

简介 sipsak 是一个面向会话初始协议 (SIP) 应用程序开发人员和管理员的小型命令行工具。它可以用于对 SIP 应用程序和设备进行一些简单的测试。 sipsak 是一款 SIP 压力和诊断实用程序。它通过 sip-uri 向服务器发送 SIP 请求&#xff0c;并检查收到的响应。它以以下模式之一…...

Caliper 负载(Workload)详细解析

Caliper 负载(Workload)详细解析 负载(Workload)是 Caliper 性能测试的核心部分,它定义了测试期间要执行的具体合约调用行为和交易模式。下面我将全面深入地讲解负载的各个方面。 一、负载模块基本结构 一个典型的负载模块(如 workload.js)包含以下基本结构: use strict;/…...

Vite中定义@软链接

在webpack中可以直接通过符号表示src路径&#xff0c;但是vite中默认不可以。 如何实现&#xff1a; vite中提供了resolve.alias&#xff1a;通过别名在指向一个具体的路径 在vite.config.js中 import { join } from pathexport default defineConfig({plugins: [vue()],//…...