python – 具有交互式SVG图像的pyQt

python – 具有交互式SVG图像的pyQt,第1张

概述我如何将交互式SVG文件添加到QGraphicsScene?我可以添加一个交互式SVG文件,但它只是显示为静态图像.我正在阅读有关QGraphicsWebView的内容,但无法弄清楚如何添加SVG文件并且缺少示例. 让我对我正在寻找的东西更具体一点.假设我有一个绘制框的SVG文件.当我将鼠标悬停在那个盒子上时,我想将颜色更改为触发悬停事件.我是否必须编辑文件并重新绘制图像?感觉应该有一种方法与Qt 我如何将交互式SVG文件添加到QGraphiCSScene?我可以添加一个交互式SVG文件,但它只是显示为静态图像.我正在阅读有关QGraphicsWebVIEw的内容,但无法弄清楚如何添加SVG文件并且缺少示例.

让我对我正在寻找的东西更具体一点.假设我有一个绘制框的SVG文件.当我将鼠标悬停在那个盒子上时,我想将颜色更改为触发悬停事件.我是否必须编辑文件并重新绘制图像?感觉应该有一种方法与Qt做交互式SVG文件.

解决方法 我有同样的问题,你的问题指向我正确的方向(使用QGraphicsWebVIEw()).
解决方案实际上非常简单:

import sysfrom PyQt4 import QtCore,QtGui,QtSvgfrom PyQt4.QtWebKit import QGraphicsWebVIEwif __name__ == "__main__":    app = QtGui.QApplication(sys.argv)    scene = QtGui.QGraphiCSScene()    vIEw = QtGui.QGraphicsVIEw(scene)    br = QtSvg.QGraphiCSSvgItem("C:\your_interactive_svg.svg").boundingRect()    webvIEw = QGraphicsWebVIEw()    webvIEw.load(QtCore.QUrl("C:\your_interactive_svg.svg"))    webvIEw.setFlags(QtGui.QGraphicsItem.ItemClipsToShape)    webvIEw.setCacheMode(QtGui.QGraphicsItem.NoCache)    webvIEw.resize(br.wIDth(),br.height())    scene.addItem(webvIEw)    vIEw.resize(br.wIDth()+10,br.height()+10)    vIEw.show()    sys.exit(app.exec_())

它对我来说很完美(脚本和其他东西).

正如你所看到的,我还将我的svg加载为QGraphiCSSvgItem,因为我不知道以其他方式来获取我的svg的大小.

总结

以上是内存溢出为你收集整理的python – 具有交互式SVG图像的pyQt全部内容,希望文章能够帮你解决python – 具有交互式SVG图像的pyQt所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1192629.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-03
下一篇 2022-06-03

发表评论

登录后才能评论

评论列表(0条)

保存