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

挑战杯推荐项目

“人工智能”创意赛 - 智能艺术创作助手&#xff1a;借助大模型技术&#xff0c;开发能根据用户输入的主题、风格等要求&#xff0c;生成绘画、音乐、文学作品等多种形式艺术创作灵感或初稿的应用&#xff0c;帮助艺术家和创意爱好者激发创意、提高创作效率。 ​ - 个性化梦境…...

python打卡day49

知识点回顾&#xff1a; 通道注意力模块复习空间注意力模块CBAM的定义 作业&#xff1a;尝试对今天的模型检查参数数目&#xff0c;并用tensorboard查看训练过程 import torch import torch.nn as nn# 定义通道注意力 class ChannelAttention(nn.Module):def __init__(self,…...

基于uniapp+WebSocket实现聊天对话、消息监听、消息推送、聊天室等功能,多端兼容

基于 ​UniApp + WebSocket​实现多端兼容的实时通讯系统,涵盖WebSocket连接建立、消息收发机制、多端兼容性配置、消息实时监听等功能,适配​微信小程序、H5、Android、iOS等终端 目录 技术选型分析WebSocket协议优势UniApp跨平台特性WebSocket 基础实现连接管理消息收发连接…...

【机器视觉】单目测距——运动结构恢复

ps&#xff1a;图是随便找的&#xff0c;为了凑个封面 前言 在前面对光流法进行进一步改进&#xff0c;希望将2D光流推广至3D场景流时&#xff0c;发现2D转3D过程中存在尺度歧义问题&#xff0c;需要补全摄像头拍摄图像中缺失的深度信息&#xff0c;否则解空间不收敛&#xf…...

1.3 VSCode安装与环境配置

进入网址Visual Studio Code - Code Editing. Redefined下载.deb文件&#xff0c;然后打开终端&#xff0c;进入下载文件夹&#xff0c;键入命令 sudo dpkg -i code_1.100.3-1748872405_amd64.deb 在终端键入命令code即启动vscode 需要安装插件列表 1.Chinese简化 2.ros …...

linux 错误码总结

1,错误码的概念与作用 在Linux系统中,错误码是系统调用或库函数在执行失败时返回的特定数值,用于指示具体的错误类型。这些错误码通过全局变量errno来存储和传递,errno由操作系统维护,保存最近一次发生的错误信息。值得注意的是,errno的值在每次系统调用或函数调用失败时…...

自然语言处理——循环神经网络

自然语言处理——循环神经网络 循环神经网络应用到基于机器学习的自然语言处理任务序列到类别同步的序列到序列模式异步的序列到序列模式 参数学习和长程依赖问题基于门控的循环神经网络门控循环单元&#xff08;GRU&#xff09;长短期记忆神经网络&#xff08;LSTM&#xff09…...

Java + Spring Boot + Mybatis 实现批量插入

在 Java 中使用 Spring Boot 和 MyBatis 实现批量插入可以通过以下步骤完成。这里提供两种常用方法&#xff1a;使用 MyBatis 的 <foreach> 标签和批处理模式&#xff08;ExecutorType.BATCH&#xff09;。 方法一&#xff1a;使用 XML 的 <foreach> 标签&#xff…...

AirSim/Cosys-AirSim 游戏开发(四)外部固定位置监控相机

这个博客介绍了如何通过 settings.json 文件添加一个无人机外的 固定位置监控相机&#xff0c;因为在使用过程中发现 Airsim 对外部监控相机的描述模糊&#xff0c;而 Cosys-Airsim 在官方文档中没有提供外部监控相机设置&#xff0c;最后在源码示例中找到了&#xff0c;所以感…...

[免费]微信小程序问卷调查系统(SpringBoot后端+Vue管理端)【论文+源码+SQL脚本】

大家好&#xff0c;我是java1234_小锋老师&#xff0c;看到一个不错的微信小程序问卷调查系统(SpringBoot后端Vue管理端)【论文源码SQL脚本】&#xff0c;分享下哈。 项目视频演示 【免费】微信小程序问卷调查系统(SpringBoot后端Vue管理端) Java毕业设计_哔哩哔哩_bilibili 项…...