首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

在QWidget python GUI上绘制一个圆

在QWidget Python GUI上绘制一个圆,可以使用Qt的绘图类QPainter来实现。

首先,需要创建一个继承自QWidget的自定义窗口类,并重写其paintEvent方法,在该方法中进行绘图操作。

以下是一个示例代码,演示如何在QWidget上绘制一个圆:

代码语言:txt
复制
import sys
from PyQt5.QtWidgets import QApplication, QWidget
from PyQt5.QtGui import QPainter, QColor, QPen
from PyQt5.QtCore import Qt

class MyWidget(QWidget):
    def __init__(self):
        super().__init__()
        self.setWindowTitle('绘制圆')
        self.setGeometry(100, 100, 400, 400)
        
    def paintEvent(self, event):
        painter = QPainter(self)
        painter.setRenderHint(QPainter.Antialiasing)  # 抗锯齿
        
        # 设置画笔
        pen = QPen()
        pen.setWidth(2)
        pen.setColor(QColor(0, 0, 255))  # 蓝色
        pen.setStyle(Qt.SolidLine)  # 实线
        painter.setPen(pen)
        
        # 设置画刷
        brush = QBrush()
        brush.setColor(QColor(255, 0, 0))  # 红色
        brush.setStyle(Qt.SolidPattern)  # 实心
        painter.setBrush(brush)
        
        # 绘制圆
        center = self.rect().center()  # 窗口中心点
        radius = min(self.width(), self.height()) // 2  # 半径为窗口宽高的最小值的一半
        painter.drawEllipse(center, radius, radius)
        
if __name__ == '__main__':
    app = QApplication(sys.argv)
    widget = MyWidget()
    widget.show()
    sys.exit(app.exec_())

在上述代码中,我们创建了一个自定义的QWidget窗口类MyWidget,并重写了其paintEvent方法。在paintEvent方法中,我们创建了一个QPainter对象,设置了画笔和画刷的样式,然后调用drawEllipse方法绘制了一个圆。

注意,为了实现抗锯齿效果,我们通过setRenderHint方法设置了QPainter的Antialiasing属性为True。

对于这个问答,没有具体的云计算、IT互联网领域的名词或相关腾讯云产品和链接地址需要提及。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

Qt编写自定义控件51-可输入仪表盘

这个控件是近期定制的控件,还是比较实用的控件之一,用户主要是提了三点需求,一点是切换焦点的时候控件放大突出显示,一点是可直接输入或者编辑值,还有一点是支持上下键及翻页键和鼠标滚轮来动态修改值,类似于qspinbox控件。要能够支持直接输入首先想到的就是qlineedit控件,在原有的仪表盘控件上中间部分,放置一个qlineedit控件用来输入值,采用正则表达式来限制只能输入数字,为了使得qlinedit和自定义绘制的仪表盘完全融为一体,必须设置qlineedit的样式为背景透明,至于输入框的位置,有个小技巧就是直接将输入框设置为控件的大小,这样输入的焦点永远在控件的中间,完全混合,丝毫看不出是一个输入框控件插在那里,至于上下键及翻页键和鼠标滚轮,直接安装事件过滤器即可识别到,进行对应的处理即可。

02
  • Qt编写自定义控件14-环形进度条

    环形进度条,用来展示当前进度,为了满足大屏UI的需要特意定制,以前有个叫圆环进度条,不能满足项目需要,只能重新定做,以前的进度间距不能自适应分辨率,而且当前进度对应的反的进度不能单独设置颜色,即当前进度90%,剩余的10%也需要设置成不同的颜色,还有一个重要的功能是,能够指定多个警戒值,一旦超过或者小于该值,则当前进度自动切换到预先设定的警戒值颜色,而不需要用户自己去判断警戒值去设置警戒颜色,用户只需要传入当前值即可,这个功能非常实用,还可以设置警戒判断的标准是超过值还是小于值报警。个人感觉这个环形进度条功能完爆市面上所有的圆环进度条。只要稍作参数设置可以变成各种想要的效果,什么起始角度+动画效果+顺时针逆时针转等。

    01

    Qt编写自定义控件5-柱状温度计

    柱状温度计控件,可能是很多人练手控件之一,基本上都是垂直方向展示,底部一个水银柱,中间刻度尺,刻度尺可以在左侧右侧或者两侧都有,自适应分辨率改动,有时候为了美观效果,可能还会整个定时器来实现动画效果,开启动画效果的缺点就是CPU占用会比较高,前阵子有个好友(贾文涛-涛哥)向我推荐了一个opengl绘制的开源东西,QNanoPainter,东西是个好东西,我个人的理解是直接封装了opengl绘制的qpainter,可以使得绘制全部走GPU,这样就可以大大减轻CPU的负担,非常方便,我自己试了下,方法和绘制逻辑和qpainter有点不一样,暂时没有将所有控件改成QNanoPainter版本,以后看情况吧。

    05

    Qt编写自定义控件26-平铺背景控件

    平铺背景控件,主要的应用场景是作为画布出现,黑白相间的背景图,然后上面可以放置图片图形等,使得看起来更美观,比如PS软件新建图层以后的背景,FireWorks软件新建画布以后的透明背景,ICO制作软件新建画布以后的背景,都会采用一个黑白相间的背景。尽管本人用QPainter很多年,后面在翻阅QPainter自带的函数中才发现居然QPainter自带了这个绘制平铺背景的函数,擦,他么叫drawTiledPixmap,Qt不愧是跨平台GUI开发中的佼佼者,这些东西居然都考虑到了,说到考虑的周到,Qt中连size和count和length都完美的封装了,适合不同人群的使用习惯,这个考虑也是非常周到的。drawTiledPixmap就两个参数,第一个参数是要绘制的区域,第二个参数是要绘制的图片,图片不足会自动拷贝填充,所以如果提供的是两个交替颜色的背景图片,就会依次绘制形成平铺背景的效果,为了使得颜色可以控制,本控件增加了交替颜色的设置,可以自行传入两种颜色作为交替颜色,在程序内部自动生成要绘制的图片。

    02
    领券