Отображать содержимое HTML-файла на моем рабочем столе

Я нашел очень старый пост на ] Отображение содержимого HTML на рабочем столе в виде виджета. Это обновленный ответ с помощью этих двух ответов Answer-1 и Answer-2 . Я попытался запустить это как скрипт python " python file.py "(поправьте меня, если я ошибаюсь, bcz у меня нет базовых знаний, просто заинтересовался постом и пытался получить рабочий скрипт)

Итак, после запуска скрипта я получил несколько ошибок, устранено DuckDuckGoing, но все же есть некоторые ошибки, требующие помощи экспертов.

Текущий скрипт

Я только что обновил первые три строчки, изменил WebKit -> WebKit2.

import gi
gi.require_version('Gtk', '3.0')
gi.require_version('WebKit2', '4.0')
from gi.repository import WebKit2, Gtk, Gdk, Gio, GLib
import signal, os

class MainWin(Gtk.Window):
    def __init__(self):
        Gtk.Window.__init__(self, skip_pager_hint=True, skip_taskbar_hint=True)
        self.set_wmclass("sildesktopwidget","sildesktopwidget")
        self.set_type_hint(Gdk.WindowTypeHint.DOCK)
        self.set_size_request(600,400)
        self.set_keep_below(True)

        #Set transparency
        screen = self.get_screen()
        rgba = screen.get_rgba_visual()
        self.set_visual(rgba)
        self.override_background_color(Gtk.StateFlags.NORMAL, Gdk.RGBA(0,0,0,0))

        #Add all the parts
        self.view = WebKit2.WebView()
        self.view.set_transparent(True)
        self.view.override_background_color(Gtk.StateFlags.NORMAL, Gdk.RGBA(0,0,0,0))
        self.view.props.settings.props.enable_default_context_menu = False
        self.view.load_uri("file:///home/sai/Downloads/todo.html")

        box = Gtk.Box()
        self.add(box)
        box.pack_start(self.view, True, True, 0)
        self.set_decorated(False)
        self.connect("destroy", lambda q: Gtk.main_quit())

        #Show all the parts
        self.show_all()
        self.move(100,100)

def refresh_file(*args):
    print args
    mainwin.view.reload()

def file_changed(monitor, file, unknown, event):
    # reload
    GLib.timeout_add_seconds(2, refresh_file)

if __name__ == '__main__':
    gio_file = Gio.File.new_for_path("/home/sai/Downloads/todo.html")
    monitor = gio_file.monitor_file(Gio.FileMonitorFlags.NONE, None)
    monitor.connect("changed", file_changed)

    mainwin = MainWin()
    signal.signal(signal.SIGINT, signal.SIG_DFL) # make ^c work
    Gtk.main()

Текущая ситуация

Я получаю эту ошибку и не могу ее устранить.

#$ python file.py 
Traceback (most recent call last):
  File "file.py", line 51, in <module>
    mainwin = MainWin()
  File "file.py", line 23, in __init__
    self.view.set_transparent(True)
AttributeError: 'WebView' object has no attribute 'set_transparent'


Пожалуйста, помогите мне получить рабочий скрипт для отображения HTML-страницы в виде виджета рабочего стола. Я использую Ubuntu Mate 20.04.

3
задан 5 April 2021 в 10:09

2 ответа

К вашему сведению - исходный скрипт нормально работает на Ubuntu MATE 14.04 LTS (EoL), 16.04 LTS (EoL) и 18.04 LTS.

Для Ubuntu MATE 20.04 LTS вы можете использовать следующий адаптированный код:

import gi
gi.require_version('Gtk', '3.0')
gi.require_version('WebKit2', '4.0')
from gi.repository import WebKit2, Gtk, Gdk, Gio, GLib
import signal, os

document="/usr/share/javascript/mathjax/test/sample.html"

class MainWin(Gtk.Window):
    def __init__(self):
        Gtk.Window.__init__(self, skip_pager_hint=True, skip_taskbar_hint=True)
        self.set_wmclass("sildesktopwidget","sildesktopwidget")
        self.set_type_hint(Gdk.WindowTypeHint.DOCK)
        self.set_size_request(600,400)
        self.set_keep_below(True)

        #Set transparency
        screen = self.get_screen()
        rgba = screen.get_rgba_visual()
        self.set_visual(rgba)
        self.override_background_color(Gtk.StateFlags.NORMAL, Gdk.RGBA(0,0,0,0))

        #Add all the parts
        self.view = WebKit2.WebView()
        #self.view.set_transparent(True)
        self.view.override_background_color(Gtk.StateFlags.NORMAL, Gdk.RGBA(0,0,0,0))
        #self.view.props.settings.props.enable_default_context_menu = False
        # configure transparency as in https://github.com/LTSchmiddy/dungeon-commander/blob/8d5c58ca321a05519c8cb1c5afdebba4954cbfca/src/webview/platforms/gtk.py#L132
        configure_transparency(self)
        configure_transparency(self.view)
        wvbg = self.view.get_background_color()
        wvbg.alpha = 0.0
        self.view.set_background_color(wvbg)

        self.view.load_uri("file://"+document)

        box = Gtk.Box()
        self.add(box)
        box.pack_start(self.view, True, True, 0)
        self.set_decorated(False)
        self.connect("destroy", lambda q: Gtk.main_quit())

        #Show all the parts
        self.show_all()
        self.move(100,100)

