Я нашел очень старый пост на ] Отображение содержимого 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.
К вашему сведению - исходный скрипт нормально работает на 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()
Примечания:
Жизнь намного проще!
Используйте 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
на один из этих.