加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Python > 正文

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

发布时间:2020-12-20 11:21:48 所属栏目:Python 来源:网络整理
导读:我如何将交互式SVG文件添加到QGraphicsScene?我可以添加一个交互式SVG文件,但它只是显示为静态图像.我正在阅读有关QGraphicsWebView的内容,但无法弄清楚如何添加SVG文件并且缺少示例. 让我对我正在寻找的东西更具体一点.假设我有一个绘制框的SVG文件.当我将
我如何将交互式SVG文件添加到QGraphicsScene?我可以添加一个交互式SVG文件,但它只是显示为静态图像.我正在阅读有关QGraphicsWebView的内容,但无法弄清楚如何添加SVG文件并且缺少示例.

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

解决方法

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

import sys
from PyQt4 import QtCore,QtGui,QtSvg
from PyQt4.QtWebKit import QGraphicsWebView
if __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的大小.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读