ImageVerifierCode 换一换
格式:DOCX , 页数:13 ,大小:160.60KB ,
资源ID:10400442      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/10400442.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(绕任意轴旋转.docx)为本站会员(b****8)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

绕任意轴旋转.docx

1、绕任意轴旋转几何变换详解在三维图形学中,几何变换大致分为三种,平移变换(Translation),缩放变换(Scaling),旋转变换(Rotation)。以下讨论皆针对DirectX,所以使用左手坐标系。平移变换将三维空间中的一个点x, y, z, 1移动到另外一个点x, y, z, 1,三个坐标轴的移动分量分别为dx=Tx, dy=Ty, dz=Tz, 即x = x + Txy = y + Tyz = z + Tz平移变换的矩阵如下。缩放变换将模型放大或者缩小,本质也是对模型上每个顶点进行放大和缩小(顶点坐标值变大或变小),假设变换前的点是x, y, z, 1,变换后的点是x, y, z,

2、 1,那么x = x * Sxy = y * Syz = z * Sz缩放变换的矩阵如下。旋转变换这是三种变换中最复杂的变换,这里只讨论最简单的情况,绕坐标轴旋转,关于绕任意轴旋转,在后续的随笔中介绍。绕X轴旋转绕X轴旋转时,顶点的x坐标不发生变化,y坐标和z坐标绕X轴旋转度,旋转的正方向为顺时针方向(沿着旋转轴负方向向原点看)。x, y, z, 1表示变换前的点,x, y, z, 1表示变换后的点。变换矩阵如下。关于旋转的正方向,OpenGL与多数图形学书籍规定旋转正方向为逆时针方向(沿着坐标轴负方向向原点看),比如Computer Graphics C Version,p409。绕Y轴旋转

3、绕Y轴旋转时,顶点的y坐标不发生变化,x坐标和z坐标绕Y轴旋转度。x, y, z, 1表示变换前的点,x, y, z, 1表示变换后的点。变换矩阵如下。绕Z轴旋转绕Z轴旋转时,顶点的z坐标不发生变化,x坐标和y坐标绕Z轴旋转度。x, y, z, 1表示变换前的点,x, y, z, 1表示变换后的点。变换矩阵如下。绕坐标轴旋转的矩阵推导上面三个旋转矩阵是如何得来的呢?我们推导一下,首先看一下二维的情况,再扩展到三维即可。实际上上面三种绕坐标轴旋转的情况属于特殊的二维旋转,比如绕Z轴旋转,相当于在与XOY平面上绕原点做二维旋转。假设点P(x, y)是平面直角坐标系内一点,其到原点的距离为r,其与X

4、轴的夹角为A,现将点P绕原点旋转度,得到点P(x, y),P与X轴的夹角为B,则A = B - 。(注意,在二维坐标中,逆时针旋转时角度为正,顺时针旋转时角度为负,下图中由P旋转到P,角度为,若是由P转到P,则角度为-)。 于是可得下面的转换方程(式一)写成矩阵的形式就是求得旋转矩阵为由于这里使用齐次坐标,所以还需加上一维,最终变成如下形式绕Z轴旋转矩阵和前面给出的绕Z轴旋转矩阵完全吻合。对于绕X轴旋转的情况,我们只需将式一中的x用y替换,y用z替换,z用x替换即可。替换后得到(式二)对应的旋转矩阵为绕X轴旋转矩阵对于绕Y轴旋转的情况,只需对式二做一次同样的替换即可,的到的变换方程为对应的变换

5、矩阵为绕Y轴旋转矩阵逆矩阵平移变换矩阵的逆矩阵与原来的平移量相同,但是方向相反。旋转变换矩阵的逆矩阵与原来的旋转轴相同但是角度相反。缩放变换的逆矩阵正好和原来的效果相反,如果原来是放大,则逆矩阵是缩小,如果原来是缩小,则逆矩阵是放大。= Happy Coding =作者:zdd出处:绕任意轴旋转绕任意轴旋转的情况比较复杂,主要分为两种情况,一种是平行于坐标轴的,一种是不平行于坐标轴的,对于平行于坐标轴的,我们首先将旋转轴平移至与坐标轴重合,然后进行旋转,最后再平移回去。将旋转轴平移至与坐标轴重合,对应平移操作旋转,对应操作步骤1的逆过程,对应操作 整个过程就是对于不平行于坐标轴的,可按如下方法

