计算机图形学实验四-简单几何形体(三角形、多边形等)的平移、缩放、旋转等几何变换

本文主要是介绍计算机图形学实验四-简单几何形体(三角形、多边形等)的平移、缩放、旋转等几何变换,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

3.1 实验数据和结果

  1. 平移、旋转、缩放算法说明与测试

①算法说明

根据老师上课讲的多边形的几何变换,操作的过程其实就是将变换矩阵M作用于齐次坐标点P生成新的坐标点P’,即 P’=M·P,其中M称为变换矩阵,点的坐标表示采用齐次坐标形式,所以在本次实验中,我同样采用矩阵的计算来进行多边形的几何变换的。

平移的算法说明:多边形的平移变换可以看成组成多边形的各个顶点的移动,即在x轴和y轴方向上分别移动一段距离。这里以一个点为例进行说明,P(x,y)在x轴和y轴方向上分别移动Tx和Ty,生成新的点P1(x1,y1),如图1所示,其中是点在x轴和y轴上移动的距离,用矩阵的形式表示如图2:

旋转的算法说明:多边形的旋转可以看成组成多边形的顶点的旋转,以一图形上的点P(x,y)为例,将其绕原点旋转θ角度(逆时针旋转为正),生成的新的点坐标P1(x1,y1),点的旋转如图1所示,用矩阵的形式表示如图2:

缩放的算法说明:多边形的缩放可以看做各个顶点沿着x轴和y轴方向比例缩小或放大。以图形上的点P(x,y)为例,在x轴和y轴方向分别作Sx和Sy的缩放,结果生成新的点坐标P1(x1,y1),如图1所示,其中是点在x轴和y轴上的缩放比例,用矩阵的形式表示如图2,其中,多边形的缩放若以坐标原点为缩放参考点,不仅改变了物体的大小和形状;另外,当|Sx|=|Sy|时,变换前后的图形相似,而|Sx|≠|Sy|时,图形会发生畸变,在本程序中也实现了图形的等比例和不等比例的缩放。

②算法设计

平移的算法设计:首先定义平移函数,传入平移变换量tx,ty,其中tx、ty的值是由鼠标点击位置来确定的(具体算法在2.1中进行说明),初始化单位矩阵(关于矩阵的相关算法在6.2中进行说明),将tx、ty的值填入对应的单位矩阵位置中,然后使之与另外定义相同维度的单位矩阵进行矩阵相乘,最后更新多边形上点的坐标,这样就完成了图形的平移。

关于更新多边形各个顶点坐标的函数说明:因为平移、旋转、缩放等集合变换均用到了更新坐标的操作,所以这里将这个功能单独定义成一个函数,其中xy是定义的多边形矩阵,用于存放多边形顶点,循环遍历各个顶点,使顶点的x、y坐标分别与Composite矩阵相乘,从而做到更新坐标的功能。

旋转的算法设计:首先定义旋转函数,传入旋转参考点坐标x,y,以及旋转角度theta(θ),其中x、y的值是由鼠标点击位置来确定的(具体算法在2.1中进行说明),这里实现了旋转操作可以指定变换参考点的操作,首先将theta值弧度化,接着初始化单位矩阵(关于矩阵的相关算法在6.2中进行说明),将x、y、theta的值填入对应的单位矩阵位置中,然后使之与另外定义相同维度的单位矩阵进行矩阵相乘,最后更新多边形上点的坐标,这样就完成了图形的旋转。

关于theta角度的说明:逆时针旋转为正,顺时针旋转为负,鼠标点击的地方为旋转参考点,即这里将tran_x,tran_y传入rotate函数,0.5是设置的旋转角度,便于观察一周的变化,这里将旋转角度设置的相对较小。

缩放的算法设计:首先定义缩放函数,传入缩放变量sx,sy,参考点的坐标(x,y),其中sx、sy的值是由鼠标点击位置来确定的,初始化单位矩阵(关于矩阵的相关算法在6.2中进行说明),将sx、sy、x、y的值填入对应的单位矩阵位置中,然后使之与另外定义相同维度的单位矩阵进行矩阵相乘,最后更新多边形上点的坐标,这样就完成了图形的缩放。

关于sx、sy的值的说明:sx、sy一开始设定的值是1,根据不同的缩放策略来调整sx、sy的值,其中不等比例缩放,当监测到鼠标点击的点大于参考点的时候,分别对sx、sy进行0.01缩放比例的相加,反之,对缩放比例进行0.01的相减;而在等比例缩放中,监测到鼠标点击的点大于参考点的时候,对缩放比例sx、sy同时进行加减操作,这里将两种情况均以代码的形式呈现。

③算法测试

平移算法的测试:如下图所示,左图是绘制的三角形(多边形的绘制在6.3中进行说明),右图是点击菜单之后图形的平移情况,若发现图形平移情况不理想,则可以点击鼠标左键进行拖动,最终效果示例图如右图所示,但是要说明的是,因为考虑到用户交互方便,这里有一个小问题,即图形只能在第一象限移动,原因是因为鼠标点击的点在画布上均为正值,这样图形的平移只能在第一象限移动。

旋转算法的测试:如下图所示,左图是绘制的四边形,左图是经过旋转后的图像,与平移不同,在刚点击旋转菜单项之后,图形不会立即左除响应,而是当鼠标进行旋转拖动的时候,图形会逆时针旋转。同样的,由于要进行用户交互,所以图形的旋转依然在第一象限内进行。

缩放算法的测试:图1是初始绘制的多边形,图2是等比例放大后的图像,图3是不等比例缩放后的图像,具体操作是鼠标在y=x或者y=-x直线上拖动时,实现的是图形的等比例缩放,其他情况则是图形的不等比例缩放,所以在用户实现操作中,还是以不等比例缩放为主

  1. 对称的说明与测试

