解决了!
通过持续的研究、搜索论坛和源代码存储库,我拼凑了必要的步骤,仅使用 libwebkit 和标准的 compiz 桌面(任何具有合成功能的 Xorg 桌面都应该这样做)来完成此任务。
对于当前的 libwebkit (1.1.10-SVN),有一个 Ubuntu PPA:
deb http://ppa.launchpad.net/webkit-team/ppa/ubuntu jaunty main
deb-src http://ppa.launchpad.net/webkit-team/ppa/ubuntu jaunty main
就代码而言,关键是调用webkit_web_view_set_transparent
.
当然,您运行它的系统应该有一个功能强大的显卡(intel、radeon 或 nvidia)并运行一个合成窗口管理器(如 Compiz)。
最后,要真正看到透明度,您正在查看的内容必须使用 CSS3 设置透明背景,否则它仍然是完全不透明的。
它很简单:
BODY { background-color: rgba(0,0,0,0); }
这是最简单的 webkit 浏览器应用程序的完整示例,具有透明度支持:
#include <gtk/gtk.h>
#include <webkit/webkit.h>
static void destroy_cb(GtkWidget* widget, gpointer data) {
gtk_main_quit();
}
int main(int argc, char* argv[]) {
gtk_init(&argc, &argv);
if(!g_thread_supported())
g_thread_init(NULL);
// Create a Window, set colormap to RGBA
GtkWidget* window = gtk_window_new(GTK_WINDOW_TOPLEVEL);
GdkScreen *screen = gtk_widget_get_screen(window);
GdkColormap *rgba = gdk_screen_get_rgba_colormap (screen);
if (rgba && gdk_screen_is_composited (screen)) {
gtk_widget_set_default_colormap(rgba);
gtk_widget_set_colormap(GTK_WIDGET(window), rgba);
}
gtk_window_set_default_size(GTK_WINDOW(window), 800, 800);
g_signal_connect(window, "destroy", G_CALLBACK(destroy_cb), NULL);
// Optional: for dashboard style borderless windows
gtk_window_set_decorated(GTK_WINDOW(window), FALSE);
// Create a WebView, set it transparent, add it to the window
WebKitWebView* web_view = web_view = WEBKIT_WEB_VIEW(webkit_web_view_new());
webkit_web_view_set_transparent(web_view, TRUE);
gtk_container_add (GTK_CONTAINER(window), GTK_WIDGET(web_view));
// Load a default page
webkit_web_view_load_uri(web_view, "http://stackoverflow.com/");
// Show it and continue running until the window closes
gtk_widget_grab_focus(GTK_WIDGET(web_view));
gtk_widget_show_all(window);
gtk_main();
return 0;
}