PyQt5之QGraphics 003 View基本缩放

下面通过滚动鼠标中键控制QGraphicsView的缩放

"""
QGraphicsView 的基本缩放
By Linyoubiao
2020-03-15
"""

from PyQt5.QtWidgets import (QApplication, QGraphicsView, QGraphicsScene, QGraphicsItem)
from PyQt5.QtCore import (QPointF, QPoint, QLineF, QLine, QRectF, QRect, Qt)
from PyQt5.QtGui import (QBrush, QPen, QPixmap, QPicture, QImage)
import math


class ImageItem(QGraphicsItem):
    def __init__(self):
        super(ImageItem, self).__init__()
        self.rect = QRectF(QPointF(.0, .0), QPointF(100., 100.))
        self.lena = QImage("c:/pic/lena.jpg")

    def boundingRect(self):
        return self.rect

    def paint(self, painter, option, widget):
        painter.drawImage(QRectF(QPointF(10.0, 10.0), QPointF(50.0, 50.0)), self.lena)
        painter.drawRect(QRectF(QPointF(10.0, 10.0), QPointF(50.0, 50.0)))
        painter.drawText(QRectF(QPointF(10.0, 10.0), QPointF(50.0, 50.0)),
                         Qt.AlignLeft, "Hi\nLena")


class ImageView(QGraphicsView):
    def __init__(self):
        super(ImageView, self).__init__()
        self.scene = QGraphicsScene()
        self.image = ImageItem()
        self.lena = QPixmap("c:/pic/lena.jpg")
        self.setBackgroundBrush(QBrush(self.lena))
        self.scene.addItem(self.image)
        self.setScene(self.scene)

    def wheelEvent(self, event):
        self.scaleView(math.pow(2.0, -event.angleDelta().y() / 240.0))

    def scaleView(self, scaleFactor):
        factor = self.transform().scale(scaleFactor, scaleFactor).mapRect(QRectF(0, 0, 1, 1)).width()

        if factor < 0.07 or factor > 100:
            return

        self.scale(scaleFactor, scaleFactor)


if __name__ == "__main__":
    import sys
    app = QApplication(sys.argv)

    view = ImageView()
    view.show()

    sys.exit(app.exec_())

 

运行,可以通过滚动鼠标中键缩放,效果如下:

 

  • 0
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: PyQt5中的QGraphicsView是一个用于显示和编辑图形的小部件。它可以用于创建交互式的图形应用程序,如绘图编辑器和游戏。QGraphicsView提供了一个可滚动的视图窗口,可以在其中显示QGraphicsScene中的图形项。您可以使用QGraphicsView缩放、平移和旋转图形项,以及捕获鼠标和键盘事件。要使用QGraphicsView,您需要创建一个QGraphicsScene,并将其设置为QGraphicsView的场景。然后,您可以将图形项添加到场景中,并使用QGraphicsView显示它们。 ### 回答2: PyQt5是一个强大的工具包,其中包括了许多图形界面相关的模块。其中,QGraphicsViewPyQt5中的一个非常常用的图形视图框架,它提供了一个可以展示并且编辑图形呈现的服务。QGraphicsView从图形界面的一个角度来说,它是用来画出2D的图形,这些图形可以是由PyQt5包中图形元素组成的。 使用QGraphicsView的第一步就是创建一个QGraphicsScene对象并将其设置为QGraphicsView的画布。QGraphicsScene对象类似于一个容器,它可以用于存储和组织QGraphicsItem和QGraphicsWidget。QGraphicsItem是最基本的图形元素,它可以让我们向QGraphicsScene添加不同类型的图形像素,如折线、矩形、多边形、椭圆等等。 QGraphicsView类提供了一个在场景中浏览这些图形元素的功能。可以通过拖动、选择和缩放的形式查看不同的图形元素。一些常见的操作包括缩放、旋转、移动和变换,这些都是通过QGraphicsView类中的一些方法来实现的。QGraphicsView类其实是将QGraphicsScene的内容呈现到一个窗口,该窗口是由QGraphicsView对象实现。 另外,QGraphicsView类还提供了一些其他常见的操作,如鼠标移动、单击、双击、按下、松开等操作,以便我们响应相应的事件。我们可以通过重写这些方法来实现与场景交互的自定义处理逻辑。 总之,QGraphicsView是一个非常强大的工具,可以提供图形界面上呈现和编辑图形元素的功能。通过掌握QGraphicsView的一些常见操作和方法,我们可以快速地创建出漂亮的图形界面程序,并让它们交互起来。 ### 回答3: PyQt5是Python语言的一个GUI工具包,它使用Qt库开发而成。其中,QGraphicsViewPyQt5的一个组件,它可以用来创建一个可视化的图形界面,显示各种复杂的图形元素,包括线条、矩形、圆形、文本、图片等。 使用QGraphicsView,我们可以轻松创建交互性强、视觉效果好的图形应用程序。以下是关于QGraphicsView的一些具体用法说明: 1. 创建QGraphicsView对象 首先,我们需要导入PyQt5库,并创建一个QGraphicsView对象,来显示我们想要展示的图形元素。例如: - from PyQt5.QtWidgets import QGraphicsView - view = QGraphicsView() 2. 添加场景(Scene) 接下来,我们需要创建一个或多个场景(Scene),来放置我们要展示的图形元素。在QGraphicsView中,场景是存放图形项(QGraphicsItem)的容器,可以理解为一个画布。我们可以使用QGraphicsScene类创建一个场景对象,并将其添加到QGraphicsView中。例如: - from PyQt5.QtWidgets import QGraphicsScene - scene = QGraphicsScene() - view.setScene(scene) 3. 添加图形项 在场景中,我们可以添加各种图形项,例如,矩形、椭圆、文本、图片等等。在QGraphicsView中,图形项是指由QGraphicsItem派生出来的类,如QGraphicsRectItem、QGraphicsEllipseItem、QGraphicsTextItem等。我们可以使用这些类来创建图形项,并将它们添加到场景中。例如: - from PyQt5.QtWidgets import QGraphicsRectItem - item1 = QGraphicsRectItem(0, 0, 100, 100) - item2 = QGraphicsRectItem(150, 150, 100, 100) - scene.addItem(item1) - scene.addItem(item2) 4. 图形项的属性设置 在添加图形项后,我们可以对其进行属性设置,例如,设置边框线条的颜色、线宽、线型,设置填充的颜色,设置旋转角度、缩放因子等等。例如: - item1.setPen(QPen(Qt.red, 2, Qt.SolidLine)) - item1.setBrush(QColor(255, 0, 0, 50)) - item1.setRotation(45) - item2.setScale(0.5) 5. 事件处理 在QGraphicsView中,我们可以通过事件机制来处理用户的交互行为,例如鼠标点击、鼠标移动、键盘事件等等。我们可以重写各种事件函数(例如mousePressEvent、mouseMoveEvent、keyPressEvent等)来实现自己的逻辑。例如: - def mousePressEvent(self, event): - item = self.scene().itemAt(event.pos()) - item.setBrush(QColor(0, 255, 0, 50)) 以上就是QGraphicsView的使用过程。通过组合使用QGraphicsView、QGraphicsScene和QGraphicsItem,我们可以轻松创建出丰富多彩的图形应用程序。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值