iOS开发-OpenGL ES入门教程3

教程

OpenGL ES入门教程1-Tutorial01-GLKit
OpenGL ES入门教程2-Tutorial02-shader入门
这次是三维图形变换

OpenGL ES系列教程在这里
OpenGL ES系列教程的代码地址 - 你的star和fork是我的源动力,你的意见能让我走得更远。

效果展示

概念准备

1、计算机图形学

首先了解计算机处理图形的流程,如下图



应用程序把数据以图元的方式提供给图形硬件,一般是点、线、多边形、纹理映射图像;基本图元通过几何变换和投影变换,获得二维屏幕坐标;对每一个屏幕像素点进行着色,得到具体的显示帧。

2、几何处理阶段


以顶点为基础,对几何图元进行处理,把三维坐标转变为二维屏幕坐标的过程。
具体的坐标系变换如下:



MC是建模坐标系,WC是世界坐标系,VC是观察坐标系,PC是投影坐标系,NPC是规格化投影坐标系,DC是设备坐标系。

几何变换

a、基本几何变换

平移变换、比例变换、旋转变换、对称变换、错切变换
具体的变换矩阵可以点这里 或者 这里

b、复合变换

  • 关于任意点的比例、旋转变换

1、将任意点P移到原点,作平移变换;
2、进行比例、旋转等变换;
3、将参考点移到原处;

  • 绕任意轴的旋转变换

这里

投影变换

把三维物体变为二维图形表示的过程成为投影变换。分类如下:


投影中心,也叫投影参考点,相当于人的视点,投影线相当于人的视线。


平行投影

投影中心和投影平面的距离为无穷大的投影。

  • 正平行投影

投影方向垂直于投影平面时称为正平行投影。三视图(主视图、俯视图、侧视图)都属于正平行投影。

  • 斜平行投影

投影方向不垂直于投影平面的平行投影称为斜平行投影。

透视投影

投影中心和投影平面的距离是有限的。
透视投影的推导可以看 这里

OpenGL ES的变换

OpenGL ES通过顶点缓存数组和图元绘制指令,形成基本的图元;图元在顶点着色器会进行顶点变换,也就是几何处理阶段的几何变换和投影变换;到了像素处理阶段,根据之前的结果,通过光照、纹理等对每一个像素点进行着色。
举一个例子,下面的代码用到了透视投影、平移变换、旋转变换。

    KSMatrix4 _projectionMatrix;
    ksMatrixLoadIdentity(&_projectionMatrix);
    float aspect = width / height; //长宽比
    
    
    ksPerspective(&_projectionMatrix, 30.0, aspect, 5.0f, 20.0f); //透视变换,视角30°
    
    //设置glsl里面的投影矩阵
    glUniformMatrix4fv(projectionMatrixSlot, 1, GL_FALSE, (GLfloat*)&_projectionMatrix.m[0][0]);
    
    glEnable(GL_CULL_FACE);
    
    
    KSMatrix4 _modelViewMatrix;
    ksMatrixLoadIdentity(&_modelViewMatrix);
    
    //平移
    ksTranslate(&_modelViewMatrix, 0.5, 0.0, -10.0);
    
    KSMatrix4 _rotationMatrix;
    ksMatrixLoadIdentity(&_rotationMatrix);
    
    //旋转
    ksRotate(&_rotationMatrix, degree, 1.0, 0.0, 0.0); //绕X轴
    ksRotate(&_rotationMatrix, yDegree, 0.0, 1.0, 0.0); //绕Y轴
    
    //把变换矩阵相乘,注意先后顺序
    ksMatrixMultiply(&_modelViewMatrix, &_rotationMatrix, &_modelViewMatrix);

这里插入一点矩阵的基本性质

Paste_Image.png

ksMatrixMultiply(&_modelViewMatrix, &_rotationMatrix, &_modelViewMatrix); 这一行的代码的精髓在于理解rotation和modelView的先后顺序对最后结果的影响。
ksPerspective(&_projectionMatrix, 30.0, aspect, 5.0f, 20.0f);这里需要明白5个参数的意义:result矩阵,视角,长宽比,近平面距离,远平面距离,不明白的可以点这里的透视投影推导
ksTranslate(&_modelViewMatrix, 0.5, 0.0, -10.0);这里是简单的平移变换,后三个参数为x、y、z的距离。
ksRotate(&_modelViewMatrix, degree, 1.0, 0.0, 0.0);这里是旋转变换,后三个参数为旋转轴。

glsl代码

attribute vec4 position;
attribute vec4 positionColor;
uniform mat4 projectionMatrix;
uniform mat4 modelViewMatrix;

varying lowp vec4 varyColor;

void main()
{
    varyColor = positionColor;
    
    vec4 vPos;
    vPos = projectionMatrix * modelViewMatrix * position;
    
//    vPos = position;

    gl_Position = vPos;
}

思考题

  • 透视投影里面有一个视锥体的概念,物体不在视锥体内的部分不可见,OpenGL ES是如何判断一个点是否在视锥体内?
  • 平移变换里面的z参数为何是负数,它的取值范围是多少?
  • ksMatrixMultiply的参数如果颠倒会如何?
  • glsl代码里面的projectionMatrix * modelViewMatrix * position顺序能否交换?要如何交换?

总结

教程2、3是shader的一个分支,内容相对较难,接下的教程主要以GLKit为主。

附上源码地址
代码里面的util在 这里

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,172评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,346评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,788评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,299评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,409评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,467评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,476评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,262评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,699评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,994评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,167评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,827评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,499评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,149评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,387评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,028评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,055评论 2 352

推荐阅读更多精彩内容