Windows GTK+ 环境搭建(详解)
来源:http://blog.sina.com.cn/s/blog_a6fb6cc901017ygy.html
Windows GTK+ 环境搭建
最近要做界面的一些东西,但是对微软提供的类库MFC不是很熟悉,里面封装了大量的Windows API比较麻烦,然后就想着其他方式吧!Qt、GTK+原本想学学Qt的,Qt跨平台、文档也多点,使用也更广泛。但是Qt的插件一直没有下载下来,然后就先学习学习GTK+吧!
在网上搜了好多关于Windows GTK+环境搭建的方法,但是很多说的都不是很清楚,所以自己就参考了一些文档,在官网上下载了所需的环境文件,自己搭建了GTK+的环境。并进行了详细的记录,以下是主要内容。
下载gtk All-in-one bundles包
好了,言归正传吧!开始我们的Windows GTK+ 环境搭建环节。主要分为以下几步:
1) 进入官网www.gtk.org开始先了解学习一些有关GTK+的内容。
GTK+ 环境搭建(详解)" name="image_operate_34581347010438522" alt="Windows GTK+ 环境搭建(详解)" src="http://s1.sinaimg.cn/middle/a6fb6cc9tc919061a1840&690" width="470" height="254" real_src="http://s1.sinaimg.cn/middle/a6fb6cc9tc919061a1840&690">
2) 点击”Download”进入下载页面,找到自己的Windows所对应的环境Win32或者Win64链接,点击进入。
GTK+ 环境搭建(详解)" name="image_operate_41151347010438190" alt="Windows GTK+ 环境搭建(详解)" src="http://s10.sinaimg.cn/middle/a6fb6cc9tc9192a8b7879&690" width="359" height="316" real_src="http://s10.sinaimg.cn/middle/a6fb6cc9tc9192a8b7879&690">
3)若要下载、解压、整理那些单独的文件,则不是很方便,所以就可以选择有”All-in-one bundles” 的链接,点击下载。
4) 下载成功后,解压到任意一个目录底下即可,我选择的是” E:\Visual Studio\GTK Env”,即VS工程目录(不是安装目录)下的GTK EnV(gtk environment),
解压完成之后可以看到一些目录文件夹,主要包括:bin、etc、include、lib、man、manifest、share、src。其中bin目录下主要包含一些可执行文件和动态链接库,lib目录主要包含一些库文件、include主要包含的是一些头文件。
设置环境变量
1) 配置环境变量Path
如我所选,将”E:\Visual Studio\GTK Env\bin”加入到环境变量”Path”中。bin目录中包含有运行时所需的dll文件,其中也包括gtk-demo.exe示例程序。
2) 测试运行
运行” E:\Visual Studio\GTK Env\bin\gtk-demo.exe”示例程序,可以显示如下程序界面。
设置VS2008编译环境
设置附加包含目录
右击工程,选择属性->C/C++->常规->附加包含目录,添加GTK+目录下的include文件夹和include文件夹里的所有文件夹,还有lib文件夹的子文件夹里面的两个include文件夹,如下图所示。
设置附加库目录
转到库文件视图,添加GTK+目录的lib文件夹。设置附加库目录:选择链接器->常规->附加库目录,添加GTK+目录下的lib文件夹,如下图所示。
添加附加依赖项
新建C++的空项目,在项目->属性->链接器->输入->附加依赖项,将” E:\Visual Studio\GTK Env\lib”目录下的所有.lib文件都放到附加依赖项中,其中包括:atk-1.0.lib、cairo.lib、expat.lib、fontconfig.lib、freetype.lib、gailutil.lib、gdk_pixbuf-2.0.lib、gdk-win32-2.0.lib、gio-2.0.lib、glib-2.0.lib、gmodule-2.0.lib、gobject-2.0.lib、gthread-2.0.lib、gtk-win32-2.0.lib、intl.lib、libpng.lib、pango-1.0.lib、
pangocairo-1.0.lib、pangoft2-1.0.lib、pangowin32-1.0.lib、zdll.lib。
测试
新建CPP文件,写入如下代码,可以正常运行则配置成功。
#include
int main (int argc, char *argv[])
{
GtkWidget *window;
GtkWidget *label;
//初始化GTK+库
gtk_init(&argc, &argv);
//创建主窗口
window = gtk_window_new(GTK_WINDOW_TOPLEVEL);
//设置窗口大小
gtk_widget_set_size_request(window,300,300);
//设置标题
gtk_window_set_title(GTK_WINDOW (window), "Hello World");
//当窗口即将被销毁,停止主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);
//设置窗口中的所有元素可见
gtk_widget_show_all(window);
//开始主循环,让它在那里休息,直到应用程序关闭
gtk_main();
return 0;
}
显示如下:
这样,我们的GTK+在Windows下的环境就搭建好了,Hello World也编写成功了,呵呵,不足之处还有待改善,希望以后能有机会再更好更多的研究下GTK+和QT吧!
Windows GTK+ 环境搭建(详解)的更多相关文章
- Python环境搭建详解(Window平台)
前言 Python,是一种面向对象的解释型计算机程序设计语言,是纯粹的自由软件,Python语法简洁清晰,特色是强制用空白符作为语句缩进,具有丰富和强大的库,它常被称为胶水语言. Python是一种解 ...
- Windows下的SVN环境搭建详解
前言:最近因为要和其他人合作开发项目,所以花时间搭建了SVN的环境. 因为是初次使用SVN,对于SVN的环境搭建很不熟悉,再加上网上的教程都介绍的比较粗略,导致前前后后重做了几次. 当然最终是搭建成功 ...
- Vue.js 运行环境搭建详解(基于windows的手把手安装教学)及vue、node基础知识普及
Vue.js 是一套构建用户界面的渐进式框架.他自身不是一个全能框架——只聚焦于视图层.因此它非常容易学习,非常容易与其它库或已有项目整合.在与相关工具和支持库一起使用时,Vue.js 也能完美地驱动 ...
- AngularJS4.0环境搭建详解--windows系统环境
第一步:安装NodeJS 下载最新版的NodeJS并安装,安装完成后打开CMD命令行,输入以下命令: node -v 若返回类似版本号则代表NodeJS安装成功,如下: 第二部 安装npm 新版的No ...
- windows 64位下,React-Native环境搭建详解 (Android)
React-Native环境搭建需要: 1.安装Java JDK 2.安装Android Studio 3.安装node.js 4.安装git 5.安装Python 2.x (注意目前不支持Pytho ...
- nginx+php环境搭建详解(Linux)
今天在内网环境下,给linux主机安装nginx+php环境,由于是内网环境,只能手动解压缩包进行安装,在这过程中我也着实遇到了一些问题(困扰了我许久),还好最后搭建环境成功了,所以写篇博客记录一下, ...
- python webdriver 环境搭建详解
学了一个月用java编写selenium driver 测试脚本,也将公司做的系统基本可用的模块做了一次自动化,虽然写的比较简陋,但是基本可用跑一遍,并用testNG生成了测试报告. 学习方式无非是: ...
- eclipseIDE for javaee developers 开发环境搭建详解图文
使用eclipse真的有年头了,相信java程序员没有不知道它的,最近在给团队中新来的应届生做指导,专门讲解了一下Eclipse开发环境的搭建过程,一是帮助他们尽快的熟悉IDE的使用,二也是保证团队开 ...
- Windows7 QT5.6.0(64位)使用mysql(64位)环境搭建详解
1 说明 使用环境为:Windows7 VS2015 QT5.6.0(64位),MYSQL 5.7.13(64位). 网上各种错误.模糊.抽象的资料,配置环境花了半天,痛定思痛,总结出来,方便后来人. ...
随机推荐
- Spring第二天
Spring第二天 整体课程安排(3天+2天): 第一天:Spring框架入门.IoC控制反转的配置管理.Spring Web集成.Spring Junit集成. 第二天:Spring AOP面向切面 ...
- 使用JavaScript把页面上的表格导出为Excel文件
如果在页面上展示了一个数据表格,而用户想把这个表格导出为Excel文件,那么在要求不高的情况下,可以不通过服务器生成表格,而是直接利用JavaScript的Blob和Object URL特性将表格导出 ...
- [妙味JS基础]第九课:定时器管理、函数封装
知识点总结 函数封装 回调函数 实例:抖动函数 获取当前的位置 通过数组来实现,一正一负,直到恢复成0为止. 当前位置与数组中各值相加
- JavaScript忍者秘籍——函数(下)
概要:本篇博客主要介绍函数的一些类型以及常见示例 1.匿名函数 使用匿名函数的常见示例: window.onload = function(){ assert(true,'power!'); }; / ...
- XML 用途
XML 用途 XML 应用于 Web 开发的许多方面,常用于简化数据的存储和共享. XML 把数据从 HTML 分离 如果您需要在 HTML 文档中显示动态数据,那么每当数据改变时将花费大量的时间来编 ...
- 4、MySql的存储过程
C:\Program Files\MySQL\MySQL Server 5.1\bin 1.1 定义无参数的存储过程//定义语句结束用//delimiter //create procedure pr ...
- 2、为Eclipse绑定Tomcat
1.window→preferences打开属性窗口 2.点击add 3.点击Tomcat6.0 点击next 4.选择tomcat的解压目录和jdk,并点击finish 5.点击ok 6.打开ser ...
- MVC5 Entity Framework学习之创建复杂的数据模型
目录(?)[-] 使用属性来自定义数据模型 DataType属性 StringLength属性 Column 属性 完成对Student实体的更改 Required 属性 Display 属性 Ful ...
- css样式的部分拓展, NuMber对象、 BoM、 DoM对象的模型的间述,ing...
css部分代码 <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> < ...
- jQuery,使用on代替delegate,live 写法区别
早期对页面上后期加载的动态元素,赋事件或值的时候,是使用live的. 由于效率比较低(其实数据不多也感觉不出来),后面使用delegate委托来代替了,再后面,1.7以后使用on 来代替delega ...