分享

How Webkit render a button | Fan's blog

 mediatv 2014-07-29

看了这位老兄的blog后,我对webkit 也有了兴趣。webkit可以根据布局结构来动态的产生HTML控件,这个在很多可视化开发工具里面可以看到,比如Netbeans,XCode都可以用 拖放的方式开发UI。我原来很好奇,这些IDE是如何显示这些控件的呢?因为这些控件和IDE本身的控件有一致外观(OS的主题外观),如果使用普通的 API来搞,比如”new JButton()”来构造UI,感觉有点头晕。

找了下,webkit的代码Source\WebCore\platform\gtk\RenderThemeGtk3.cpp是用来创建 Gnome 3外观风格的控件,比如方法paintToggle就是对应单选框。我把里面的代码抽取出来,做了个小例子。费了老大劲,因为压根不知道如何得到 context和cairo_t这些上下文信息(或者称为状态机,Functional Language反感的就是这个)。GTK的getting started在这里

01/**
02  this code show how to render a button with gtk 3
03  Some code copy from webkit/Source/WebCore/platform/gtk
04*/
05 
06#include <gtk/gtk.h>
07static gboolean
08draw_cb (GtkWidget *widget, cairo_t *cr){
09  GtkStyleContext *context;
10  context = gtk_widget_get_style_context (widget);
11  gtk_style_context_save(context);
12  gtk_style_context_add_class(context,GTK_STYLE_CLASS_CHECK );
13  gtk_style_context_set_state(context, GTK_STATE_FLAG_ACTIVE);
14 
15  int i;
16  for(i = 0; i < 20; i++){
17    <strong>gtk_render_check</strong>(context, cr, 10*(i+1), 10*(i+1), 10, 10);
18  }
19  gtk_style_context_restore(context);
20}
21 
22int
23main (int   argc, char *argv[]){
24  GtkWidget *window;
25  GtkWidget *ebox;
26 
27  gtk_init (&argc, &argv);
28 
29  window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
30  ebox = gtk_event_box_new ();
31  gtk_event_box_set_visible_window (GTK_EVENT_BOX (ebox), TRUE);
32  gtk_container_add (GTK_CONTAINER (window), ebox);
33  g_signal_connect_after (ebox, "draw", G_CALLBACK (draw_cb), NULL);
34  g_signal_connect (window, "destroy", G_CALLBACK (gtk_main_quit), NULL);
35 
36  gtk_widget_show_all (window);
37 
38  gtk_main ();
39 
40  return 0;
41}

上面的截图中可以看到checkbox有native的looking(本人非Nike控),不同的是这些控件只是画上去的(没有JButton这 种类的层次结构),没有event binding,也就是MVC只有MV。C的一块可能就由浏览器接过来来统一管理,那得遵循HTML Dom Event Model的规范。

这里不考虑CSS的外观。Gnome 3也是用CSS来控制外观,不知道是不是借鉴webkit。Windows的theme我还没有找到在哪里。

从webkit的代码看其已经支持Gtk+-3.0的back-end,不过Chrome还没有推出相应版本,据说是因为他跟Gtk+-2.0绑的太紧,跟Ubuntu走的太近(Ubuntu没有支持gnome 3)。唉,才几年又轻又快的东东就成了个史前巨无霸。

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多