Gtk+/Glade 编程(四)布局管理

By unanao
<sunjianjiao@gmail.com>
     
    本文是根据只使用Gtk+的文章 http://zetcode.com/tutorials/gtktutorial/gtklayoutmanagement/,将文中的例子使用Glade实现的。
    当我们设计我们的GUI应用程序时,我们确定使用哪些组件,以及如何组织这些组件。我们使用不可见得“布局容器”对组件进行组织,这一章,我们会使用Glade实现GtkAlignment, GtkFixed, GtkVBox和GtkTable。

一、GtkFixed
    GtkFixed容器将子组件放在固定的位置,并且大小固定。这个容器没有自动的布局管理,在大多数的应用程序中,我们不实用GtkFixed 容器。但是有一些特殊的地方,我们使用这个容器。例如游戏,与图表协作的特殊应用程序,可移动并且可以改变大小的组件(如一个在电子表格中的图表),用于教学的小程序。
    由于叫布局容器,所以GtkFixed在容器中,中文叫“固定的”。
在Glade中选择组件
1.1 在"顶层"中,选择“窗口”
1.2 在"容器"中,选择“固定的”
1.3 在“控制和显示”中,选择“按钮”
1.4 可以通过工具栏中“拖拽并调整工作区部件的大小”调整组件的位置和组件的大小

编写Gtk+程序
unanao@debian:~/Experiment/gui/layout-mgt$ cat gtkfixed.c
/**
 * @file gtkfixed.c
 * @brief simple use of GtkFixed container 
 * @author unanao <sunjianjiao@gmai.com>
 * @version 0.1
 * @date 2011-03-17
 */
#include <gtk/gtk.h>

int main(int argc, char *argv[])
{
GtkWidget *window;
GtkBuilder *builder;

gtk_init(&argc, &argv);

builder = gtk_builder_new();
gtk_builder_add_from_file(builder, "gtkfixed.glade", NULL);

window = GTK_WIDGET(gtk_builder_get_object(builder, "window1"));

g_signal_connect(window, "destroy", G_CALLBACK(gtk_main_quit), NULL);
gtk_widget_show_all(window);

gtk_main();

return 0;
}
编译执行:
unanao@debian:~/Experiment/gui/layout-mgt$ gcc -o gtkfixed gtkfixed.c -Wall `pkg-config --cflags --libs gtk+-2.0`
unanao@debian:~/Experiment/gui/layout-mgt$ ./gtkfixed
Gtk+/Glade  编程(四)布局管理 - unanao - unanao
 

二、GtkVBox
GtkVBox是一个盒子容器,可以将1个组件放到其中的1行里面(1个格子里)。
使用Glade设计gui
1、添加1个窗口
2、在“容器”中选择“垂直框”,设置条目数为6
3、向每一个长方条的框中添加按钮,别且修改,按钮的属性

编写gtk+程序:
/**
 * @file gtkvbox.c
 * @brief Simple example about using GtkVbox with Glade
 * @author unanao <sunjianjiao@gmai.com>
 * @version 0.1
 * @date 2011-03-19
 */
#include <gtk/gtk.h>

int main(int argc, char *argv[])
{
GtkWidget *window;
GtkBuilder *builder;

gtk_init(&argc, &argv);

builder = gtk_builder_new();
gtk_builder_add_from_file(builder, "gtkvbox.glade", NULL);

window = GTK_WIDGET(gtk_builder_get_object(builder, "window1"));

g_signal_connect(window, "destroy", G_CALLBACK(gtk_main_quit), NULL);

gtk_widget_show_all(window);

gtk_main();

return 0;
}
编译:gcc -o gtkvbox gtkvbox.c -Wall `pkg-config --cflags --libs gtk+-2.0`
执行:./gtkvbox
Gtk+/Glade  编程(四)布局管理 - unanao - unanao
三、GtkTable
GtkTable的是用方法与GtkVBox的方法基本一样,只是一些表各种添加组件。
设计1个计算器的gui
使用Glade设计GUI
1、添加窗口
2、在“容器”中选择“表格” -- 4*4
3、添加按钮,并且设置按钮的属性(标签)

编写GTK+程序:
unanao@debian:~/Experiment/gui/layout-mgt$ cat gtktable.c
/**
 * @file gtktale.c
 * @brief simple example about how to use gtktable with glade
 * @Compile gcc -o gtktable gtktable.c -Wall `pkg-config --cflags --libs gtk+-2.0`
 *
 * @author unanao <sunjianjiao@gmai.com>
 * @version 0.1
 * @date 2011-03-19
 */
#include <gtk/gtk.h>

int main(int argc, char *argv[])
{
    GtkWidget *window;
    GtkBuilder *builder;

    gtk_init(&argc, &argv);

    builder = gtk_builder_new();
    gtk_builder_add_from_file(builder, "gtktable.glade", NULL);

    window = GTK_WIDGET(gtk_builder_get_object(builder, "window1"));
   
    gtk_widget_show_all(window);
   
    gtk_main();

    return 0;
}
执行结果:
Gtk+/Glade  编程(四)布局管理 - unanao - unanao
 四、GtkAlignment
控制子组件的对其方式和大小
1、添加一个窗口:
2、添加一个垂直框“,条目数为1
3、在垂直框上加入一个”对齐“(在容器中)
4、这只对齐的属性:
Gtk+/Glade  编程(四)布局管理 - unanao - unanao
水平排列:1左右边,0 最左边
垂直排列:1最下边,0最上边
缩放比例:是否随着窗口的变化而变化,0为不变化。

5、添加“水平框”(在容器中),并且设置属性

 
Gtk+/Glade  编程(四)布局管理 - unanao - unanao
间距设置两个框之间的间距。
6、向“水平框”中添加两个按钮--标签为ok 和 close

Gtk+程序:
/**
 * @file gtkalignment.c
 * @brief simple use of GtkAlignment container
 * @author unanao <sunjianjiao@gmai.com>
 * @version 0.1
 * @date 2011-03-17
 */
#include <gtk/gtk.h>

int main(int argc, char *argv[])
{
    GtkWidget *window;
    GtkBuilder *builder;
   

    gtk_init(&argc, &argv);

    builder = gtk_builder_new();
    gtk_builder_add_from_file(builder, "gtkalignment.glade", NULL);

    window = GTK_WIDGET(gtk_builder_get_object(builder, "window1"));

    g_signal_connect(window, "destroy", G_CALLBACK(gtk_main_quit), NULL);   
    gtk_widget_show_all(window);

    gtk_main();

    return 0;
}
执行结果:
Gtk+/Glade  编程(四)布局管理 - unanao - unanao
 
 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值