opengl 教程(7) 旋转变化

简介: 原帖地址:http://ogldev.atspace.co.uk/www/tutorial07/tutorial07.html       本章我们来学习一下,物体的旋转。所谓旋转,就是一个点,绕某个固定的轴转动一定的角度。

原帖地址:http://ogldev.atspace.co.uk/www/tutorial07/tutorial07.html

      本章我们来学习一下,物体的旋转。所谓旋转,就是一个点,绕某个固定的轴转动一定的角度。在笛卡尔坐标系中,我们绕某个主轴转动时候,会保持该轴决定的分量不变,比如绕z轴旋转,z坐标分量不变,x,y分量变化,所以又称绕xy平面旋转,当然,我们也可以绕任意向量进行旋转操作。

我们通过下面的图来了解一下旋转矩阵是如何产生的?

rotation

沿着圆把顶点从位置(x1,y1)移动到(x2,y2),由图可知,旋转的角度是 a2 ,假定圆是以弧度为单位,则有下面的式子:

x1=cos(a1)
y1=sin(a1)
x2=cos(a1+a2)
y2=sin(a1+a2)

用正弦和余弦公式展开,则有:

cos(a+b) = cosacosb - sinasinb
sin(a+b) = sinacosb+cosasinb

x2=cos(a1+a2) = cosa1cosa2 - sina1sina2 = x1cosa2 - y1sina2

y2=sin(a1+a2) = sina1cosa2 + cosa1sina2 = y1cosa2 + x1sina2

上面的式子是绕xy平面的旋转变化,转化到齐次坐标,则有下面的公式:

07_01

同理,绕y轴的旋转矩阵如下:

07_02

绕x轴旋转矩阵如下:

07_03

主要变化代码:

程序代码做很小的变动,就是改变世界矩阵的值,改用绕z轴渲染的矩阵。

World.m[0][0]=cosf(Scale); World.m[0][1]=-sinf(Scale); World.m[0][2]=0.0f; World.m[0][3]=0.0f;
World.m[1][0]=sinf(Scale); World.m[1][1]=cosf(Scale);  World.m[1][2]=0.0f; World.m[1][3]=0.0f;
World.m[2][0]=0.0f;        World.m[2][1]=0.0f;         World.m[2][2]=1.0f; World.m[2][3]=0.0f;
World.m[3][0]=0.0f;        World.m[3][1]=0.0f;         World.m[3][2]=0.0f; World.m[3][3]=1.0f;

程序执行后界面如下:

image

相关文章
|
7月前
QT4.7版本的OPENGL的3D旋转模型例子
QT4.7版本的OPENGL的3D旋转模型例子
135 0
|
C++ 计算机视觉 Python
C++ VS OpenGL绘制教室三维立体旋转图像
C++ VS OpenGL绘制教室三维立体旋转图像
163 0
C++ VS OpenGL绘制教室三维立体旋转图像
|
存储 Java Android开发
Android OpenGL ES(六)----进入三维在代码中创建投影矩阵和旋转矩阵
Android OpenGL ES(六)----进入三维在代码中创建投影矩阵和旋转矩阵
195 0
Android OpenGL ES(六)----进入三维在代码中创建投影矩阵和旋转矩阵
|
缓存 Swift iOS开发
OpenGL ES 案例02:GLKit绘制立方体+旋转
OpenGL ES 案例02:GLKit绘制立方体+旋转
205 0
OpenGL ES 案例02:GLKit绘制立方体+旋转
|
Swift 容器
OpenGL ES 案例03:CoreAnimation绘制立方体+旋转
OpenGL ES 案例03:CoreAnimation绘制立方体+旋转
214 0
OpenGL ES 案例03:CoreAnimation绘制立方体+旋转
|
API Android开发 索引
【OpenGL ES】OpenGL ES 2.0 -- 制作 3D 彩色旋转三角形 - 顶点着色器 片元着色器 使用详解(一)
【OpenGL ES】OpenGL ES 2.0 -- 制作 3D 彩色旋转三角形 - 顶点着色器 片元着色器 使用详解(一)
155 0
【OpenGL ES】OpenGL ES 2.0 -- 制作 3D 彩色旋转三角形 - 顶点着色器 片元着色器 使用详解(一)
openGL简明教程(一)---开始的开始,绘制一个三角形
openGL简明教程(一)---开始的开始,绘制一个三角形
260 0
|
API
【OpenGL ES】OpenGL ES 2.0 -- 制作 3D 彩色旋转三角形 - 顶点着色器 片元着色器 使用详解(三)
【OpenGL ES】OpenGL ES 2.0 -- 制作 3D 彩色旋转三角形 - 顶点着色器 片元着色器 使用详解(三)
221 0
|
API 索引 容器
【OpenGL ES】OpenGL ES 2.0 -- 制作 3D 彩色旋转三角形 - 顶点着色器 片元着色器 使用详解(二)
【OpenGL ES】OpenGL ES 2.0 -- 制作 3D 彩色旋转三角形 - 顶点着色器 片元着色器 使用详解(二)
224 0