码迷,mamicode.com
首页 > 其他好文 > 详细

GTK入门学习:布局容器之水平布局

时间:2015-07-25 12:27:32      阅读:135      评论:0      收藏:0      [点我收藏+]

标签:

如果我们希望窗口里多放添加几个控件,直接添加是不成功的,因为窗口只能容纳一个控件的容器。这时候,我们需要借助布局容器,我们先把布局容器添加到窗口里,然后再把所需要添加的控件放在布局容器里。


布局容器的主要分类:水平布局( GtkHBox)、垂直布局(GtkVBox )、表格布局(GtkTable)、固定布局(GtkFixed )。


水平布局容器:


水平布局容器的创建:
GtkWidget *gtk_hbox_new( gboolean homogeneous,  

gint spacing );

homogeneous:容器内控件是否大小一致( gboolean 取值为TRUE 或 FALSE )
spacing:控件之间的间隔( 以像素点为单位 ),gint相当于 C语言的int
返回值:水平布局控件指针


容器添加添加控件:
void gtk_container_add(GtkContainer *container, 

GtkWidget *widget);

container:容纳控件的容器
widget:要添加的控件


显示容器上所有控件
void gtk_widget_show_all(GtkWidget *widget);
widget:需要显示的控件


完整代码如下:

#include <gtk/gtk.h>

int main(int argc,char *argv[])
{
        //1.gtk环境初始化
        gtk_init(&argc, &argv);

        //2.创建一个窗口
        //GtkWidget *window = gtk_window_new(GTK_WINDOW_POPUP);

        GtkWidget *window = gtk_window_new(GTK_WINDOW_TOPLEVEL);

        //设置窗口标题
        gtk_window_set_title(GTK_WINDOW(window), "hbox");

        //3.1创建一个水平容器
        GtkWidget *hbox = gtk_hbox_new(TRUE, 10);
        //3.2将水平容器加入到窗口中
        gtk_container_add(GTK_CONTAINER(window), hbox);

        //4.1.1创建按钮button1
        GtkWidget *button1 = gtk_button_new_with_label("button1");
        //4.1.2将button1加入到hbox中
        gtk_container_add(GTK_CONTAINER(hbox), button1);

        //4.2.1创建按钮button2
        GtkWidget *button2 = gtk_button_new_with_label("button2");
        //4.2.2将button2加入到hbox
        gtk_container_add(GTK_CONTAINER(hbox), button2);

        //4.3.1创建按钮button2
        GtkWidget *button3 = gtk_button_new_with_label("button3");
        //4.3.2将button2加入到hbox
        gtk_container_add(GTK_CONTAINER(hbox), button3);

        //5.显示所有文件
        gtk_widget_show_all(window);

        //6.主事件循环
        gtk_main();

        return 0;
}

运行结果:

技术分享

源码下载:http://download.csdn.net/download/lianghe_work/8931851


转自:http://blog.csdn.net/tennysonsky/article/details/42741907

阿斯达

版权声明:本文为博主原创文章,未经博主允许不得转载。

GTK入门学习:布局容器之水平布局

标签:

原文地址:http://blog.csdn.net/lianghe_work/article/details/47053903

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!