模拟点击事件

一、通过代码模拟用户对按钮的点击。

模拟按钮的点击:

# 方法一:使用btn.click模拟用户的点击 #btn.click()

# 方法二:两秒之后自动松开按钮 #btn.animateClick(2000)

区别是方法一没有什么动画、界面展示,方法二有时间效果。

二、案例:点击按钮二的时候去测试按钮一的代码模拟点击。

from PyQt5.Qt import *
import sys

app = QApplication(sys.argv)
window = QWidget()
window.setWindowTitle("按钮点击模拟")
window.resize(500, 500)

btn = QPushButton(window)
btn.setText("这是按钮")
btn.move(200, 200)
btn.pressed.connect(lambda: print("点击了这个按钮"))

# 方法一:使用btn.click模拟用户的点击
#btn.click()
# 方法二:两秒之后自动松开按钮
#btn.animateClick(2000)

btn2 = QPushButton(window)
btn2.setText("按钮")

def signal():
    #btn.click()
    btn.animateClick(1000)

btn2.pressed.connect(signal)

window.show()
sys.exit(app.exec_())

三:设置按钮点击的有效区域:

重写一个方法,传递一个点的坐标,想要让他响应就返回True,不想让他相应则返回False。

(按钮点击一个点,他会先进入按钮的bitButton()方法中,判断该点是否有效,才会发射相关信号。)

点击按钮有效区域,才会发出信号。

②:限定只有点击按钮的内切圆的内部区域,才会产生信号。

class Btn(QPushButton):
    def hitButton(self, point):
        # 通过给定点坐标计算他与圆心的距离
        # 求解圆心
        center_x = self.width() / 2
        center_y = self.height() / 2

        # 给定点
        point_x = point.x()
        point_y = point.y()

        # 计算两点之间的距离
        import math
        distance = math.sqrt(math.pow(point_x - center_x) + math.pow(point_y - center_y))
        if distance < self.width() / 2:
            return True
        return False

三、在按钮内部绘制一个内切圆,则需要使用重写paintEvent(self, QPointEvent):方法

from PyQt5.Qt import *
import sys

class Btn(QPushButton):
    def hitButton(self, point):
        # 通过给定点坐标计算他与圆心的距离
        # 求解圆心
        center_x = self.width() / 2
        center_y = self.height() / 2

        # 给定点
        point_x = point.x()
        point_y = point.y()

        # 计算两点之间的距离
        import math
        distance = math.sqrt(math.pow(point_x - center_x, 2) + math.pow(point_y - center_y, 2))
        if distance < self.width() / 2:
            return True
        return False


    # 在整个按钮的内部绘制一个内切圆,使用绘制方法
    def paintEvent(self, QPointEvent):
        # 并将该事件传入,即在父类绘制的基础上在绘制一个内切圆
        super().paintEvent(QPointEvent)
        # 创建一个画家,画布为整个按钮
        painter = QPainter(self)
        # 创建一个画笔
        painter.setPen(QPen(QColor(100, 219, 234), 6))

        # 画圆,将整个按钮的矩形传入
        painter.drawEllipse(self.rect())
        # 文本内容为绘制出来的,重写了该方法之前的内容会覆盖,故需要调用父类相同的方法


app = QApplication(sys.argv)
window = QWidget()
window.setWindowTitle("按钮点击模拟")
window.resize(500, 500)

btn = Btn(window)
btn.setText("这是按钮")
btn.move(200, 200)
btn.resize(200, 200)
btn.pressed.connect(lambda: print("点击了这个按钮"))


window.show()
sys.exit(app.exec_())
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

。七十二。

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值