当前位置: 首页 > news >正文

【qt】视口和窗口坐标

视口和窗口坐标

  • 一.视口和窗口坐标的原理
  • 二.视口和窗口坐标的好处
  • 三.演示好处
  • 四.总结

一.视口和窗口坐标的原理

在绘图事件中进行绘图

void Widget::paintEvent(QPaintEvent *event)
{QPainter painter(this);QRect rect(200,0,200,200);painter.drawRect(rect);//设置视口的范围,相当于一个窗口painter.setViewport(rect);//设置窗口坐标,这是逻辑大小,可以自己任意设计//左上角的坐标为(-50,-50),长为100,宽为100,这是逻辑大小//原本我们的设置的视口范围为长200,宽200painter.setWindow(-50,-50,100,100);QPen pen;pen.setColor(Qt::blue);//换个颜色区分painter.setPen(pen);painter.drawRect(QRect(0,0,50,50));}

运行结果;
在这里插入图片描述
原理:
在这里插入图片描述

二.视口和窗口坐标的好处

1.我们可以自定义窗口的坐标大小(逻辑大小)
2.视口里面的绘图可以自适应视口大小的变化.

三.演示好处

void Widget::paintEvent(QPaintEvent *event)
{QPainter painter(this);int minSide=qMin(this->width(),this->height());//取最小的窗口边QRect rect((this->width()-minSide)/2,(this->height()-minSide)/2,minSide,minSide);painter.drawRect(rect);painter.drawEllipse(QPoint(200,200),50,50);//圆心,水平半径,垂直半径}

运行结果:
在这里插入图片描述

这个矩形可以随窗口的变化而变化.但是这个圆不可以.
现在我们开始添加视口和窗口.

void Widget::paintEvent(QPaintEvent *event)
{QPainter painter(this);int minSide=qMin(this->width(),this->height());//取最小的窗口边QRect rect((this->width()-minSide)/2,(this->height()-minSide)/2,minSide,minSide);painter.drawRect(rect);painter.drawEllipse(QPoint(200,200),50,50);painter.setViewport(rect);painter.setWindow(-100,-100,200,200);QPen pen;pen.setColor(Qt::red);painter.setPen(pen);int count=10;for(int i=0;i<count;i++){painter.drawEllipse(QPoint(50,0),50,50);painter.rotate(360/count);//坐标旋转}}

运行结果:
在这里插入图片描述
自适应:
在这里插入图片描述

四.总结

记住setViewportsetWindow就可以了!

马上姚期末考试了!

http://www.lryc.cn/news/371144.html

相关文章:

  • 优化SQL查询的策略和技巧 - AI提供
  • 平安科技智能运维案例
  • 基于深度学习的向量图预测
  • 鸿蒙HarmonyOS $r(““)与$rawfile(““)的区别
  • 简单了解java中的Collection集合
  • java 实现导出word 自定义word 使用aspose教程包含图片 for 循环 自定义参数等功能
  • CSS动画(炫酷表单)
  • Stream
  • 鸿蒙轻内核A核源码分析系列五 虚实映射(5)虚实映射解除
  • 编程初学者用什么软件电脑:全方位指南及深度解析
  • 代理IP池功能组件
  • Sqlite3入门和c/c++下使用
  • pyinstaller打包exe多种失败原因解决方法
  • x64-linux下在vscode使用vcpkg
  • 运营商二要素核验-手机号机主姓名核验接口-运营商二要素核验接口
  • C++设计模式-生产者消费者模式
  • VSTO Word.net 如何在另外的工程内添加CustomTaskPane
  • ROS——自定义话题消息和使用方法
  • 包装对象类型又是啥啊。。。
  • 服务编排如何选?这几款可视化服务编排引擎,开发团队赶紧收藏
  • web前端语言框架:探索现代前端开发的核心架构
  • 基于flask的网站如何使用https加密通信
  • 软件测试面试题(应届生)
  • 使用halo的jar方法搭建博客(数据库mysql
  • Linux - 复盘一次句柄数引发的故障
  • 2024/06/13--代码随想录算法2/17| 62.不同路径、63. 不同路径 II、343. 整数拆分 (可跳过)、96.不同的二叉搜索树 (可跳过)
  • Android低代码开发 - 直接创建一个下拉刷新列表界面
  • 23.Dropout
  • 电脑撤回的快捷键是什么?
  • 每日一题——Python实现PAT甲级1116 Come on! Let‘s C(举一反三+思想解读+逐步优化)五千字好文