QGraphicsView如何使图片以鼠标为中心进行放缩

这篇具有很好参考价值的文章主要介绍了QGraphicsView如何使图片以鼠标为中心进行放缩。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

QGraphicsView如何使图片以鼠标为中心进行放缩

顺带说一句,下面的代码放在了一个继承了QMainWindow的自定义class里面,这个类包含着一个QGraphicsView部件,所有以下的代码都会以为处在类中而出现对应的首行缩进。

QGraphicsView的自带语句实现

因为QGraphicsView是从Qt整个改过来的,自然包含了所有的部件,其中就有所用到的三句话:
self.ui.graphicsView.setDragMode(QGraphicsView.ScrollHandDrag)
self.ui.graphicsView.setTransformationAnchor(QGraphicsView.AnchorUnderMouse)
self.ui.graphicsView.setResizeAnchor(QGraphicsView.AnchorUnderMouse)
可以很清楚地发现,第一句是自带的拖动效果的实现,第二句是说将变换的锚点设置到鼠标的下面,第三句话说的是将图元重设大小时的锚点设置到鼠标下面,这里就将放大缩小的点设置到了鼠标的下面。这样一来就可以通过指定点进行放大缩小。

QGraphicsView的事件重写实现

那么问题来了,我如果有一个自定义的函数需要写的话,怎么跟这个已有的方法结合起来呢?类的继承是可以,但是这家伙看着也不像一个类啊,倒像是一个方法,那我们除了将_文档_找出来慢慢研读,就是自己实现所有的操作了,文档可以去官方查找,里面用的是当前鼠标坐标与整个视图坐标的比值,再通过比值确定滚动条的位置进行操作,下方的滚动条设置偏左,右边的滚动条设置偏上 ,就能使得图片进行左上为中心的变换,至于具体位置根据图元与视图的比值进行计算就可以。
但是我有一个__更简单的逻辑__,就是将图片的重绘点设置在一个变化后的点,这个点也是通过计算算出来的,但是不同的是,这个点的坐标比较容易计算,并且没有涉及到任何其他部件,只是单纯更新一个点然后进行重绘。这个点的计算方法我会详细介绍给大家。

重写过程中涉及到的事件

既然自己重写了,那么鼠标的所有事件都要自己来一遍
之前讲过图片的放大缩小和移动,但是那个放缩是改变了滑动条,不能指哪变哪,所以这次的鼠标滑动事件和鼠标移动事件都要稍微改动一下。

自定义滚轮事件的实现逻辑

第一步:提取图片的左上和右下两个点来确定计算所需要的参数:图元第一次绘制的setPos()图片转来的图片的尺寸;第二步:获取鼠标当前坐标值以进行计算;第三步:计算出差值偏移量delta;第四步:进行图元的重绘

对于滚轮事件计算的说明

滚轮事件的第三步有一个计算出delta差值,这里截出来代码给大家看看:


# -*- coding: utf-8 -*-
"""
@author:xiaoyangchicao2020
@time:2022-99-99
"""
self.item.setScale(self.ratio)
a1=self.posss - self.item.pos()
a2=self.ratio/(self.ratio-self.step)-1
self.delta = a1 * a2
self.posnow=self.item.pos()-self.delta
self.item.setPos(self.posnow)

self.ratio是一个int,说的是图片初始的大小比例,一般设为1。self.posss就是鼠标现在相对于view的坐标了,就是==mapToscne(event.pos())==这个方法返回的值,是鼠标当前坐标,是一个QPoinF,然后用这个坐标减去图元一开始所在的坐标,也就是setPos()的那个坐标点。self.step就是图片缩放的步长,太大了图片突变,我设置的是0.3,按照这个数学运算最终会得出一个点,这个点就是需要变换的坐标差值,用图元之前的坐标减去差值,就是图元现在应该重新设置的地方,就是那个self.posnow图片在这个点重绘之后就能得到以鼠标为中心的放大缩小的效果。
完整代码如下):


# -*- coding: utf-8 -*-
"""
@author:xiaoyangchicao2020
@time:2022-99-99
"""
	self.ratio = 1#缩放系数
	self.step = 0.3 #缩放步长
	self.posnow = QPointF(0, 0)  # 图片绘制位置
    def wheel_Event_tinghua(self,event):
        angle = event.angleDelta() / 8
        angley = angle.y()
        self.posss=self.ui.graphicsView.mapToScene(event.pos())
        if angley > 0:
            self.ratio+=self.step
            w = math.ceil(self.pix.width()*(self.ratio-self.step))
            h = math.ceil(self.pix.height()*(self.ratio-self.step))
            x1=self.item.pos().x()
            x2=self.item.pos().x()+w
            y1=self.item.pos().y()
            y2=self.item.pos().y()+h
            if self.posss.x() > x1 and self.posss.x() < x2 * self.ratio \
                and self.posss.y() > y1 and self.posss.y() < y2 * self.ratio:
                self.inimg = True
                self.item.setScale(self.ratio)
                value1=self.posss - self.item.pos()
                value2=self.ratio/(self.ratio-self.step)-1
                self.delta = value1 * value2
                self.posnow=self.item.pos()-self.delta
                self.item.setPos(self.posnow)
            else:
                pass
        elif angley < 0:
            self.ratio -= self.step
            w =  math.ceil(self.pix.width() * (self.ratio + self.step))
            h =  math.ceil(self.pix.height() * (self.ratio + self.step))
            x1 = self.item.pos().x()
            x2 = self.item.pos().x() + w
            y1 = self.item.pos().y()
            y2 = self.item.pos().y() + h
            if self.posss.x() > x1 and self.posss.x() < x2 * self.ratio \
                and self.posss.y() > y1 and self.posss.y()  < y2 * self.ratio:
                self.inimg = True
                self.item.setScale(self.ratio)
                value1=self.posss - self.item.pos()
                value2=self.ratio/(self.ratio+self.step)-1
                self.delta = value1 * value2
                self.posnow = self.item.pos()-self.delta
                self.item.setPos(self.posnow)
            else:
                pass

