我正在尝试使用cairo绘制GtkLayout。布局很大,我需要获取容器窗口中可见的部分并仅更新该部分。使用GTK2,公开事件数据就足以完成此任务。我没有成功使用GTK3。
在处理“绘制”事件的功能中,我做了以下事情:
GdkWindow *gdkwin; // window to draw
cairo_region_t *cregion; // update regions
cairo_rectangle_int_t crect; // enclosing rectangle
gdkwin = gtk_layout_get_bin_window(GTK_LAYOUT(layout));
cregion = gdk_window_get_update_area(gdkwin);
cairo_region_get_extents(cregion,&crect);
expy1 = crect.y; // top of update area
expy2 = expy1 + crect.height; // bottom of update area
问题是cregion有垃圾。 gdk_window_get_update_area()是错误的,或者我没有使用正确的绘图窗口。
如下传递GtkLayout也不起作用(这是g_signal_connect的函数arg):
void draw_function(GtkWidget *layout, cairo_t *cr, void *userdata)
传递的内容不是来自g_signal_connect的GtkLayout,而是其他内容。
=================更新====================
我找到了一种方法,可以在不使用GtkLayout的情况下做我想做的事情。 我在视口中使用GtkDrawingArea。 我可以滚动到大图形布局中的任何窗口 并仅更新该窗口。一旦我发现,就能很好地运作 神秘的文档。
scrwing = gtk_scrolled_window_new(0,0);
gtk_container_add(GTK_CONTAINER(vboxx),scrwing);
drwing = gtk_drawing_area_new();
gtk_scrolled_window_add_with_viewport(GTK_SCROLLED_WINDOW(scrwing),drwing);
gtk_scrolled_window_set_policy(SCROLLWIN(scrwing),ALWAYS,ALWAYS);
scrollbar = gtk_scrolled_window_get_vadjustment(GTK_SCROLLED_WINDOW(scrwing));