解決しました!
進行中の調査、フォーラムおよびソース コード リポジトリの精査を通じて、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;
}