zoukankan      html  css  js  c++  java
  • GTK+-3.0编程 (四) 网格布局 Grid


    http://www.cnblogs.com/rain-blog/p/gtk3-4.html

      实际的应用中,往往有很多个控件, 同样GTK提供了很多种布局方案,Box, Fixed , Table , Grid 等。

    接下来试试网格布局 Grid。

    我们创建 example4.c ,内容如下:

    #include <gtk/gtk.h>
    
    
    static void print_hello(GtkWidget *button , gpointer data);
    static void activate(GtkApplication *app , gpointer data);
    
    int main(int argc , char **argv)
    {
        GtkApplication *app;
        int app_status;
    
        app = gtk_application_new("org.rain.gtk" , G_APPLICATION_FLAGS_NONE);
        g_signal_connect(app , "activate" , G_CALLBACK(activate) , NULL);
        app_status = g_application_run(G_APPLICATION(app) , argc , argv);
    
        g_object_unref(app);
    
        return app_status;
    }
    
    static void print_hello(GtkWidget *button , gpointer data)
    {
        printf("Hello,World!
    ");
    }
    
    static void activate(GtkApplication *app , gpointer data)
    {
        GtkWidget *window;
        GtkWidget *grid;
        GtkWidget *button;
    
        //创建窗口
        window = gtk_application_window_new(app);
        gtk_window_set_title(GTK_WINDOW(window) , "grid test");
    //    gtk_window_set_default_size(GTK_WINDOW(window) , 200 , 200);
    
        //创建网格
        grid = gtk_grid_new();
        
        //添加网格布局到window上
        gtk_container_set_border_width(GTK_CONTAINER(window) , 20);
        gtk_container_add(GTK_CONTAINER(window) , grid);
    
        //添加按钮一到位置(0,0)处,并设置高,宽均为一个单元
        button = gtk_button_new_with_label("Button1");
        g_signal_connect(button , "clicked" , G_CALLBACK(print_hello) , NULL);
        gtk_grid_attach(GTK_GRID(grid) , button , 0 , 0 , 1 , 1); 
    
        //添加按钮一到位置(1,0)处,并设置高,宽均为一个单元
        button = gtk_button_new_with_label("Button2");
        g_signal_connect(button , "clicked" , G_CALLBACK(print_hello) , NULL);
        gtk_grid_attach(GTK_GRID(grid) , button , 1 , 0 , 1 , 1);
    
        //添加按钮一到位置(0,1)处,并设置高为一个单元,宽为两个单元
        button = gtk_button_new_with_label("Exit");
        g_signal_connect_swapped(button , "clicked" , G_CALLBACK(gtk_widget_destroy) , window);
        gtk_grid_attach(GTK_GRID(grid) , button , 2 , 0 , 1 , 1);
        
        //添加按钮一到位置(1,1)处,并设置高为一个单元,宽为两个单元
        button = gtk_button_new_with_label("Exit");
        g_signal_connect_swapped(button , "clicked" , G_CALLBACK(gtk_widget_destroy) , window);
        gtk_grid_attach(GTK_GRID(grid) , button , 1 , 1 , 2 , 1);
        
        gtk_widget_show_all(window);
    
    }

      编译并运行:

    gcc exampe.c `pkg-config --cflags --libs gtk+-3.0`
    ./a.out

      运行结果:

     gtk_grid_attach(GTK_GRID(grid) , button , 0 , 0 , 1 , 1); 
    
    该函数后面四个参数依次代表:第几行,第几列,横向跨度,纵向跨度。










  • 相关阅读:
    关于Web应用开发流程的总结
    package.json的所有配置项及其用法,你都熟悉么
    curl 命令行工具的使用及命令参数说明
    pytest插件探索——hook开发
    浅探前端图片优化
    使用Flask构建一个Web应用
    原生的js实现jsonp的跨域封装
    CSS定位之BFC背后的神奇原理
    webview错误
    Android 中的webview
  • 原文地址:https://www.cnblogs.com/ztguang/p/12645238.html
Copyright © 2011-2022 走看看