某些 SVG 元素未在 python webkitgtk 应用程序中呈现

Some SVG elements not rendering in python webkitgtk application

我正在编写一个小型应用程序,使用 python gtk3 与 WebKit 和 SchemDraw 的绑定来生成电路图。我的意图是使用 SchemDraw 的 svg 输出(在内部使用 matplotlib)并将其呈现在 WebView 小部件中。当我加载由 matplotlib(从文件和 StringIO)生成的 svg 时,WebView 中缺少一些水平和垂直线元素 window。

我尝试在多个浏览器(Firefox、Google Chrome 和 Epiphany)中打开相同的 svg 文件,并且所有元素都正确呈现。我认为 Epiphany 会是一个很好的测试,因为它似乎使用 WebView 实例,尽管是在 C 中。

gtk 程序:

import pgi as gi
gi.install_as_gi()
gi.require_version('Gtk', '3.0')
gi.require_version('WebKit', '3.0')
from gi.repository import Gtk
from gi.repository import Gdk
from gi.repository import WebKit
print ("PyGtk v%s" % gi.__version__)

# Test webkit SVG rendering
window = Gtk.Window(title="Hello World")
webview1 = WebKit.WebView()
webview1.open('file:///redacted_path/example.svg')
window.add(webview1)
window.show_all()
window.connect("destroy", Gtk.main_quit)
Gtk.main()

渲染example.svg的代码(SchemDraw网站上的例子):

import SchemDraw as schem
import SchemDraw.elements as e
d = schem.Drawing()
V1 = d.add(e.SOURCE_V, label='10V')
d.add(e.RES, d='right', label='100K$\Omega$')
d.add(e.CAP, d='down', botlabel='0.1$\mu$F')
d.add(e.LINE, to=V1.start)
d.add(e.GND)
d.draw()
d.save("example.svg")

我怀疑需要更多的 WebView 实例设置才能使它像我测试过的浏览器一样工作,但我不确定如何在这里继续。

我在我的笔记本电脑 (Ubuntu 19.10) 上测试了你的代码,它成功了。不过我不得不改变一些东西(Ubuntu 19.10 具有更新版本的 gir-webkitgtk,我另外将 SVG 保存到一个文件并通过 URL 打开它) .

这是我的代码,其中包含修改:

#!/usr/bin/env python

import SchemDraw as schem
import SchemDraw.elements as e

d = schem.Drawing()
V1 = d.add(e.SOURCE_V, label='10V')
d.add(e.RES, d='right', label='100K$\Omega$')
d.add(e.CAP, d='down', botlabel='0.1$\mu$F')
d.add(e.LINE, to=V1.start)
d.add(e.GND)
d.draw()
d.save("example.svg")

我注意到 'example.svg' 没有被自动保存。因此,一旦 window 打开电路,我就使用菜单手动将其保存到 SVG 文件中。

#!/usr/bin/env python

import pgi as gi

gi.install_as_gi()
gi.require_version('Gtk', '3.0')
gi.require_version('WebKit2', '4.0')
from gi.repository import Gtk
from gi.repository import Gdk
from gi.repository import WebKit2
print ("PyGtk v%s" % gi.__version__)

# Test webkit SVG rendering
url = 'http://127.0.0.1:8001/example.svg'
window = Gtk.Window(title="Hello World")
webview1 = WebKit2.WebView()
webview1.load_uri(url)
window.add(webview1)
window.show_all()
window.connect("destroy", Gtk.main_quit)
Gtk.main()

截图:

在我看来,SVG 渲染得很好(我没有注意到缺少任何元素)。