理解Op en GL 拾取模式(Op en GL Pick in g) 在用OpenGL 进行图形编程的时候,通常要用鼠标进行交互操作,比如用鼠标点选择画面中的物体,我们称之为拾取(Picking),在网上看了很多OpenGL 拾取的文章,但大多是只是介绍在OpenGL 中如何拾取,如何利用OpenGL 提供的一系列函数来完成拾取,最多再简单介绍下OpenGL 的名字栈(Name stack),拾取矩阵(Picking Matrix)等等,但是拾取真正的原理确没有提到
所以,我在这里为大家详细介绍下OpenGL 中拾取是怎样实现的,以及其背后的真正原理
OpenGL 中的拾取是对 OpenGL 图形管线的一个应用
所以 OpenGL 中的拾取并不是像D3D 一样采用射线交叉测试来判断是否选中一个目标,而是在图形管线的投影变换(Projection Transformation)阶段利用拾取矩阵来实现的
为了理解这个过程,先来复习一下OpenGL 的图形管线
总的来说,OpenGL 图形管线大体分为上面的五个阶段
在编程的时候使用glMatrixMode(GL_MODELVIEW),或者 glMatrixMode(GL_PROJECTION)就是告诉OpenGL 我们是要在那个阶段进行操作
先来看看投影变换,因为理解投影变换是理解OpenGL 拾取的前提条件
为了简单起见,这里以正交投影(Orthogonal Projection)为例
在OpenGL 中,使用正交投影可以调用glOrtho (left, right, bottom, top, zNear, zFar),其中的六个参数分别对应正交投影视体的六个平面到观察坐标系原点的距离
一旦在程序中调用了这个函数,OpenGL 会马上创建根据给定的六个参数创建一个视体,并且把视体的大小归一化到-1 到1 之间,也就是说,