从球形绳的制作学习简单三维(下)
作者 佚名技术
来源 服务器技术
浏览
发布时间 2012-07-13
接上一帖的内容 dispbbs.ASP?boardID=49&ID=236734&page=2 C.移动视点 到此为止,我们已经讨论了移动对象本身,现在让我们看一下怎样才能移动整个视图以使得用户的透视图看起来在运动,并且对象保持固定,而不是用户保持固定而对象在移动. 元件:一个40*40的球形,链接名:sphere 在主场景第一帧代码如下: //xoff,yoff,zoff用来确定我们观察者所处的位置. xoff=0; yoff=0; zoff=0; d=1000; centerX=275; centerY=200; ang=0; function project() { if((this.z-zoff)<40) { this._visible=false; } else { this._visible=true; var zfactor=d/(this.z-zoff); this._x=(this.x-xoff)*zfactor+centerX;//在上一个效果中公式中少了一个xoff,因为现在的球位置都是相对于观察者的. this._y=(this.y-yoff)*zfactor+centerY; this._xscale=100*zfactor; this._yscale=100*zfactor; this.swapDepths(Math.floor(100000-(this.z-zoff)));//让近的球摆在上面. } } //接下来用于生成小球.... for(var i=0;i<40;i++) { var nm="sphere"+i; _root.attachMovie("sphere",nm,i); _root[nm].x=Math.cos(ang)*200; ang+=0.2; _root[nm].y=100+Math.cos(i/3)*100; _root[nm].z=(i*50)+d; _root[nm].project=project; _root[nm].onEnterFrame=project; } //建一个侦听器,侦听鼠标的活动. mouseListener=new Object(); mouseListener.onMouseWheel=function(diff) { zoff+=(diff*50) } mouseListener.onMouseMove=function() { xoff=_xmouse-centerX; yoff=_ymouse-centerY; } Mouse.addListener(mouseListener); 关键词: |
凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢! |
你可能对下面的文章感兴趣
上一篇: MOHO教程+动物的运动下一篇: 一个斜仰视角的绘法
关于从球形绳的制作学习简单三维(下)的所有评论