对称的算法说明:多边形的对称变换可以看成组成多边形的各个顶点的关于轴或者直线的对称,对称变换也称反射变化。这里直接将变换前后的点表示成矩阵的形式,如下图所示,对于不同的abde值,对应不同的对称变化,有下面几种情况:b=d=0,a=-1,e=1时,作与y轴对称的反射变换;b=d=0,a=1,e=-1时,作与x轴对称的反射变换;b=d=0,a=e=-1时,作与原点对称的反射变换;b=d=1,a=e=0时,作与y=x直线对称的反射变换;b=d=-1,a=e=0时,作与y=-x对称的反射变换。

对称的算法设计:采用鼠标键盘交互的方式,鼠标用于选择对称算法,键盘用于选择对称的类型,同样将上述矩阵转换成代码的形式,根据不同的type值,设定不同的abde值。

对称的算法测试:图1是绘制的原图,图2是关于x轴对称的图形,图3是在图2的基础上关于y轴对称的图形,依次类推,图4是图3关于原点对称的图形,图5是图4关于y=x直线对称的图形,图6是图5关于y=-x直线对称的图形。这里程序运行时有一个小bug,切换对称状态之后,用鼠标点击对称操作图形出现“闪现”的现象,不稳定,这种情况多点几次菜单中的对称选项即可。

详细代码见链接:https://download.csdn.net/download/weixin_53249260/88236610

这篇关于计算机图形学实验四-简单几何形体(三角形、多边形等)的平移、缩放、旋转等几何变换的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/288906

相关文章

C++初始化数组的几种常见方法(简单易懂)

《C++初始化数组的几种常见方法(简单易懂)》本文介绍了C++中数组的初始化方法,包括一维数组和二维数组的初始化,以及用new动态初始化数组,在C++11及以上版本中,还提供了使用std::array... 目录1、初始化一维数组1.1、使用列表初始化(推荐方式)1.2、初始化部分列表1.3、使用std::

redis群集简单部署过程

《redis群集简单部署过程》文章介绍了Redis,一个高性能的键值存储系统,其支持多种数据结构和命令,它还讨论了Redis的服务器端架构、数据存储和获取、协议和命令、高可用性方案、缓存机制以及监控和... 目录Redis介绍1. 基本概念2. 服务器端3. 存储和获取数据4. 协议和命令5. 高可用性6.

JAVA调用Deepseek的api完成基本对话简单代码示例

《JAVA调用Deepseek的api完成基本对话简单代码示例》:本文主要介绍JAVA调用Deepseek的api完成基本对话的相关资料,文中详细讲解了如何获取DeepSeekAPI密钥、添加H... 获取API密钥首先,从DeepSeek平台获取API密钥,用于身份验证。添加HTTP客户端依赖使用Jav

css实现图片旋转功能

《css实现图片旋转功能》:本文主要介绍了四种CSS变换效果:图片旋转90度、水平翻转、垂直翻转,并附带了相应的代码示例,详细内容请阅读本文,希望能对你有所帮助... 一 css实现图片旋转90度.icon{ -moz-transform:rotate(-90deg); -webkit-transfo

Python将大量遥感数据的值缩放指定倍数的方法(推荐)

《Python将大量遥感数据的值缩放指定倍数的方法(推荐)》本文介绍基于Python中的gdal模块,批量读取大量多波段遥感影像文件,分别对各波段数据加以数值处理,并将所得处理后数据保存为新的遥感影像... 本文介绍基于python中的gdal模块,批量读取大量多波段遥感影像文件,分别对各波段数据加以数值处

利用Python编写一个简单的聊天机器人

《利用Python编写一个简单的聊天机器人》这篇文章主要为大家详细介绍了如何利用Python编写一个简单的聊天机器人,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 使用 python 编写一个简单的聊天机器人可以从最基础的逻辑开始,然后逐步加入更复杂的功能。这里我们将先实现一个简单的

基于WinForm+Halcon实现图像缩放与交互功能

《基于WinForm+Halcon实现图像缩放与交互功能》本文主要讲述在WinForm中结合Halcon实现图像缩放、平移及实时显示灰度值等交互功能,包括初始化窗口的不同方式,以及通过特定事件添加相应... 目录前言初始化窗口添加图像缩放功能添加图像平移功能添加实时显示灰度值功能示例代码总结最后前言本文将

使用IntelliJ IDEA创建简单的Java Web项目完整步骤

《使用IntelliJIDEA创建简单的JavaWeb项目完整步骤》:本文主要介绍如何使用IntelliJIDEA创建一个简单的JavaWeb项目,实现登录、注册和查看用户列表功能,使用Se... 目录前置准备项目功能实现步骤1. 创建项目2. 配置 Tomcat3. 项目文件结构4. 创建数据库和表5.

使用PyQt5编写一个简单的取色器

《使用PyQt5编写一个简单的取色器》:本文主要介绍PyQt5搭建的一个取色器,一共写了两款应用,一款使用快捷键捕获鼠标附近图像的RGB和16进制颜色编码,一款跟随鼠标刷新图像的RGB和16... 目录取色器1取色器2PyQt5搭建的一个取色器,一共写了两款应用,一款使用快捷键捕获鼠标附近图像的RGB和16

四种简单方法 轻松进入电脑主板 BIOS 或 UEFI 固件设置

《四种简单方法轻松进入电脑主板BIOS或UEFI固件设置》设置BIOS/UEFI是计算机维护和管理中的一项重要任务,它允许用户配置计算机的启动选项、硬件设置和其他关键参数,该怎么进入呢?下面... 随着计算机技术的发展,大多数主流 PC 和笔记本已经从传统 BIOS 转向了 UEFI 固件。很多时候,我们也