看起来很长其实只是因为判断语句和前期获取计算需要的数据进行的工作比较多,其实逻辑还是很清晰的。文章来源地址https://www.toymoban.com/news/detail-647411.html

到了这里,关于QGraphicsView如何使图片以鼠标为中心进行放缩的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • QGraphicsView通过鼠标操作来绘制图元

    在Visio和MindManager等类似的图元操作软件中,很多时候我们会通过鼠标操作来添加自定义的图元。这里就介绍一下如何在QT的图形视图框架中通过鼠标绘制来添加图元。 在实现的时候我们先添加一个自定义图元用来响应鼠标操作,自定义图元的实现如下所示. 辅助图元类似于标

    2024年02月13日
    浏览(49)
  • Qt中QGraphicsView架构下实时鼠标绘制图形

    上一章节介绍了关于QGraphicsView的基础讲解,以及简单的类图创建,由上一章节中最后展示的动画效果来看,今年主要讲述如何在QGraphicsView架构下,实时拖动鼠标绘制图形! 今天主要以矩形为例,再来看一下展示效果吧! 想要实现鼠标拖拽绘图的效果,离不开鼠标的三大事件

    2024年01月22日
    浏览(44)
  • QGraphicsView制作绘制图元工具资料整理(鼠标、平移、缩放)

    QGraphicsView制作绘制工具资料整理 继承自QGraphicsView的类中使用QGraphicsSceneMouseEvent 简单显示图片的示例 Qt之QGraphicsView入门篇 Qt之QGraphicsView入门篇 鼠标事件和滚轮事件 鼠标事件和滚轮事件 QGraphicsItem的缩放 QGraphicsItem的缩放 QT官方文档:QGraphicsItem Class QGraphicsItem Class Qt之QGraph

    2024年02月09日
    浏览(38)
  • QGraphicsView 显示图片

    QGraphicsView 是 PyQt6 里负责显示图形的组件,搭配 QGraphicsScene 和 QtGui.QPixmap() 就可以显示图片,这篇教学会介绍如何在 PyQt6 窗口里加入 QGraphicsView 组件并显示图片。 快速预览: QGraphicsView 显示图片 改变图片尺寸 设定图片位置 显示多张图片 建立 PyQt6 窗口物件后, 透过 QtWidg

    2023年04月25日
    浏览(32)
  • 【[Qt]基于QGraphicsView的图像显示控件,支持放大、缩小、鼠标拖动】

    ImageViewer.h文件 ImageViewer.cpp 文件 具体使用代码如下 1、初始化类对象,并加入界面布局中 2、打开图像,并加载到控件中 3、从控件中卸载图片 源码链接:https://download.csdn.net/download/xiaohuihuihuige/87239431 百度云: 链接:https://pan.baidu.com/s/1W-KUlIKUFAktUKFin63N0g 提取码:4g8a

    2024年02月11日
    浏览(58)
  • 《QT从基础到进阶·十五》用鼠标绘制矩形(QGraphicsView、QPainter、QGraphicsRectItem)

    以下是鼠标绘制矩形最全的一种用法,完整源码将会放在最后面。 QT版本:5.15.2 VS版本:2019 1、在界面加载一张图片 界面的搭建选用QGraphicsView,自定义类GraphicsView继承QGraphicsView,在主程序中点击按钮打开 图片,相关代码如下: 2、创建矩形绘制对象,并绘制、移动矩形 在

    2024年02月04日
    浏览(50)
  • 【Qt图形视图框架】自定义QGraphicsItem和QGraphicsView,实现鼠标(移动、缩放)及键盘事件、右键事件

    说明 在使用Qt的图形视图框架实现功能时,一般会在其基础上进行自定义功能实现。 如:滚轮对场景的缩放,鼠标拖动场景中的项,以及可以在场景中进行右键操作等。 示例 myitem 为自定义QGraphicsItem,实现了边框、重绘事件、鼠标悬停、按键、右键菜单等功能。 myitem.h myi

    2024年02月04日
    浏览(48)
  • QGraphicsView 如何让图形大小适配窗口

    setSceneRect是一个Qt中的函数,用于设置QGraphicsView中的场景矩形(QRectF)。 QGraphicsView是一个用于显示和编辑图形场景的控件,而setSceneRect函数用于设置场景矩形,即指定场景的可视区域的大小和位置。具体来说,它的作用有以下几个方面: 定义场景的大小:通过设置场景矩形

    2024年01月24日
    浏览(33)
  • Qt中QGraphicsView总体架构学习

    前段时间学习了下如何在QGraphicsView架构中绘制刻度尺,主要是与OnPainter中进行比较的,那么今天就来详细讲解下我对QGraphicsView框架的认知吧~ 最近一段时间想学习下,如果我有不正确的,欢迎留言探讨哟~ 使用过OnPainter绘制过图形的,QPainter绘制需要在绘制设备的paintEvent()事

    2024年02月02日
    浏览(36)
  • QGraphicsView 实例3地图浏览器

    主要介绍Graphics View框架,实现地图的浏览、放大、缩小,以及显示各个位置的视图、场景和地图坐标 效果图:  mapwidget.h  mapwidget.cpp

    2024年02月12日
    浏览(36)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包