基于PyQT實(shí)現(xiàn)區(qū)分左鍵雙擊和單擊
在PyQt中沒有直接提供左鍵雙擊的判斷方法,需要自己實(shí)現(xiàn),其思路主要如下所示:
1、起動(dòng)一個(gè)定時(shí)器,判斷在指定的時(shí)間之內(nèi),點(diǎn)擊次數(shù)超過2次,則視為雙擊(其主要思路判斷兩次點(diǎn)擊的時(shí)間差在預(yù)測(cè)的條件以內(nèi))
2、 起動(dòng)一個(gè)定時(shí)器,判斷在指定的時(shí)間之內(nèi),點(diǎn)擊次數(shù)超過2次,另外再獲取鼠標(biāo)點(diǎn)擊的坐標(biāo),如果前后兩次點(diǎn)擊的坐標(biāo)位置,屬于同一個(gè)位置,滿足這兩個(gè)條件則判斷為雙擊(其主要思路判斷兩次點(diǎn)擊的時(shí)間差在預(yù)測(cè)的條件以內(nèi),且點(diǎn)擊的坐標(biāo)在預(yù)設(shè)的坐標(biāo)之內(nèi),允許存在一定的偏差)
from PyQt5.QtCore import QTimer
from PyQt5 import QtCore, QtGui, QtWidgets
class myWidgets(QtWidgets.QTableWidget):
def __init__(self, parent=None):
super(myWidgets, self).__init__(parent)
self.isDoubleClick = False
self.mouse = ""
def mousePressEvent(self, e):
# 左鍵按下
if e.buttons() == QtCore.Qt.LeftButton:
QTimer.singleShot(0, lambda: self.judgeClick(e))
# 右鍵按下
elif e.buttons() == QtCore.Qt.RightButton:
self.mouse = "右"
# 中鍵按下
elif e.buttons() == QtCore.Qt.MidButton:
self.mouse = '中'
# 左右鍵同時(shí)按下
elif e.buttons() == QtCore.Qt.LeftButton | QtCore.Qt.RightButton:
self.mouse = '左右'
# 左中鍵同時(shí)按下
elif e.buttons() == QtCore.Qt.LeftButton | QtCore.Qt.MidButton:
self.mouse = '左中'
# 右中鍵同時(shí)按下
elif e.buttons() == QtCore.Qt.MidButton | QtCore.Qt.RightButton:
self.mouse = '右中'
# 左中右鍵同時(shí)按下
elif e.buttons() == QtCore.Qt.LeftButton | QtCore.Qt.MidButton | QtCore.Qt.RightButton:
self.mouse = '左中右'
def mouseDoubleClickEvent(self,e):
# 雙擊
self.mouse = "雙擊"
self.isDoubleClick=True
def judgeClick(self,e):
if self.isDoubleClick== False:
self.mouse="左"
else:
self.isDoubleClick=False
self.mouse = "雙擊"
或
from PyQt5.QtCore import QTimer
from PyQt5 import QtCore, QtGui, QtWidgets
class myWidgets(QtWidgets.QTableWidget):
def __init__(self, parent=None):
super(myWidgets, self).__init__(parent)
self.mouse = ""
self.timer=QTimer(self)
self.timer.timeout.connect(self.singleClicked)
def singleClicked(self):
if self.timer.isActive():
self.timer.stop()
self.mouse="左"
def mouseDoubleClickEvent(self,e):
if self.timer.isActive() and e.buttons() ==QtCore.Qt.LeftButton:
self.timer.stop()
self.mouse="雙擊"
super(myWidgets,self).mouseDoubleClickEvent(e)
def mousePressEvent(self,e):
if e.buttons()== QtCore.Qt.LeftButton:
self.timer.start(1000)
elif e.buttons()== QtCore.Qt.RightButton:
self.mouse="右"
super(myWidgets,self).mousePressEvent(e)
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
python多線程案例之多任務(wù)copy文件完整實(shí)例
這篇文章主要介紹了python多線程案例之多任務(wù)copy文件,結(jié)合完整實(shí)例形式分析了Python使用multiprocessing模塊實(shí)現(xiàn)基于多線程的文件拷貝相關(guān)操作技巧,需要的朋友可以參考下2019-10-10
Python 實(shí)現(xiàn)字符串中指定位置插入一個(gè)字符
下面小編就為大家分享一篇Python 實(shí)現(xiàn)字符串中指定位置插入一個(gè)字符,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-05-05
Python中數(shù)據(jù)類轉(zhuǎn)換為JSON的方法詳解
這篇文章主要介紹了Python中數(shù)據(jù)類轉(zhuǎn)換為JSON的方法詳解的相關(guān)資料,需要的朋友可以參考下2023-09-09
TensorFlow2基本操作之 張量排序 填充與復(fù)制 查找與替換
這篇文章主要介紹了TensorFlow2基本操作之 張量排序 填充與復(fù)制 查找與替換,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-09-09
certifi輕松地管理Python證書信任鏈保障網(wǎng)絡(luò)安全
在使用Python進(jìn)行網(wǎng)絡(luò)通信時(shí),我們通常需要使用第三方庫來處理HTTPS連接,其中,certifi庫是一個(gè)非常實(shí)用的庫,可以幫助我們輕松地管理Python的證書信任鏈2024-01-01
Python分析特征數(shù)據(jù)類別與預(yù)處理方法速學(xué)
這篇文章主要為大家介紹了Python分析特征數(shù)據(jù)類別與預(yù)處理方法速學(xué),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-02-02
Python Django搭建文件下載服務(wù)器的實(shí)現(xiàn)
這篇文章主要介紹了Python Django搭建文件下載服務(wù)器的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-05-05
異步任務(wù)隊(duì)列Celery在Django中的使用方法
對(duì)于網(wǎng)站來說,給用戶一個(gè)較好的體驗(yàn)是很重要的事情,其中最重要的指標(biāo)就是網(wǎng)站的瀏覽速度。因此服務(wù)端要從各個(gè)方面對(duì)網(wǎng)站性能進(jìn)行優(yōu)化,這篇文章主要介紹了異步任務(wù)隊(duì)列Celery在Django中的使用方法,感興趣的小伙伴們可以參考一下2018-06-06
Anaconda安裝pytorch及配置PyCharm 2021環(huán)境
小編使用的是python3.8版本,為了防止訪問量過大導(dǎo)致http連接失敗,所以采用本地安裝,具體安裝方法本文給大家詳細(xì)介紹,在文章底部給大家提到了PyCharm 2021配置環(huán)境的方法,感興趣的朋友一起看看吧2021-06-06

