- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在开发一个使用修改后的QWebView
的项目。我收到此错误:
Traceback (most recent call last):
File "/home/jorge/coders/universal-scraper/src/customwebview.py", line 63, in mouseMoveEvent
hittestresult = self.currentframe.hitTestContent(event.pos())
RuntimeError: Internal C++ object (PySide.QtWebKit.QWebFrame) already deleted.
我读过 PySide pitfalls已经,并且我已经使用 setframeafterloadfinished
方法将该 QtWebKit.QWebFrame
对象保存为修改后的 QWebView
的属性,该方法页面加载完成时调用,在我修改的 QWebView
上需要的一些重大更改发生后引发的问题,在此之前,一切都很顺利。
功能和最小示例在这里(只需确保在运行测试之前将文件 webelementinfo.py
放在与此代码相同的目录中):
#!/usr/bin/env python2
# coding: utf-8
# VENI, SANCTE SPIRITUS
from PySide.QtWebKit import QWebView
from PySide import QtCore, QtGui
try:
from . import webelementinfo
except ValueError:
import webelementinfo
class CustomQWebView(QWebView):
def __init__(self, *args, **kwargs):
""" Init the custom class
"""
super(CustomQWebView, self).__init__(*args, **kwargs)
self.colors = {0: QtGui.QColor(255, 165, 0, 127),
1: QtGui.QColor(135, 206, 235, 127),
2: QtGui.QColor(135, 235, 164, 127),
3: QtGui.QColor(235, 135, 206, 127),
4: QtGui.QColor(235, 164, 135, 127)}
self.color = None
self.currentframe = None
self.element = None
self.loadFinished.connect(self.setframeafterloadfinished)
self.selectCommentsArea()
@QtCore.Slot()
def selectCommentsArea(self):
""" For selecting the comment area
"""
self.setup_rectcolor_area(0)
@QtCore.Slot(QtGui.QMouseEvent)
def mouseMoveEvent(self, event):
super(CustomQWebView, self).mouseMoveEvent(event)
if self.drawrects:
if self.currentframe:
hittestresult = self.currentframe.hitTestContent(event.pos())
element = webelementinfo.WebElement(
hittestresult, self.color, self)
if not self.element:
self.element = element
elif self.element != element:
self.element = element
# FIXME: self.update should draw rects from WebElements too.
self.update()
@QtCore.Slot(QtGui.QPaintEvent)
def paintEvent(self, event):
# draw the content first
super(CustomQWebView, self).paintEvent(event)
if self.drawrects:
# then the rectangle
if self.element:
self.element.update()
def setframeafterloadfinished(self):
self.currentframe = self.page().mainFrame()
def setup_rectcolor_area(self, forarea):
"""Called when we want to select certain area of a web site
This method set-up the painter to a giving color so web elements are
drawn with a rect on top. Also activates the flag to allow painting
inside CustomQWebView.
:param int forarea: For which area we are going to set the painter\\
valid values are: 0 for Comments area, 1 for comment box, 2 for\\
commentator's user name, 3 for comment date and time, 4 for\\
commentary text.
"""
self.drawrects = True
self.color = self.colors[forarea]
# defines what we are looking to select
self.selecttype = forarea
if __name__ == "__main__":
app = QtGui.QApplication([])
mainwn = QtGui.QMainWindow()
mainwn.resize(800, 696)
centralwidget = QtGui.QWidget(mainwn)
centralwidget.resize(800, 600)
gridlayout = QtGui.QGridLayout(centralwidget)
web = CustomQWebView(parent=centralwidget)
gridlayout.addWidget(web, 0, 0, 1)
web.setUrl(QtCore.QUrl("http://duckduckgo.com"))
mainwn.show()
app.exec_()
这是另一个文件,其中包含我编写并开始使用的新类 WebElement
的定义:
#!/usr/bin/env python2
# coding: utf-8
# VENI, SANCTE SPIRITUS
from PySide.QtWebKit import QWebElement, QWebHitTestResult
from PySide import QtGui
from PySide import QtCore
class WebElement(QtCore.QObject):
""" Holds information of webelements
"""
def __eq__(self, other):
if isinstance(other, WebElement):
return (self.web_element == other.web_element and
self.getrect() == other.getrect())
else:
raise ValueError("Not same objects")
def __ne__(self, other):
if isinstance(other, WebElement):
return (self.web_element != other.web_element and
self.getrect() != other.getrect())
else:
raise ValueError("Not same objects")
def __init__(self, hittestresult, color, parent=None):
super(WebElement, self).__init__(parent)
if (not isinstance(hittestresult, QWebHitTestResult) and
not isinstance(hittestresult, QWebElement)):
raise ValueError(
"Argument passed for 'hittestresult' is not"
" QtWebkit.QWenHitTestResult or QtWebkit.QWebElement instance"
)
if not isinstance(color, QtGui.QColor):
raise ValueError(
"Argument passed for 'color' is not QtGui.QColor instance"
)
try:
self.frame = hittestresult.frame()
except AttributeError:
self.frame = hittestresult.webFrame()
self.frame_scroll_x = self.frame.scrollPosition().x()
self.frame_scroll_y = self.frame.scrollPosition().y()
try:
rect = hittestresult.boundingRect()
except AttributeError:
rect = hittestresult.geometry()
self.element_rect_x = rect.x()
self.element_rect_y = rect.y()
self.element_rect_w = rect.width()
self.element_rect_h = rect.height()
try:
self.web_element = hittestresult.element()
except AttributeError:
self.web_element = hittestresult
self.color = color
self.color_darker = color.darker()
self.color_darker.setAlpha(255)
self.pen = QtGui.QPen(self.color_darker)
self.pen.setWidth(2)
#self.painter = QtGui.QPainter(self.parent)
self.painter = QtGui.QPainter()
self.painter.setPen(self.pen)
def update(self):
""" draw the rect for this element in the CustomQWebView
"""
rect = self.getrect()
rectf = QtCore.QRectF(rect)
self.painter.fillRect(rectf, self.color)
self.painter.drawRect(rectf)
def getrect(self):
""" Return the rect for this WebElement
"""
self.frame_scroll_x = self.frame.scrollPosition().x()
self.frame_scroll_y = self.frame.scrollPosition().y()
rect = QtCore.QRect()
rect.setRect(self.element_rect_x - self.frame_scroll_x,
self.element_rect_y - self.frame_scroll_y,
self.element_rect_w, self.element_rect_h)
return rect
我的项目应该可以正常工作,就好像我没有更改任何内容一样,但是,经过这些更改后,情况却并非如此。我究竟做错了什么?我是否缺少有关 QWebFrame
的信息?
最佳答案
首先,您的示例不是最小:文件“webelementinfo.py”不相关(以及您的类的许多其他部分),导致问题的是 QWebHitTestResult.frame()
方法。足以发生错误的代码如下:
@QtCore.Slot(QtGui.QMouseEvent)
def mouseMoveEvent(self, event):
if self.currentframe:
hittestresult = self.currentframe.hitTestContent(event.pos())
hittestresult.frame() # <- will cause the crash on next mouseMoveEvent
正如 ekhumoro 所指出的这看起来像是 PySide 中的一个错误,与对象所有权相关。您需要避免调用 frame()
方法 - 看起来它在您的代码中并不是真正重要的。将 WebElement
的构造函数更改为:
def __init__(self, frame, hittestresult, color, parent=None):
然后:
#try:
# self.frame = hittestresult.frame() <-- DO NOT CALL THIS
#except AttributeError:
# self.frame = hittestresult.webFrame()
self.frame = frame
并显式传递帧:
hittestresult = self.currentframe.hitTestContent(event.pos())
element = webelementinfo.WebElement(
self.currentframe,
hittestresult,
self.color,
self)
通过这些修复,“内部 C++ 对象 (PySide.QtWebKit.QWebFrame) 已被删除。”不会发生错误。
关于python - 错误 : Internal C++ object (PySide. QtWebKit.QWebFrame) 已删除;但我将其保存为属性以避免这个问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26726878/
我想更新小部件的值,但为了防止无限循环,我需要防止调用此小部件的回调函数 .valueChanged信号。 以下示例完全按预期工作: Qt = PySide class MainWindow(Acto
使用以下代码,在尝试发出信号时出现错误(“PySide.QtCore.Signal”对象没有属性“emit”): #!/usr/bin/env python from PySide import Qt
我是 Python 新手。我同时安装了 Python 2.7 和 Python 3。我刚刚尝试通过 Homebrew 安装 PySide 并收到此消息: PySide package successf
是否可以使用 PySide 中的 Web 类之一加载包含按钮的本地 html/JS 文件,并将这些按钮连接到 PySide 插槽? 最佳答案 您可以使用 QtWebKit 将 QObject 导出到
我一直在寻找一个工作示例,该示例如何在使用 QT 设计器创建的 pyside 中嵌入 matplotlib 图,同时将逻辑保存在单独的文件中。我知道网上有很多例子,但没有一个真正使用 QT 设计器,然
我想我可以通过将\PySide 文件夹附加到我的环境的“搜索路径”来添加 PySide 库,但智能感知似乎没有发现任何东西。不过,它正在使用我的其他图书馆。有什么建议吗? 注意:我已经安装了 PTVS
我正在设计一个 Pyside Qt 应用程序,我想切换 QtCore.Qt.WindowStaysOnTopHint我的主窗口中的窗口标志。使用此代码设置此提示工作正常: self.setWindow
你如何在 PySide 中禁用声子? 我正在尝试使用 QWebpage 并且我不希望 phonon 启动,因为我正在编写的应用程序是服务器端应用程序,并且不需要媒体。我尝试了一些东西,但没有找到任何真
本文为大家分享了pyside pyqt实现鼠标右键菜单功能的具体代码,供大家参考,具体内容如下 在三维软件中使用pyside/pyqt编写gui界面时,为了艺术家使用操作的简洁,以及方便,经常会使
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 4年前关闭。 Improve thi
我试图在 PySide 的单独线程中运行一个长任务,以便主线程可以继续处理 GUI 事件。我已经阅读了执行此操作的正确方法: 将任务封装在 QObject 子类中,其中工作在 run() 方法中完成,
我想知道如何根据最大标签的最大宽度/高度截断QLabel中的文本。 输入的文本可以是任意长度,但是为了保持整洁的布局,我想截断长字符串以填充最大空间(小部件的最大宽度/高度)。 例如。: 'A ve
我有一个界面,屏幕顶部有 4 个按钮,下面有 QFrame。我想根据按下的按钮更改 QFrame 中的布局。例如,如果按下 Button_1 显示一个 TextEdit Widget,如果按下 But
我想制作一个小部件的角。在 PyQt 中,我用样式表解决了这个问题,效果很好。我想在 PySide 中做同样的事情,但由于某些原因它不起作用。 这是我的代码: TitelWidget = QtGui.
我是 python 和 pyside 的新手。我将尝试成功运行以下代码。但现在我希望程序在显示窗口后等待用户无法使用它的定义时间,然后升级状态栏。我会尝试 sleep() 但不知道它必须以正确的方式放
我从 example of Zetcode 开始学习 PySide并尝试编写具有两个窗口的应用程序:“布局 View ”的父级“示意图 View ”,每个窗口都有菜单栏。启动时应该只是原理图窗口,布局
我从 example of Zetcode 开始学习 PySide并尝试编写具有两个窗口的应用程序:“布局 View ”的父级“示意图 View ”,每个窗口都有菜单栏。启动时应该只是原理图窗口,布局
我正在尝试通过 pyside 设置 QGridLayout 小部件的背景图像(位于与应用程序相同的文件夹中),但无济于事我已经查看了有关样式表的所有图、文档和论坛帖子,但仍然我不知道我做错了什么。 f
我有一个带有 5 个按钮的布局,我充当“菜单”,因此您单击一个按钮,会显示一个 View ,单击另一个按钮,会显示另一个 View 。我需要找出单击了哪个按钮,以便我可以根据按下的按钮执行某些操作。类
基本上我想要的是: 在主窗口中显示一个小部件,其中包含打开 QFileDialog 的按钮 选择文件后,包含按钮的小部件应切换到新的小部件,该新小部件会显示一些基于文件内容的可视化效果。 在下面的代码
我是一名优秀的程序员,十分优秀!