6、处理。(该方法实际上涵盖了上面的情况)1将旋转轴平移至原点2将旋转轴旋转至YOZ平面3将旋转轴旋转至于Z轴重合4绕Z轴旋转度5执行步骤3的逆过程6执行步骤2的逆过程7执行步骤1的逆过程假设用v1(a1, b2, c2)和v2(a2, b2, c2)来表示旋转轴,表示旋转角度。为了方便推导,暂时使用右手系并使用列向量,待得出矩阵后转置一下即可,上面步骤对应的流程图如下。步骤1是一个平移操作,将v1v2平移至原点,对应的矩阵为步骤2是一个旋转操作,将p(p = v2 -v1)旋转至XOZ平面,步骤3也是一个旋转操作,将p旋转至与Z轴重合,这两个操作对应的图如下。做点p在平面YOZ上的投影点q。再过

7、q做Z轴垂线,则r是p绕X轴旋转所得,且旋转角度为,且, 于是旋转矩阵为现在将r绕Y轴旋转至与Z轴重合,旋转的角度为-beta(方向为顺时针),且, 于是得到旋转矩阵为最后是绕Z轴旋转,对应的矩阵如下如果旋转轴是过原点的,那么第一步和最后一步的平移操作可以省略,也就是把中间五个矩阵连乘起来,再转置一下,得到下面的绕任意轴旋转的矩阵即对应的函数代码如下。void RotateArbitraryAxis(D3DXMATRIX* pOut, D3DXVECTOR3* axis, float theta) D3DXVec3Normalize(axis, axis); float u = axis-x;

8、 float v = axis-y; float w = axis-z; pOut-m00 = cosf(theta) + (u * u) * (1 - cosf(theta); pOut-m01 = u * v * (1 - cosf(theta) + w * sinf(theta); pOut-m02 = u * w * (1 - cosf(theta) - v * sinf(theta); pOut-m03 = 0; pOut-m10 = u * v * (1 - cosf(theta) - w * sinf(theta); pOut-m11 = cosf(theta) + v * v

9、* (1 - cosf(theta); pOut-m12 = w * v * (1 - cosf(theta) + u * sinf(theta); pOut-m13 = 0; pOut-m20 = u * w * (1 - cosf(theta) + v * sinf(theta); pOut-m21 = v * w * (1 - cosf(theta) - u * sinf(theta); pOut-m22 = cosf(theta) + w * w * (1 - cosf(theta); pOut-m23 = 0; pOut-m30 = 0; pOut-m31 = 0; pOut-m32

10、 = 0; pOut-m33 = 1;如果旋转轴是不过原点的,那么第一步和最后一步就不能省略,将所有七个矩阵连乘起来,得到如下变换矩阵对应如下这个超长的矩阵,在这里(u, v, w) = (a2, b2, c2) - (a1, b1, c1),且是单位向量,a, b, c分别表示(a1, b1, c1)将上面的过程写成函数,该函数接受四个参数,第一个参数是一个输出参数,用来保存得到的旋转矩阵,第二个和第三个参数是旋转轴的两个端点,最后一个参数是旋转角度,注意,在函数中我们已经将上面的矩阵转置了,因为上面是按照列向量计算的。void RotateArbitraryLine(D3DXMATRIX*

11、 pOut, D3DXVECTOR3* v1, D3DXVECTOR3* v2, float theta) float a = v1-x; float b = v1-y; float c = v1-z; D3DXVECTOR3 p = *v2 - *v1; D3DXVec3Normalize(&p, &p); float u = p.x; float v = p.y; float w = p.z; float uu = u * u; float uv = u * v; float uw = u * w; float vv = v * v; float vw = v * w; float ww

12、= w * w; float au = a * u; float av = a * v; float aw = a * w; float bu = b * u; float bv = b * v; float bw = b * w; float cu = c * u; float cv = c * v; float cw = c * w; float costheta = cosf(theta); float sintheta = sinf(theta); pOut-m00 = uu + (vv + ww) * costheta; pOut-m01 = uv * (1 - costheta)

13、+ w * sintheta; pOut-m02 = uw * (1 - costheta) - v * sintheta; pOut-m03 = 0; pOut-m10 = uv * (1 - costheta) - w * sintheta; pOut-m11 = vv + (uu + ww) * costheta; pOut-m12 = vw * (1 - costheta) + u * sintheta; pOut-m13 = 0; pOut-m20 = uw * (1 - costheta) + v * sintheta; pOut-m21 = vw * (1 - costheta)

14、 - u * sintheta; pOut-m22 = ww + (uu + vv) * costheta; pOut-m23 = 0; pOut-m30 = (a * (vv + ww) - u * (bv + cw) * (1 - costheta) + (bw - cv) * sintheta; pOut-m31 = (b * (uu + ww) - v * (au + cw) * (1 - costheta) + (cu - aw) * sintheta; pOut-m32 = (c * (uu + vv) - w * (au + bv) * (1 - costheta) + (av - bu) * sintheta; pOut-m33 = 1;

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1