[WebGL入门]十二,模型数据和顶点属性

翻译 2014年08月06日 22:20:09

注:文章译自http://wgld.org/,原作者杉本雅広(doxas),文章中如果有我的额外说明,我会加上[lufy:],另外,鄙人webgl研究还不够深入,一些专业词语,如果翻译有误,欢迎大家指正。


顶点属性的意思

上次的文章中,介绍了一下从着色器的生成,编译,到程序对象的生成和着色器的连接。这次,简单的说一下模型数据的定义和顶点属性的处理。另外,介绍一下根据模型数据生成VBO的方法。
VBO的使用要比生成难理解一些,但是不要担心,后面会慢慢说明。
接下来看一下顶点属性。
顶点属性,说的简单点,就是顶点包含的各种元素。WebGL中,顶点至少要包含的元素是位置情报,这个之前已经说过很多遍了。
顶点是三维空间中的任意一个点,所以一定要有位置情报,如果没有位置情报,则无法在三维空间中定义这个点,因为每个点都不一样,所以位置情报是必须的。lufy:感觉好罗嗦啊,作者是为了强调吧,可是真的好罗嗦啊,好罗嗦啊,啰嗦啊,嗦啊,啊.....
但是,顶点里还有可能包含其他属性,举个例子来说的话,比如顶点的颜色等等。根据顶点的颜色属性,来对多边形进行着色,或者透明等各种各样的处理。
另外的,还有顶点的法线,纹理坐标等相关的情报,这些都可以在顶点属性中自由的定义。DirectX中根据所谓的顶点格式来实现这些,但是在WebGL中顶点的各种属性都可以定义在顶点属性中。

顶点属性和VBO

既然顶点属性是可以自由定义的,那么具体应该如何来实现呢?
看过以前的文章的话,应该知道顶点属性的个数和生成VBO的个数是一致的,如果顶点中有三个属性,那么就需要三个VBO,因为顶点属性必须通过VBO来传给顶点着色器。VBO也叫做顶点缓存,和它的名字一样,就是将顶点相关的情报缓存起来。顶点属性和VBO一对一进行分配,然后传给顶点着色器。
为了生成VBO,首先准备好和顶点个数相对应的矩阵,这里用的就是普通的javascript数组,当然Array对象也可以,但是不可以使用关联数组,要使用一维数组。
举个例子,由三个顶点定义多边形的时候,写成下面这样。

>保存模型数据的数组的例子

var vertex_position = [
    // X,   Y,   Z
     0.0, 1.0, 0.0,
     1.0, 0.0, 0.0,
    -1.0, 0.0, 0.0
];
为了让大家看的更容易些,中间加了换行,可以看到这是一个一维数组,包含有9个元素,三个顶点都分别包含了X,Y,Z的坐标,顶点数x要素的数,就是3x3=9,所以数组中元素的个数是9。

VBO的生成

用矩阵准备好顶点数据之后,就可以使用这个矩阵来生成VBO了,生成VBO的时候使用WebGL的createBuffer函数,这个函数就是用来生成缓存的。但是这个函数并不是用来直接生成VBO的,它只是生成了一个缓存对象,根据它里面保存的内容不同,用途也是不用的。
要操作缓存,首先必须跟WebGL进行绑定,就是说,要向“缓存”这个“光盘”中写入数据的时候,必须连接到WebGL这个“光驱”上。
绑定了缓存之后,使用bufferData函数来向缓存中写入数据,把这些处理写成一个函数,就是下面这样。

>生成VBO的函数

function create_vbo(data){
    // 生成缓存对象
    var vbo = gl.createBuffer();
    
    // 绑定缓存
    gl.bindBuffer(gl.ARRAY_BUFFER, vbo);
    
    // 向缓存中写入数据
    gl.bufferData(gl.ARRAY_BUFFER, new Float32Array(data), gl.STATIC_DRAW);
    
    // 将绑定的缓存设为无效
    gl.bindBuffer(gl.ARRAY_BUFFER, null);
    
    // 返回生成的VBO
    return vbo;
}
这个函数,接受一个矩阵作为参数,最后返回生成的VBO。首先使用createBuffer生成缓存对象,接着绑定缓存,然后写入数据。
绑定缓存的时候使用bindBuffer函数,这个函数有两个参数,第一个参数是缓存的类型,第二个参数是指定缓存对象。将第一个参数指定为gl.ARRAY_BUFFER就可以生成VBO。
另外,bufferData函数的第二个参数中出现的Float32Array对象,是javascript的类型数组,和一般的Array对象类似,是处理浮点型小数的时候使用的数组对象。3D世界里小数的精确度非常重要,所以使用类型数组来传递数据。而第三个参数中的gl.STATIC_DRAW这个常量,定义了这个缓存中内容的更新频率。VBO的话,模型数据基本上就是直接这么反复用,所以使用这个常量。
可以绑定WebGL的缓存,一次只能绑定一个,所以要操作其他的缓存的时候,必须要绑定相应的缓存。所以在函数的最后,再次使用bindBuffer函数,设定第二个参数为null,来将上次的绑定无效化,这是为了防止WebGL中的缓存一致保留,而出现和预想不一致的情况。

总结

顶点中的属性是由程序员来自由添加的,需要的VBO的个数就是添加的属性个数。
顶点属性的各个数据,使用纯粹的一维数组,当然,数组的元素个数要根据想要绘制的顶点个数来定义。
生成VBO的时候,首先要把缓存绑定到WebGL,然后相应的数据,要转换为相应的类型,然后使用指定的常量来写入数据。而为了避免预想之外的错误发生,数据写入结束之后,要将WebGL中绑定的缓存无效化。
这样,一连串的处理之后,模型数据就可以被顶点着色器利用了。下一回以后,说一下将VBO传给着色器的步骤,首先先把VBO的准备部分好好理解一下吧。


下次,说一下如何准备坐标变换矩阵。


转载请注明:转自lufy_legend的博客http://blog.csdn.net/lufy_legend

三、WebGL入门,顶点缓冲区

我们在接下来的学习中,我们主要会了解到一下一些知识点: 顶点缓冲区索引缓冲区纹理帧缓冲深度缓冲颜色缓冲模型缓冲 模型矩阵观察矩阵投影矩阵视口 本节先介绍顶点缓冲区 顶点缓冲区的使用步...
  • a23366192007
  • a23366192007
  • 2016年01月17日 21:12
  • 1879

osg demo20 输出模型所有结点

//DEMO20 //功能:输出模型所有的顶点 #include #include #include #include #include #include //定义一个定点访问的no...
  • u013186536
  • u013186536
  • 2014年01月02日 14:39
  • 1434

[WebGL入门]十二,模型数据和顶点属性

顶点中的属性是由程序员来自由添加的,需要的VBO的个数就是添加的属性个数。 顶点属性的各个数据,使用纯粹的一维数组,当然,数组的元素个数要根据想要绘制的顶点个数来定义。 生成VBO的时候,首先要把缓存...
  • lufy_Legend
  • lufy_Legend
  • 2014年08月06日 22:20
  • 8359

CATIA一些技巧----------转自水木清华

1.螺母的几种画法 ⑴先画好六棱柱,然后用小三角形旋转切除。⑵先画圆柱,然后将圆柱上下底面边缘倒角,再用六边形拉伸向外切除。 2. 三维零件建模时的命名 零件建模时,系统会自动在其模型树的开头为零件命...
  • cc_sky
  • cc_sky
  • 2004年12月26日 21:58
  • 2996

WebGL入门教程第1篇——六色立方

介绍了WebGL的基础知识,并实战绘制立方体
  • u013874236
  • u013874236
  • 2014年04月15日 20:39
  • 5364

unity webgl 初学者1

1。安装webgl环境 2。直接打包 选择分辨率与导出Canvas 模式; 屏幕自适应请参照http://blog.sina.com.cn/s/blog_b54e5f1d0102wa45...
  • hjt13201
  • hjt13201
  • 2017年09月29日 15:18
  • 396

怎么导出三维模型文件stl?

用三维建模软件(如ug,proe,solidworks,catia)进行建模,最后另存为.stl格式就可以了。 STL是用三角网格来表现3D CAD模型。 STL只能用来表示封闭的面或者体,st...
  • wide288
  • wide288
  • 2014年01月26日 10:00
  • 14117

基于OpenGL 的STL 文件可视化研究

基于OpenGL 的STL 文件可视化研究 1.引言 目前,CAD 系统在三维建模上具有优秀强大的功能,但在功能梯度材料零件建模、3D模型数据处理等专业领域为了达到特定的目标,往往需要对CAD 软...
  • Cracent
  • Cracent
  • 2016年04月03日 10:43
  • 2755

WebGL数据制作流程及加载

作者:翔翔 随着科技的不断进步和客户需求不断提高,无插件客户端WebGL已慢慢成为主流。那么WebGL的数据如何制作?如何加载数据?接下来我会为大家一一解开这些迷惑。下面我将介绍WebGL的数据制作和...
  • supermapsupport
  • supermapsupport
  • 2016年12月09日 09:51
  • 3264

[WebGL入门]六,顶点和多边形

顶点就是至少包含了坐标情报的三维空间上的任意的一个点,三个点用线连接起来,表现为一个三角形的多边形。而多边形根据顶点的连接顺序不同,分为内侧和外侧,根据这个可以进行遮挡剔除。 接下来,实际进行渲染的时...
  • lufy_Legend
  • lufy_Legend
  • 2014年08月01日 01:40
  • 9662
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:[WebGL入门]十二,模型数据和顶点属性
举报原因:
原因补充:

(最多只允许输入30个字)