版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
但千万不要陷入到思维定式中。因为解决这些特殊渲染需求,并没有固定的路径或方法,它是一个需要迭代优化的过程,需要我们对WeGL的渲染机制非常了解,并深入思考,才能创造出最适合的方法来。在我们实际的工作里,还有许多其他的方法可以使用,你一定要根据自己的实际情况随机应变。如果我们要实现这些静态的标准点,方法其实很简单,用Canvas2D或者WeGL都可以轻松实现。就算点数量比较多也没关系,因为渲染对性能影响也不会很大。不过,如果我们想让圆点运动起来,比如,做出一种闪烁或者呼吸灯的效果,那我们就要考虑点的数量对性能的影响了。那面对这一类特殊的渲染的需求,我们该怎么办呢?下面,我们先用常规的做法来实现,然后在这个方法上不断迭代优化。为了方便你理解,我就不绘制地图了,只绘制这些随机的小圆点。constcanvas constrenderer=new3constvertex=attributevec2uniformvec2uniformfloatuniformfloat9voidmain()vec3pos=vec3(a_vertexPosition,floatscale=0.7+0.3*sin(6.28*bias+0.003*mat3m=scale,0,0,scale,xy, gl_Position=vec4(m*pos, 20constfragment=#ifdefprecisionhighp uniformvec4voidmain()gl_FragColor= 32constprogram pileSync(fragment,functioncircle(radius=0.05)constdelta=2*Math.PI/constpositions=constcells=for(leti=0;i<32;i++)constangle=i*positions.push([radius*Math.sin(angle),radius*if(i>0&&i<31)cells.push([0,i,i+ return{positions,48constCOUNT=functioninit()constmeshData=const{positions,cells}=for(leti=0;i<COUNT;i++)constx=2*Math.random()-consty=2*Math.random()-constrotation=2*Math.PI*constuniforms=uniforms.u_color=uniforms.xy=2*Math.random()-2*Math.random()- uniforms.bias= renderer.uniforms.uTime=81functionupdate(t)renderer.uniforms.uTime=8890上面的代码非常简单,关键思路就是用circle生成顶点信息,然后对每个需要绘制的圆应用circle顶点信息,并设置不同的unifom参数,最后在shader中根据参数进行绘制就不过如果我们这么做的话,整体的性能就会非常低,比如在绘制500个圆的时候,浏览器的帧率就掉到十几fps了。那我们该怎么优化呢?在学完Canvas和WebGL的性能优化之后,我们知道,在绘制大量同种几何图形的时代代123456789constcanvasconstrenderer=newconstvertex=attributevec2a_vertexPosition;attributevec4color;attributevec2xy;attributefloatbias;uniformfloatuTime;varyingvec4voidmain()vec3pos=vec3(a_vertexPosition,floatscale=0.7+0.3*sin(6.28*bias+0.003*mat3mmat3(scale,0,0,scale,xy,vColor=gl_Position=vec4(m*pos,24}constfragment=#ifdefprecisionhighp varyingvec4voidmain()gl_FragColor= 37constprogram pileSync(fragment,functioncircle(radius=0.05)constdelta=2*Math.PI/constpositions=constcells=for(leti=0;i<32;i++)constangle=i*positions.push([radius*Math.sin(angle),radius*if(i>0&&i<31)cells.push([0,i,i+ return{positions,53constCOUNT=functioninit()const{positions,cells}=constcolors=constpos=constbias=for(leti=0;i<COUNT;i++)constx=2*Math.random()-consty=2*Math.random()-constrotation=2*Math.PI*1 2*Math.random()-2*Math.random()- renderer.uniforms.uTime=instanceCount:attributes:color:{data:[...colors],divisor:xy:{data:[...pos],divisor:bias:{data:[...bias],divisor: 9495functionupdate(t)renderer.uniforms.uTime=101103uniformattribute染100000个点,浏览器的帧率也能达到30fps以上,性能提升了超过2000倍!JavaScriptWebGL20000绘制规则的图形,我们还可以使用点图元。还记得吗?我们WebGL的基本图元包括点、线、三角形等等。前面我们绘制圆的时候,都是用re函数生成三角网格,然后通过三角形绘制的。这样,我们绘制一个圆需要许多顶点。但实际上,这种简单的图形,我们还可以直接采用点图元。在WebGL中,点图元是最简单的图元,它用来显示画布上的点。在顶点器里,我们可以设置gl_PointSize来改变点图元的大小,所以我们就可以用点图元来表示一个矩形。代代12345constcanvasconstrenderer=newconstvertex=attributevec266789uniformvec2voidmain()gl_PointSize=0.2*uResolution.x;gl_Position=vec4(a_vertexPosition,1,1);}constfragment=`#ifdefGL_ESprecisionhighpfloat;voidmain()gl_FragColor=vec4(0,0,1,}constprogrampileSync(fragment,renderer.uniforms.uResolution=[canvas.width,canvas.height];mode:renderer.gl.POINTS,positions:[[0,0]],如上面代码所示,meshDaa的moe设为l.POITS,只绘制一个点(0,0)。在顶点器中,我们通过l_Pointize来设置顶点的大小。由于l_Pointize的单位是像素,所以我们需要传一个画布宽高uResoluion进去,然后将lPosiion设为0.2*esolion,这就让这个点的大小设为画布的20%,最终在画布上就呈现出一个蓝色矩形。注意,这里你可以回顾一下之前我们采用的常规的方法绘制的矩形,我们是将矩形剖分为两个三角形,然后用填充三角形来绘制的。而这里,我们用点图元,好处是我们只需要一个顶点就可以绘制,而不需要用四个顶点、两个三角形来填充。gl_PointSize代1234567代123456789attributevec2uniformvec2uResolution;varyingvec2vResolution;varyingvec2vPos;voidmain()gl_PointSize=0.2*uResolution.x;vResolution=uResolution;vPos=gl_Position=vec4(a_vertexPosition,1,}代代123456789#ifdefGL_ESprecisionhighpfloat;varyingvec2vResolution;varyingvec2vPos;voidmain()vec2st=gl_FragCoord.xy/vResolution;st=2.0*st-1.0;floatd=distance(st,d=1.0-smoothstep(0.195,0.2,d);gl_FragColor=d*vec4(0,0,1,1);}经过前面课程的学习,你应该对造型函数的实现原理比较熟悉了,这里我们就是通过计算到圆心的距离得出距离场,然后通过smoohsep将一定距离内的图形绘制出来,这样就得到一个蓝色的圆。constcanvas constrenderer=new3constvertex=attributevec2attributevec47attributefloat89uniformfloatuniformvec2varyingvec4varyingvec2varyingvec2varyingfloatvoidmain()floatscale=0.7+0.3*sin(6.28*bias+*gl_PointSize=0.05*uResolution.x*vColor=vPos=vResolution=vScale=gl_Position=vec4(a_vertexPosition,1,}constfragment=#ifdefprecisionhighpvaryingvec4varyingvec2varyingvec2varyingfloatvoidmain()vec2st=gl_FragCoord.xy/st=2.0*st-floatd=step(distance(vPos,st),0.05*gl_FragColor=d*}45constprogram pileSync(fragment,constCOUNT=functioninit()88
constcolors=[];constpos=[];constbias=[];for(leti=0;i<COUNT;{constx=2*Math.random()-1;consty=2*Math.random()-1;constrotation=2*Math.PI*colors.push([Ma2*Math.random()-2*Math.random()-}renderer.uniforms.uTime=renderer.uniforms.uResolution=[canvas.width,renderer.setMeshData({mode:enableBlend:true,positions:pos,attributes:{color:{data:bias:{data:89functionupdate(t)renderer.uniforms.uTime=9698可以看到,我们没有采用前面那样通过circle函数来生成圆的顶点数据,而是直接使用gl.POINTS来绘制,并在器中用距离场和造型函数来画圆。这么做之后,我们大大减少了顶点的运算,原先我们每绘制一个圆,需要32个顶点、30个三角形,而现在用一个点就解决了问题。这样一来,就算我们要渲染200000个点,帧率也可以保持在50fps以上,这里举上面的这个例子,主要是想说明一个问题:即使是使用WebGL,不同的渲染方式,性能的差别也会很大,甚至会达到数千倍的差别。因此,在可视化业务中,要学会根据不同的应用场景来有针对性地进行优化。说起来简单,要做到这一点并不容易,你需要对WeGL本身非常熟悉,而且对于GPU的使用、渲染管线等基本原理有着比较深刻的理解。这不是一朝一夕可以做到的,需要持续不断地学习和积累。就像有些同学使用绘图库ThreeJS或者SrieJS来绘图的时候,做出来的应用性能很差,就会怀疑是图形库本身的问题。实际上,这些问题很可能不是库本身的问题,而是我们使用方法上的问题。换句话说,是我们使用的绘图方式并不是最适用于当前的业务场景。而ThreeJS、SrieJS这些通用的绘图库,也并不会自己针对特定场景来优化。原因,我没有把这门课程的重点放在库的API的使用上,而是深入到图形渲染的底层原针对场景的性能优化方法其实非常多,我刚才讲的也只是几种典型的情况。为了帮助你在实战中慢慢领悟,我再举几个例子。不过我要提前说一下,我不会具体去讲这些例子的代码,只会重点强调常用的思路。学会这些方法之后,你再在实践中慢慢应用和体会就会容易很多了。我们已经学习过使用后期处理通道的基本方法。实际上,后期处理通道十分强大,它最重要的特性就是可以把各种数据在纹理中。这样在迭代处理的时候,我们就可以用GPU将这些数据并行地和处理,从而达到非常高效地渲染。这里是一个OGL官网上例子,它就是用后期处理通道实现了粒子流的效果。这样的效果,在其他图形系统中,或者WebGL不使用后期处理通道是不可能做到的。纹理中,然后利用GPU
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年度注塑机设备转让及市场占有率提升合同样本4篇
- 2025年度材料安全评价及风险评估合同范本3篇
- 2025年度新能源项目土地租赁经营合同范本4篇
- 2025年度生态环保型安置房建设一体化服务合同3篇
- 2024版海鲜采购合同
- 2025年度外墙艺术装饰工程承揽合同4篇
- 2024维修公司环保设备维修人员劳动合同范本3篇
- 2024跨国物流仓储服务全面合作框架协议
- 2025年度物流企业绿色包装材料采购合同4篇
- 2025年度临时设施搭建与场地租赁合同3篇
- 2024版塑料购销合同范本买卖
- 【高一上】【期末话收获 家校话未来】期末家长会
- JJF 2184-2025电子计价秤型式评价大纲(试行)
- GB/T 44890-2024行政许可工作规范
- 有毒有害气体岗位操作规程(3篇)
- 儿童常见呼吸系统疾病免疫调节剂合理使用专家共识2024(全文)
- 2025届山东省德州市物理高三第一学期期末调研模拟试题含解析
- 《华润集团全面预算管理案例研究》
- 2024-2025高考英语全国卷分类汇编之完型填空(含答案及解析)
- 二年级下册加减混合竖式练习360题附答案
- 苏教版五年级数学下册解方程五种类型50题
评论
0/150
提交评论