Python 覆盖容器中具有透明背景的pygtk3标签

Python 覆盖容器中具有透明背景的pygtk3标签,python,label,transparency,pygtk,gtk3,Python,Label,Transparency,Pygtk,Gtk3,我只是想为一个小的makerspace项目快速创建一个GUI,但我被这个细节卡住了。 关于gtk widget透明性有很多类似的问题,但没有一个建议的解决方案适合我。可能是因为我正在使用覆盖容器中的标签? 这是我精简的最小测试用例代码。我希望快照标签的背景(现在是深绿色)是(完全)透明的。显然,gtk忽略了css的argb颜色元组中的alpha值。 也许任何人都有一个黑客的想法来实现这一点 #!/usr/bin/env python import gi gi.require_version('

我只是想为一个小的makerspace项目快速创建一个GUI,但我被这个细节卡住了。 关于gtk widget透明性有很多类似的问题,但没有一个建议的解决方案适合我。可能是因为我正在使用覆盖容器中的标签? 这是我精简的最小测试用例代码。我希望快照标签的背景(现在是深绿色)是(完全)透明的。显然,gtk忽略了css的argb颜色元组中的alpha值。 也许任何人都有一个黑客的想法来实现这一点

#!/usr/bin/env python

import gi
gi.require_version('Gtk', '3.0')
gi.require_version('Gst', '1.0')
gi.require_version('GdkX11', '3.0')
from gi.repository import Gst, GObject, Gtk, GdkX11, Gdk, GstVideo

CSS_DATA = """
.snapshot_label {
background-color: rgba (50, 30, 70, 100);
background: rgba (50, 100, 10, 50);
color: white;
font-weight: bold;
font-size: 60px;
padding: 0 20px 0 20px; 
} """

class GTK_Main:
    def __init__(self):
        window = Gtk.Window(Gtk.WindowType.TOPLEVEL)
        window.set_title("Live Video Preview")
        window.set_default_size(1024, 830)
        window.connect("destroy", Gtk.main_quit, "WM destroy")
        Gtk.Window.fullscreen(window)

        style_provider = Gtk.CssProvider()
        style_provider.load_from_data(CSS_DATA)
        Gtk.StyleContext.add_provider_for_screen(
            Gdk.Screen.get_default(),
            style_provider,
            Gtk.STYLE_PROVIDER_PRIORITY_APPLICATION
        )

        self.overlay = Gtk.Overlay()
        window.add(self.overlay)

        self.movie_window = Gtk.DrawingArea()
        self.movie_window.add_events(Gdk.EventMask.BUTTON_PRESS_MASK)
        self.movie_window.connect("button-press-event", self.snapshot)
        self.overlay.add(self.movie_window)

        vbox = Gtk.VBox()
        hbox = Gtk.HBox()
        vbox.pack_start(hbox, False, False, 0)
        hbox.set_border_width(10)
        hbox.pack_start(Gtk.Label(), False, False, 0)
        self.button_play = Gtk.Button("Start")
        self.button_play.connect("clicked", self.start_stop)
        hbox.pack_start(self.button_play, False, False, 0)
        self.button_quit = Gtk.Button("Quit")
        self.button_quit.connect("clicked", self.exit)
        hbox.pack_start(self.button_quit, False, False, 0)

        vbox.set_valign(Gtk.Align.END)
        vbox.set_halign(Gtk.Align.CENTER)
        self.overlay.add_overlay(vbox)

        self.overlay.show_all()
        window.show_all()

        self.videoplayer = Gst.Pipeline.new("player")
        source = Gst.ElementFactory.make("videotestsrc", "file-source")
        capsfilter = Gst.ElementFactory.make("capsfilter", "capsfilter")
        caps = Gst.Caps.from_string("video/x-raw, width=1024, height=768")
        capsfilter.set_property("caps", caps)
        videosink = Gst.ElementFactory.make("xvimagesink", "video-output")

        for ele in (source, capsfilter, videosink):
            self.videoplayer.add(ele)

        source.link(capsfilter)
        capsfilter.link(videosink)

        bus = self.videoplayer.get_bus()
        bus.add_signal_watch()
        bus.enable_sync_message_emission()
        bus.connect("message", self.on_message)
        bus.connect("sync-message::element", self.on_sync_message)

    def start_stop(self, w):
        if self.button_play.get_label() == "Start":
            self.xid = self.movie_window.get_property('window').get_xid()
            self.button_play.set_label("Stop")
            self.videoplayer.set_state(Gst.State.PLAYING)
        else:
            self.videoplayer.set_state(Gst.State.NULL)
            self.button_play.set_label("Start")

    def snapshot(self, widget, event):
        if event.button == 1 and self.videoplayer.get_state(0).state == Gst.State.PLAYING:
            snapshot_label = Gtk.Label(label="SNAPSHOT!", angle=25, halign=Gtk.Align.END)
            snapshot_label.set_valign(Gtk.Align.CENTER)
            snapshot_label.set_halign(Gtk.Align.CENTER)
            snapshot_label.set_size_request(500, 300)
            snapshot_label.get_style_context().add_class("snapshot_label")
            self.overlay.add_overlay(snapshot_label)
            self.overlay.show_all()

    def exit(self, widget, data=None):
        Gtk.main_quit()

    def on_message(self, bus, message):
        t = message.type
        if t == Gst.MessageType.EOS:
            self.videoplayer.set_state(Gst.State.NULL)
            self.button_play.set_label("Start")
        elif t == Gst.MessageType.ERROR:
            err, debug = message.parse_error()
            print "Error: %s" % err, debug
            self.videoplayer.set_state(Gst.State.NULL)
            self.button_play.set_label("Start")

    def on_sync_message(self, bus, message):
        struct = message.get_structure()
        if not struct:
            return
        message_name = struct.get_name()
        if message_name == "prepare-window-handle":
            message.src.set_window_handle(self.xid)

Gst.init(None)
GTK_Main()
GObject.threads_init()
Gtk.main()

例如,我尝试过这样做:self.visual=Gdk.Screen.get_rgba_visual(Gdk.Screen.get_default()),然后在覆盖或标签widget上设置该视觉。例如,我尝试过这样做:self.visual=Gdk.Screen.get_rgba_visual(Gdk.Screen.get_default()),然后在覆盖或标签小部件上设置该视觉