def refresh_file(*args):
    print args
    mainwin.view.reload()

def file_changed(monitor, file, unknown, event):
    # reload
    GLib.timeout_add_seconds(2, refresh_file)

# configure transparency as in https://github.com/LTSchmiddy/dungeon-commander/blob/8d5c58ca321a05519c8cb1c5afdebba4954cbfca/src/webview/platforms/gtk.py#L549
def configure_transparency(c):
    c.set_visual(c.get_screen().get_rgba_visual())
    c.override_background_color(Gtk.StateFlags.ACTIVE, Gdk.RGBA(0, 0, 0, 0))
    c.override_background_color(Gtk.StateFlags.BACKDROP, Gdk.RGBA(0, 0, 0, 0))
    c.override_background_color(Gtk.StateFlags.DIR_LTR, Gdk.RGBA(0, 0, 0, 0))
    c.override_background_color(Gtk.StateFlags.DIR_RTL, Gdk.RGBA(0, 0, 0, 0))
    c.override_background_color(Gtk.StateFlags.FOCUSED, Gdk.RGBA(0, 0, 0, 0))
    c.override_background_color(Gtk.StateFlags.INCONSISTENT, Gdk.RGBA(0, 0, 0, 0))
    c.override_background_color(Gtk.StateFlags.INSENSITIVE, Gdk.RGBA(0, 0, 0, 0))
    c.override_background_color(Gtk.StateFlags.NORMAL, Gdk.RGBA(0, 0, 0, 0))
    c.override_background_color(Gtk.StateFlags.PRELIGHT, Gdk.RGBA(0, 0, 0, 0))
    c.override_background_color(Gtk.StateFlags.SELECTED, Gdk.RGBA(0, 0, 0, 0))
    transparentWindowStyleProvider = Gtk.CssProvider()
    transparentWindowStyleProvider.load_from_data(b"""
        GtkWindow {
            background-color:rgba(0,0,0,0);
            background-image:none;
        }""")
    c.get_style_context().add_provider(transparentWindowStyleProvider, Gtk.STYLE_PROVIDER_PRIORITY_APPLICATION)


if __name__ == '__main__':
    gio_file = Gio.File.new_for_path(document)
    monitor = gio_file.monitor_file(Gio.FileMonitorFlags.NONE, None)
    monitor.connect("changed", file_changed)

    mainwin = MainWin()
    signal.signal(signal.SIGINT, signal.SIG_DFL) # make ^c work
    Gtk.main()

Примечания:

  1. Я еще не эксперт по Python, но он работает должным образом:

    HTML on Ubuntu MATE desktop

  2. Для сценария необходимы пакеты, установленные sudo apt-get install python2 python-gi gir1.2-webkit2-4.0 .

4
ответ дан 23 April 2021 в 23:26

Жизнь намного проще!

Шаг за шагом

  • Используйте google-chrome в режиме --app с wmctrl так:

    google-chrome --app="https://askubuntu.com/" && wmctrl -r :ACTIVE: -b add,ниже
    

    Вот он у вас... ваш "виджет" на рабочем столе... переместите его, измените размер или закройте.

  • Чтобы сделать его прозрачным, используйте xprop так:

    xprop -f _NET_WM_WINDOW_OPACITY 32c -set _NET_WM_WINDOW_OPACITY "0xCCFFFFFF".
    

    Затем, коснитесь его .

  • Чтобы раздеть его голой, используйте xprop снова так:

    xprop -f _MOTIF_WM_HINTS 32c -set _MOTIF_WM_HINTS "0x2, 0x0, 0x0, 0x0, 0x0, 0x0".
    

    Затем, коснитесь его еще раз .

Все сразу

  • Все вышеперечисленное можно сделать за один шаг, например:

    google-chrome -disable-gpu --disable-software-rasterizer --app="https://askubuntu.com/" && \.
    wmctrl -r :ACTIVE: -e 0,0,0,550,800 -b add,ниже && \.
    xprop -id "$(xprop -root _NET_ACTIVE_WINDOW | awk '{print $5}')"). \
    -f _NET_WM_WINDOW_OPACITY 32c -set _NET_WM_WINDOW_OPACITY "0xCCFFFFF" && \.
    xprop -id "$(xprop -root _NET_ACTIVE_WINDOW | awk '{print $5}')"). \
    -f _MOTIF_WM_HINTS 32c -set _MOTIF_WM_HINTS "0x2, 0x0, 0x0, 0x0, 0x0".
    
  • -e 0,0,0,550,800 устанавливает положение и размер окна... последние четыре числа. См. man wmctrl

  • -set _NET_WM_WINDOW_OPACITY "0xCCFFFFFFF" устанавливает прозрачность окна. Для изменения уровня прозрачности измените CC на один из этих.

4
ответ дан 23 April 2021 в 23:26

Другие вопросы по тегам:

Похожие вопросы: