第四章 OpenGL ES 基础-位移、缩放、旋转原理

2024-03-12 05:52

本文主要是介绍第四章 OpenGL ES 基础-位移、缩放、旋转原理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

第四章 OpenGL ES 基础-位移、缩放、旋转原理

第一章 OpenGL ES 基础-屏幕、纹理、顶点坐标
第二章 OpenGL ES 基础-GLSL语法简单总结
第三章 OpenGL ES 基础-GLSL渲染纹理
第四章 OpenGL ES 基础-位移、缩放、旋转原理
第五章 OpenGL ES 基础-透视投影矩阵与正交投影矩阵
第六章 OpenGL ES 基础-FBO、VBO理解与运用
第七章 OpenGL ES 基础-输入输出框架思维

矩阵小知识

对应矩阵效果
注意:必须是相同维度矩阵才行,比如23矩阵不能和33矩阵进行加减
在这里插入图片描述
矩阵与标量数乘和矩阵与标量加减类似, 实际是对矩阵的每个元素和该标量进行相乘,如下图所示在这里插入图片描述
所以值其实就是两个矩阵行列式相乘的和,取出矩阵A的i行下的所有元素与矩阵B的j列下的所有元素进行相乘和
在这里插入图片描述

OpenGL 初始化矩阵原理

并且任何矩阵与单位矩阵相乘都为矩阵本身.如下图所示:
在这里插入图片描述

根据上图的原理你可以4*4的矩阵,可以默认初始化矩阵,如下代码

void m3dLoadIdentity44(M3DMatrix44f m)
{// Don't be fooled, this is still column majorstatic M3DMatrix44f     identity = { 1.0f, 0.0f, 0.0f, 0.0f,0.0f, 1.0f, 0.0f, 0.0f,0.0f, 0.0f, 1.0f, 0.0f,0.0f, 0.0f, 0.0f, 1.0f };memcpy(m, identity, sizeof(M3DMatrix44f));
}

OpenGL的XYZ位移矩阵原理

在4×4矩阵上有几个特别的位置用来执行特定的操作,对于位移来说它们是第四列最上面的3个值。如果我们把位移向量表示为(Tx,Ty,Tz),我们就能把位移矩阵定义为:
在这里插入图片描述
m3dLoadIdentity44初始化后,对Tx,Ty,Tz进行对应参数补充

void m3dTranslationMatrix44(M3DMatrix44f m, float x, float y, float z)
{// 初始化为单位矩阵m3dLoadIdentity44(m);// 填充位移矩阵的最后一列m[12] = x;m[13] = y;m[14] = z;
}

OpenGL的缩放矩阵原理

矩阵来实现缩放功能, 如果我们把缩放变量表示为(S1,S2,S3)我们可以为任意向量(x,y,z)定义一个缩放矩阵:S1=2,x就放大2倍
在这里插入图片描述
所以上面图可以推测下标0,5,10的位置进行数据填充

void m3dScaleMatrix44(M3DMatrix44f m, float xScale, float yScale, float zScale)
{// 初始化为单位矩阵m3dLoadIdentity44(m);// 填充缩放矩阵的对角线元素m[0] = xScale;m[5] = yScale;m[10] = zScale;
}

OpenGL的旋转矩阵原理

对向量进行旋转也是通过矩阵实现.

比如对于二维进行旋转,其本质就是将z轴作为旋转轴实现旋转,

比如下图所示,由向量v向右旋转θ角度得到向量k:
在这里插入图片描述
那么我们如何获取向量k的x2和y2呢?
由于两个向量的长度都是相同的.并且:

x1 = 长度cosa y1 = 长度sina

所以:

x2 = 长度cos(a+θ) = 长度cosacosθ – 长度sinasinθ= x1cosθ – y1*sinθ

y2 =长度sin(a+θ) = 长度sinacosθ + 长度cosasinθ = y1cosθ + x1*sinθ

所以沿Z轴旋转的矩阵等于:
在这里插入图片描述
同理得出沿x轴旋转为:
在这里插入图片描述
沿y轴旋转为:
在这里插入图片描述

利用旋转矩阵我们可以把任意位置向量沿一个单位旋转轴进行旋转。也可以将多个矩阵复合,比如先沿着x轴旋转再沿着y轴旋转。但是这会很快导致一个问题——万向节死锁(Gimbal Lock)。在这里我们不会讨论它的细节,但是对于3D空间中的旋转,一个更好的模型是沿着任意的一个轴,比如单位向量(0.662, 0.2, 0.7222)旋转,而不是对一系列旋转矩阵进行复合。这样的一个(超级麻烦的)矩阵是存在的,见下面这个公式,其中(Rx,Ry,Rz)代表任意旋转轴:
在这里插入图片描述

有上面三个矩阵推测出

void m3dRotationMatrix44(M3DMatrix44f m, float angle, float x, float y, float z)
{float c = cos(angle);float s = sin(angle);float t = 1.0f - c;// 归一化旋转轴float mag = sqrt(x*x + y*y + z*z);if (mag > 0.0f) {x /= mag;y /= mag;z /= mag;} else {// 如果传入的旋转轴为零向量,则返回单位矩阵m3dLoadIdentity44(m);return;}// 填充旋转矩阵m[0] = x*x*t + c;m[1] = y*x*t - z*s;m[2] = z*x*t + y*s;m[3] = 0.0f;m[4] = x*y*t + z*s;m[5] = y*y*t + c;m[6] = z*y*t - x*s;m[7] = 0.0f;m[8] = x*z*t - y*s;m[9] = y*z*t + x*s;m[10] = z*z*t + c;m[11] = 0.0f;m[12] = 0.0f;m[13] = 0.0f;m[14] = 0.0f;m[15] = 1.0f;
}

这篇关于第四章 OpenGL ES 基础-位移、缩放、旋转原理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

深入探索协同过滤:从原理到推荐模块案例

文章目录 前言一、协同过滤1. 基于用户的协同过滤(UserCF)2. 基于物品的协同过滤(ItemCF)3. 相似度计算方法 二、相似度计算方法1. 欧氏距离2. 皮尔逊相关系数3. 杰卡德相似系数4. 余弦相似度 三、推荐模块案例1.基于文章的协同过滤推荐功能2.基于用户的协同过滤推荐功能 前言     在信息过载的时代,推荐系统成为连接用户与内容的桥梁。本文聚焦于

hdu4407(容斥原理)

题意:给一串数字1,2,......n,两个操作:1、修改第k个数字,2、查询区间[l,r]中与n互质的数之和。 解题思路:咱一看,像线段树,但是如果用线段树做,那么每个区间一定要记录所有的素因子,这样会超内存。然后我就做不来了。后来看了题解,原来是用容斥原理来做的。还记得这道题目吗?求区间[1,r]中与p互质的数的个数,如果不会的话就先去做那题吧。现在这题是求区间[l,r]中与n互质的数的和

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

poj 2187 凸包or旋转qia壳法

题意: 给n(50000)个点,求这些点与点之间距离最大的距离。 解析: 先求凸包然后暴力。 或者旋转卡壳大法。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <cmath>#include <s

【Linux 从基础到进阶】Ansible自动化运维工具使用

Ansible自动化运维工具使用 Ansible 是一款开源的自动化运维工具,采用无代理架构(agentless),基于 SSH 连接进行管理,具有简单易用、灵活强大、可扩展性高等特点。它广泛用于服务器管理、应用部署、配置管理等任务。本文将介绍 Ansible 的安装、基本使用方法及一些实际运维场景中的应用,旨在帮助运维人员快速上手并熟练运用 Ansible。 1. Ansible的核心概念

AI基础 L9 Local Search II 局部搜索

Local Beam search 对于当前的所有k个状态,生成它们的所有可能后继状态。 检查生成的后继状态中是否有任何状态是解决方案。 如果所有后继状态都不是解决方案,则从所有后继状态中选择k个最佳状态。 当达到预设的迭代次数或满足某个终止条件时,算法停止。 — Choose k successors randomly, biased towards good ones — Close

hdu4407容斥原理

题意: 有一个元素为 1~n 的数列{An},有2种操作(1000次): 1、求某段区间 [a,b] 中与 p 互质的数的和。 2、将数列中某个位置元素的值改变。 import java.io.BufferedInputStream;import java.io.BufferedReader;import java.io.IOException;import java.io.Inpu

hdu4059容斥原理

求1-n中与n互质的数的4次方之和 import java.io.BufferedInputStream;import java.io.BufferedReader;import java.io.IOException;import java.io.InputStream;import java.io.InputStreamReader;import java.io.PrintWrit

Android 10.0 mtk平板camera2横屏预览旋转90度横屏拍照图片旋转90度功能实现

1.前言 在10.0的系统rom定制化开发中,在进行一些平板等默认横屏的设备开发的过程中,需要在进入camera2的 时候,默认预览图像也是需要横屏显示的,在上一篇已经实现了横屏预览功能,然后发现横屏预览后,拍照保存的图片 依然是竖屏的,所以说同样需要将图片也保存为横屏图标了,所以就需要看下mtk的camera2的相关横屏保存图片功能, 如何实现实现横屏保存图片功能 如图所示: 2.mtk

音视频入门基础:WAV专题(10)——FFmpeg源码中计算WAV音频文件每个packet的pts、dts的实现

一、引言 从文章《音视频入门基础:WAV专题(6)——通过FFprobe显示WAV音频文件每个数据包的信息》中我们可以知道,通过FFprobe命令可以打印WAV音频文件每个packet(也称为数据包或多媒体包)的信息,这些信息包含该packet的pts、dts: 打印出来的“pts”实际是AVPacket结构体中的成员变量pts,是以AVStream->time_base为单位的显