Webkit自带谷歌浏览器实例分析(2)

    技术2022-05-19  17

    作者:水木杨

         上篇说到,咱们把main函数走了一遍了,是不是可以写个基于webkit简单的浏览器了呢?

    非也,,,其实即便是这么简单的浏览器,代码也还没完。Main函数只是整个程序的一个入口而已,也就是说只是个门口,,,~~~~(>_<)~~~~ 好辛苦啊……里边东西多着哩!

    还有三个创建整个浏览器界面的函数,不过我认为对了解Gtk的人来说应该不是很麻烦,只是核心部分是与webkit的接口,是不是还是像上节那样一直挖下去呢?快来看看吧~

    还是先找重点的那三个函数。。。

    /*严格来说这个例子很懒,直接定义在main函数之前了,有点乱是不*/

    static GtkWidget* create_toolbar (){} /*返回个工具栏,,,有点废话哈~*/

    static GtkWidget* create_browser (){}/*返回个browser,,,依然废话哈~,这个browser是什么哇?有点犯嘀咕*/

    static GtkWidget* create_statusbar (){}  /*这个好理解多了*/

     

    /*Come on baby!创建工具栏啦*/

    static GtkWidget*

    create_toolbar ()

    {

        GtkWidget* toolbar = gtk_toolbar_new (); /*创建一个工具栏部件*/

     

    #if GTK_CHECK_VERSION(2,15,0) /*检查GTK+的版本,版本要比括号中的新才好*/

        gtk_orientable_set_orientation (GTK_ORIENTABLE (toolbar), GTK_ORIENTATION_HORIZONTAL);

    #else

        gtk_toolbar_set_orientation (GTK_TOOLBAR (toolbar),

    /*设置工具箱是水平显示还是垂直显示*/ GTK_ORIENTATION_HORIZONTAL);

    #endif

        /*设置toolbar风格GTK_TOOLBAR_BOTH_HORIZ 是自定义的*/

        gtk_toolbar_set_style (GTK_TOOLBAR (toolbar), GTK_TOOLBAR_BOTH_HORIZ);

     

        GtkToolItem* item; /*新建一个小家伙,准备暂存工具栏的控件*/

     

        /* 后退按钮下边红色部分函数是从储存库中得到GTK_STOCK_GO_BACK图标*/

        item = gtk_tool_button_new_from_stock (GTK_STOCK_GO_BACK);

     

    /*将信号click与item部件绑定,点击按钮时候调用go_back_cb ,null是要传给回调函数的参数,这里为空。一会再分析回调函数,回调函数一般cb结尾*/

        g_signal_connect (G_OBJECT (item), "clicked", G_CALLBACK (go_back_cb), NULL);

        gtk_toolbar_insert (GTK_TOOLBAR (toolbar), item, -1);/*负1表示从工具栏的最后第一个位置追加*/

     

        /* 前进按钮,同上,就不罗嗦了 */

        item = gtk_tool_button_new_from_stock (GTK_STOCK_GO_FORWARD);

        g_signal_connect (G_OBJECT (item), "clicked", G_CALLBACK (go_forward_cb), NULL);

        gtk_toolbar_insert (GTK_TOOLBAR (toolbar), item, -1);/*追加到最后一个*/

     

        /* 地址输入栏,,,注意了啊,含金量的地方!O(∩_∩)O */

        item = gtk_tool_item_new ();

        gtk_tool_item_set_expand (item, TRUE);/*将item放大占据额外的控件*/

        uri_entry = gtk_entry_new ();/*创建一个网址输入框直接加到工具栏可否?*/

        gtk_container_add (GTK_CONTAINER (item), uri_entry);/*放到item中去*/

        g_signal_connect (G_OBJECT (uri_entry), "activate", G_CALLBACK (activate_uri_entry_cb), NULL);

        gtk_toolbar_insert (GTK_TOOLBAR (toolbar), item, -1);

     

        /* The go button */

        item = gtk_tool_button_new_from_stock (GTK_STOCK_OK);

     

           /* g_signal_connect_swapped 与g_signal_connect 意思一样,只不过前者的回调函数有一个参数,也就是g_signal_connect_swapped的第四个参数,这次非空了噶 */

        g_signal_connect_swapped (G_OBJECT (item), "clicked", G_CALLBACK (activate_uri_entry_cb), (gpointer)uri_entry);

        gtk_toolbar_insert (GTK_TOOLBAR (toolbar), item, -1);

     

        return toolbar;

    }/*工具栏创建完毕,,,先把这三个函数看完,待会去看回调函数去*/

     

     

     

    /*创建browser,何为browser,,,我也不知道,不过一会就知道了*/

    static GtkWidget*

    create_browser ()

    {   /*先创建一个带滚动条的滚动窗,原来如此,滚动条是滚动窗的一部分啊*/

        GtkWidget* scrolled_window = gtk_scrolled_window_new (NULL, NULL);

    /*为滚动条设置一个方针,GTK_POLICY_AUTOMATIC 意思是需要时候才显示*/

        gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (scrolled_window), GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC);

    /*这个是全局变量,相当于一个view就是(标题栏+页面)视图,然后放入滚动窗*/

        web_view = WEBKIT_WEB_VIEW (webkit_web_view_new ());

        gtk_container_add (GTK_CONTAINER (scrolled_window), GTK_WIDGET (web_view));

     

    g_signal_connect (web_view, "title-changed", G_CALLBACK (title_change_cb), web_view);/* title-changed信号与web_view绑定.时间发生调用title_change_cb回调函数改变标题*/

        g_signal_connect (web_view, "notify::load-status", G_CALLBACK (notify_load_status_cb), web_view);/*加载状态*/

        g_signal_connect (web_view, "notify::progress", G_CALLBACK (notify_progress_cb), web_view);/*加载进度*/

        g_signal_connect (web_view, "hovering-over-link", G_CALLBACK (link_hover_cb), web_view);

     

        return scrolled_window;

    } /*至此带滚动条的窗口创建完毕,,,回调函数与信号回头一起研究*/

     

     

    static GtkWidget*

    create_statusbar ()

    {

        main_statusbar = GTK_STATUSBAR (gtk_statusbar_new ());

        status_context_id = gtk_statusbar_get_context_id (main_statusbar, "Link Hover");

     

        return (GtkWidget*)main_statusbar;

    }/*创建状态栏*/

     

    /*下面该创建个东西放这三个:工具栏、状态栏、browser了,创建mainwindow*/

    static GtkWidget*

    create_window ()

    {

            /*创建一个主窗口*/

        GtkWidget* window = gtk_window_new (GTK_WINDOW_TOPLEVEL);

        /*设置默认大小*/

        gtk_window_set_default_size (GTK_WINDOW (window), 800, 600);

        gtk_widget_set_name (window, "GtkLauncher");/*设置窗口名字*/

       

        /*绑定销毁回调函数,一般来说都会有这个函数的*/

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

     

        return window;

    }/*主窗口创建完毕*/

    目前为止,整个程序基本上走完了一遍,程序的第二个层次也已分析完毕,,,剩下的回调函数部分是与webkit接触最为紧密的一部分,且听下回细细道来


    最新回复(0)