CS184.1X 计算机图形学导论(第四讲)
一、齐次变换
1、平移变换
变换矩阵不能包含X,Y,Z等坐标变量
如果x坐标向右平移了5个单位长度,则x~=x+5。在变换矩阵中表示的时候添加一个w坐标变量。通过加入一个w坐标,可以实现平移变换
1>如果w>0,这表示一个真实物理世界的点,因为你可以用x,y,z三个坐标初一w得到这个真是的点。
2>如果w=0,表示一个无穷远处的点
3>在实际应用中,w等于0通常用来表示一个向量
齐次坐标的优点:只需在渲染管线的最后做一次 除法(除以w)就能将齐次坐标转换为非齐次。
一般的平移矩阵:
可以简写为2*2的矩阵,左上角是一个3*3的单位矩阵,T和0是向量,1是数值。
旋转总是相对于原点!!先做旋转再做平移,因为矩阵乘法是不可交换的
2、齐次坐标
齐次坐标的形式:简而言之,齐次坐标就是用N+1维来代表N维坐标
齐次坐标在电脑图形内无处不在,因为该坐标允许平移、旋转、缩放及透视投影等可表示为矩阵与向量相乘的一般向量运算。
我们可以在一个2D笛卡尔坐标末尾加上一个额外的变量w来形成2D齐次坐标,因此,一个点(X,Y)在齐次坐标里面变成了(x,y,w),并且有
X = x/w
Y = y/w
我们把齐次坐标转化为笛卡尔坐标的方法是前面n-1个坐标分量分别除以最后一个分量即可。
例如,笛卡尔坐标系下(1,2)的齐次坐标可以表示为(1,2,1),如果点(1,2)移动到无限远处,在笛卡尔坐标下它变为(∞,∞),然后它的齐次坐标表示为(1,2,0),因为(1/0, 2/0) = (∞,∞),我们可以不用”∞"来表示一个无穷远处的点了
3、旋转变换
先平移再旋转的结果:
先旋转再平移的结果:
例题:
解:因为所变换的向量在后边,所以j是先平移再旋转,k是先旋转再平移,利用平移公式与旋转公式得出结果。
二、法向变换
这个公式要施加到曲面上所有的法向上,产生法向变换
例题:
解:
与M相关的法向变换Q=(M^−1)^T。
对于这里的旋转矩阵 R(a⃗ ,θ), 逆矩阵等于绕着相同的旋转轴旋转 −θ:
R(a⃗ ,θ)^−1=R(a⃗ ,−θ)
对这个矩阵转置产生相似的结果:R(a⃗ ,θ)^T=R(a⃗ ,−θ)
(R(a⃗ ,θ)^T=R(a⃗,θ)^−1 是旋转矩阵的一个特殊属性。)
组织起来我们得到:
R(a⃗,θ)^−T=R(a⃗,θ)
三、旋转和坐标系
坐标系分为世界坐标系和相机坐标系
图一可看成P点逆时针旋转了θ角度,而图二可以看成坐标轴顺时针旋转了θ角度
从u,v轴分别向x,y轴画垂线,假设u,v长度为单位1,则u的坐标为(cosθ,-sinθ),v(sinθ,cosθ),对应旋转矩阵的数值
旋转矩阵的行可以看成新坐标轴的坐标
轴角公式:
例题:
图解如下图所示:
现将标准坐标轴原点移动到新的原点处,根据新x,y画出新x,y轴的方向(也可以根据上边公式得出),i点当好在新x轴上,(根号2,0)
四、推导GLULOOKAT
1、定义:gluLookAt是OpenGL中观察变换的一个关键函数。
2、gluLookAt矩阵可以简要总结为:gluLookAt矩阵可以认为先将相机/视点平移到原点,然后绕着原点旋转,使得相机可以观察模型,通常,在OpenGL中相机朝着−z⃗方向观察。
在这里,平移向量就是视点坐标,更准确的说是负的视点坐标,因为不得不对世界坐标系做相反的平移
CS184.1X 计算机图形学导论(第四讲)的更多相关文章
- CS184.1X 计算机图形学导论 第3讲L3V1
二维空间的变换 L3V1这一课主要讲了二维空间的变换,包括平移.错切和旋转. 缩放 缩放矩阵 使用矩阵的乘法来完成缩放 缩放矩阵是一个对角矩阵,对角线上的值对应缩放倍数 错切(shear) 错切可以将 ...
- CS184.1X 计算机图形学导论(第五讲)
一.观察:正交投影 1.特性:保持平行线在投影后仍然是平行的 2.一个长方体,对处在只有深度不同的位置上的同一物体来说,它的大小不会改变. 3.透视投影:平行线在远处会相交(例如铁轨) 4.glOrt ...
- CS184.1X 计算机图形学导论 HomeWork1
最容易填写的函数就是left.输入为旋转的角度,当前的eye与up这两个三维向量 void Transform::left(float degrees, vec3& eye, vec3& ...
- CS184.1X 计算机图形学导论 罗德里格斯公式推导
罗德里格斯公式推导 图1(复制自wiki) 按照教程里,以图1为例子,设k为旋转轴,v为原始向量. v以k为旋转轴旋转,旋转角度为θ,旋转后的向量为vrot. 首先我们对v进行分解,分解成一个平行于k ...
- CS184.1X 计算机图形学导论L3V2和L3V3(部分)
组合变换 连接矩阵的优点是可以使用这些矩阵单独操作. 多个变换依然是一个矩阵. 连接矩阵不可交换,因为矩阵乘法不具有交换性. X3=RX2 X2=SX1 X3=R(SX1)=(RS)X1 X3≠SRX ...
- CS184.1X 计算机图形学导论 作业0
1.框架下载 在网站上下载了VS2012版本的作业0的框架,由于我的电脑上的VS是2017版的,根据提示安装好C++的版本,并框架的解决方案 重定解决方案目标为2017版本. 点击运行,可以出来界面. ...
- CS184.1X 计算机图形学导论(第三讲)
第一单元(介绍关于变换的数学知识) :基本二维变换 模型坐标系,世界坐标系 1.缩放 Scale(规模,比例) Sx表示在x方向上放大的倍数,Sy表示在y方向上放大的倍数,因此X坐标乘以Sx,Y坐标乘 ...
- MIT算法导论——第四讲.Quicksort
本栏目(Algorithms)下MIT算法导论专题是个人对网易公开课MIT算法导论的学习心得与笔记.所有内容均来自MIT公开课Introduction to Algorithms中Charles E. ...
- 计算机图形学 opengl版本 第三版------胡事民 第四章 图形学中的向量工具
计算机图形学 opengl版本 第三版------胡事民 第四章 图形学中的向量工具 一 基础 1:向量分析和变换 两个工具 可以设计出各种几何对象 点和向量基于坐标系定义 拇指指向z轴正 ...
随机推荐
- SPOJ QTREE - Query on a tree 【树链剖分模板】
题目链接 引用到的大佬博客 代码来自:http://blog.csdn.net/jinglinxiao/article/details/72940746 具体算法讲解来自:http://blog.si ...
- 两个list 合并后去除掉重复removeAll()的,然后再随机获取最后list中的 几个值
public static void test1(){ String s1="1,2,5,3,6,9"; String n1[]=s1.split(","); ...
- 19 如何在String和Byte[]对象之间进行转换?
- CollectionUtils工具类中常用方法
@SuppressWarnings("rawtypes") @Test public void test1() { List<String> coll = new Ar ...
- eclipse 4.5 离线安装mybatis generator1.3.6卡在Install New Software的解决方法
转载:https://blog.csdn.net/ssshen14/article/details/80004459 离线插件 下载:https://github.com/mybatis/genera ...
- [CSP-S模拟测试]:Equation(数学+树状数组)
题目描述 有一棵$n$个点的以$1$为根的树,以及$n$个整数变量$x_i$.树上$i$的父亲是$f_i$,每条边$(i,f_i)$有一个权值$w_i$,表示一个方程$x_i+x_{f_i}=w_i$ ...
- [CSP-S模拟测试]:旋转子段(数学)
题目描述 $ZYL$有$N$张牌编号分别为$1,2,...,N$.他把这$N$张牌打乱排成一排,然后他要做一次旋转使得旋转后固定点尽可能多.如果第$i$个位置的牌的编号为$i$,我们就称之为固定点.旋 ...
- React准备工作
一.环境准备 使用react官方推荐的脚手架create-react-app 1.安装nodejs 2.npm install -g create-react-app //全局安装脚手架 3.cre ...
- python3爬虫开发与实战预览版
https://germey.gitbooks.io/python3webspider/content/1.2.3-ChromeDriver%E7%9A%84%E5%AE%89%E8%A3%85.ht ...
- CDN-template
ylbtech-CDN: 1.返回顶部 2.返回顶部 3.返回顶部 4.返回顶部 5.返回顶部 6.返回顶部 7.返回顶部 8.返回顶部 9.返回顶部 10.返 ...