PySide:QWebView 的鼠标移动和鼠标按下事件冻结 html 文档
PySide:QWebView's Mouse move and Mouse press events Freezing html document
每当我在 window(不是标题栏)内拖动鼠标时,我试图使 QwebView window 移动,同时 html 文档中的事件可以触发。
这是我的实现
import sys
import json
import threading
from time import sleep
from PySide.QtCore import *
from PySide.QtGui import *
from PySide.QtWebKit import QWebView, QWebSettings
from PySide.QtNetwork import QNetworkRequest
from PySide.QtCore import QObject, Slot, Signal
#html_str="".join((open("/root/adstar_gui_generate.html","r").readlines()))
html_str="""
<!doctype>
<body>
<html>
<div class="btns">Books</div>
<div class="btns">Enteraintment</div>
<div class="btns">Sport</div>
</html>
<style>
.btns{
display:inline-block;
color:white;
background:black;
}
.btns:hover{
background:green;
cursor:pointer;
}
</style>
</body>
</doctype>
"""
class move_win(QObject):
def __init__(self):
super(move_win,self).__init__()
@Slot(str)
def move(self,pos):
print pos
pos=json.loads(pos)
#x_w = event.pos().X
#y_w = event.pos().X
dial.webview.move(pos["x"],pos["y"])
class web_view(QWebView):
def __init__(self):
super(web_view,self).__init__()
self.mousedown=None
self.mouseup=None
def mouseReleaseEvent(self,event):
self.mouseup=True
self.mousedown=False
def mousePressEvent(self, event):
#self.offset = event.pos()
self.offset = event.pos()
self.mouseup=False
self.mousedown=True
def mouseMoveEvent(self, event):
if self.mousedown is True:
x=event.globalX()
y=event.globalY()
x_w = self.offset.x()
y_w = self.offset.y()
self.move(x-x_w, y-y_w)
if __name__=="__main__":
Qapp=QApplication(sys.argv)
t=web_view()
t.settings().setAttribute(QWebSettings.WebAttribute.DeveloperExtrasEnabled, True)
t.setHtml(html_str)
t.show()
QCoreApplication.processEvents()
Qapp.exec_()
运行 上面的代码,可以看出悬停在html 按钮上大部分时间不起作用(按钮的颜色不会改变,光标也不会改变)。
我的想法
我假设这是由于 QWebview 本身的 mousePressEvent 和 mouseMoveEvents(以及我的实现)阻止或导致 html 文档冻结。
备注
如果我从 class web_view 中注释掉 mousePressEvent 和 mouseMoveEvent。悬停在 html 按钮上有效(按钮改变颜色,光标改变)
我尝试创建一个 QThread 以确定异步方法是否可以作为解决方案(同样倒霉)...
问题:
如何拖动 QWebView Window 而不会导致 window 中的 html 文档冻结(欢迎使用简单的方法,因为我是 PySide 的新手)
您忘记调用 mouse*Event 的超级方法。
原因:这些方法称为事件处理程序。由于您覆盖了它并且没有调用默认实现,QWebView 没有机会知道鼠标状态(但它不是 "freezed")。
class web_view(QWebView):
def __init__(self):
super(web_view,self).__init__()
self.mousedown=None
self.mouseup=None
def mouseReleaseEvent(self,event):
self.mouseup=True
self.mousedown=False
super(web_view, self).mouseReleaseEvent(event) # here
def mousePressEvent(self, event):
#self.offset = event.pos()
self.offset = event.pos()
self.mouseup=False
self.mousedown=True
super(web_view, self).mousePressEvent(event) # here
def mouseMoveEvent(self, event):
if self.mousedown is True:
x=event.globalX()
y=event.globalY()
x_w = self.offset.x()
y_w = self.offset.y()
self.move(x-x_w, y-y_w)
super(web_view, self).mouseMoveEvent(event) # here
每当我在 window(不是标题栏)内拖动鼠标时,我试图使 QwebView window 移动,同时 html 文档中的事件可以触发。
这是我的实现
import sys
import json
import threading
from time import sleep
from PySide.QtCore import *
from PySide.QtGui import *
from PySide.QtWebKit import QWebView, QWebSettings
from PySide.QtNetwork import QNetworkRequest
from PySide.QtCore import QObject, Slot, Signal
#html_str="".join((open("/root/adstar_gui_generate.html","r").readlines()))
html_str="""
<!doctype>
<body>
<html>
<div class="btns">Books</div>
<div class="btns">Enteraintment</div>
<div class="btns">Sport</div>
</html>
<style>
.btns{
display:inline-block;
color:white;
background:black;
}
.btns:hover{
background:green;
cursor:pointer;
}
</style>
</body>
</doctype>
"""
class move_win(QObject):
def __init__(self):
super(move_win,self).__init__()
@Slot(str)
def move(self,pos):
print pos
pos=json.loads(pos)
#x_w = event.pos().X
#y_w = event.pos().X
dial.webview.move(pos["x"],pos["y"])
class web_view(QWebView):
def __init__(self):
super(web_view,self).__init__()
self.mousedown=None
self.mouseup=None
def mouseReleaseEvent(self,event):
self.mouseup=True
self.mousedown=False
def mousePressEvent(self, event):
#self.offset = event.pos()
self.offset = event.pos()
self.mouseup=False
self.mousedown=True
def mouseMoveEvent(self, event):
if self.mousedown is True:
x=event.globalX()
y=event.globalY()
x_w = self.offset.x()
y_w = self.offset.y()
self.move(x-x_w, y-y_w)
if __name__=="__main__":
Qapp=QApplication(sys.argv)
t=web_view()
t.settings().setAttribute(QWebSettings.WebAttribute.DeveloperExtrasEnabled, True)
t.setHtml(html_str)
t.show()
QCoreApplication.processEvents()
Qapp.exec_()
运行 上面的代码,可以看出悬停在html 按钮上大部分时间不起作用(按钮的颜色不会改变,光标也不会改变)。
我的想法
我假设这是由于 QWebview 本身的 mousePressEvent 和 mouseMoveEvents(以及我的实现)阻止或导致 html 文档冻结。
备注
如果我从 class web_view 中注释掉 mousePressEvent 和 mouseMoveEvent。悬停在 html 按钮上有效(按钮改变颜色,光标改变)
我尝试创建一个 QThread 以确定异步方法是否可以作为解决方案(同样倒霉)...
问题:
如何拖动 QWebView Window 而不会导致 window 中的 html 文档冻结(欢迎使用简单的方法,因为我是 PySide 的新手)
您忘记调用 mouse*Event 的超级方法。
原因:这些方法称为事件处理程序。由于您覆盖了它并且没有调用默认实现,QWebView 没有机会知道鼠标状态(但它不是 "freezed")。
class web_view(QWebView):
def __init__(self):
super(web_view,self).__init__()
self.mousedown=None
self.mouseup=None
def mouseReleaseEvent(self,event):
self.mouseup=True
self.mousedown=False
super(web_view, self).mouseReleaseEvent(event) # here
def mousePressEvent(self, event):
#self.offset = event.pos()
self.offset = event.pos()
self.mouseup=False
self.mousedown=True
super(web_view, self).mousePressEvent(event) # here
def mouseMoveEvent(self, event):
if self.mousedown is True:
x=event.globalX()
y=event.globalY()
x_w = self.offset.x()
y_w = self.offset.y()
self.move(x-x_w, y-y_w)
super(web_view, self).mouseMoveEvent(event) # here