已阅读5页,还剩10页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
基于HTML5的动态数据3D网页的需求规格说明书 Canvas sphere Sphere = (function() var canvas;var ctx;var offsetX = 300;var offsetY = 300;var objectsInScene = new Array();var focalLength = 300;var cameraView = x:0, y:0, z:0, rotX:0, rotY:0, rotZ:0;var space = 15;var PI = Math.PI;var radius = 200;var radian = PI/180;var mouseX = 0;var mouseY = 0;var objectRadius = 14;var scaleRatio = 0;var scaling = true;var nrOfFollowers = 32;var followRadius = 8;var minDistToLeader = 20;var sx = 0;var cx = 0;var sy = 0;var cy = 0;var sz = 0;var cz = 0;return function() this.createSphere = function() canvas = document.getElementById(sphere);ctx = canvas.getContext(2d);if (canvas.getContext) this.init();this.init = function() / create sphere objects:for (var i=space; i180; i+=space) for (var angle=0; angle360; angle+=space) var object = ;var x = Math.sin(radian*i)*radius;object.x = Math.cos(angle*radian)*x;object.y = Math.cos(radian*i)*radius;object.z = Math.sin(angle*radian)*x;object.glow = .5;object.type = sphere;objectsInScene.push(object);/ create followers:for(var i=0; i .5) object.glow -= .02;var radgrad = ctx.createRadialGradient(offsetX+object.x*scaleRatio, offsetY+object.y*scaleRatio, scale*.5, offsetX+object.x*scaleRatio, offsetY+object.y*scaleRatio, scale*objectRadius*.5);radgrad.addColorStop(0, #8484d7);radgrad.addColorStop(object.glow, #00008f);radgrad.addColorStop(1, rgba(0,0,143,0);ctx.fillStyle = radgrad;ctx.fillRect(offsetX+object.x*scaleRatio-scale*objectRadius*.5, offsetY+object.y*scaleRatio-scale*objectRadius*.5, scale*objectRadius, scale*objectRadius);/ display a follow object:this.displayFollower = function(object) / calculate distance to leadervar distx = object.x - object.leader.x;var disty = object.y - object.leader.y;var distz = object.z - object.leader.z;/ recalculate momentumobject.momentumx -= Math.min(50, distx) / 100;object.momentumy -= Math.min(50, disty) / 100;object.momentumz -= Math.min(50, distz) / 100;/ dampen the momentum a littleobject.momentumx *= 0.85;object.momentumy *= 0.85;object.momentumz *= 0.85;/ change positionobject.x += object.momentumx;object.y += object.momentumy;object.z += object.momentumz;/ render to screenscaleRatio = focalLength/(focalLength + object.z);switch(scaling) case true:scale = scaleRatio;break;case false:scale = 1;break;var radgrad = ctx.createRadialGradient(offsetX+object.x*scaleRatio, offsetY+object.y*scaleRatio, scale*.5, offsetX+object.x*scaleRatio, offsetY+object.y*scaleRatio, scale*followRadius*.5);radgrad.addColorStop(0, #3f3f57);radgrad.addColorStop(0.5, #3f3f57);radgrad.addColorStop(1, rgba(60,60,90,0);ctx.fillStyle = radgrad;ctx.fillRect(offsetX+object.x*scaleRatio-scale*followRadius*.5, offsetY+object.y*scaleRatio-scale*followRadius*.5, scale*followRadius, scale*followRadius);/ assign new leader when coming to close the current leader:if(distxminDistToLeader & distyminDistToLeader & distzminDistToLeader) object.l
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 中小学研学旅行课程方案
- 有理数及其运算知识点
- 中学-学年度工作总结
- 个人下半年工作总结
- 社交媒体中电子口碑对消费者行为影响的差异性研究
- 三年级下学期班务工作计划
- 一年级老师工作总结
- 《在课堂中培养学生倾听能力的研究》课题组工作总结
- 四川省绵阳市三台县2023届九年级下学期中考二模数学试卷(含解析)
- 陕西公务员考试(行政职业能力测验)模拟试卷47
- 肺动脉闭锁护理课件
- 防腐木维修施工方案
- C语言程序设计-第5章-循环结构
- 座板式单人吊具悬吊作业安全技术规范
- 房屋修建补充协议
- 《男生女生》主题班会课件市公开课获奖课件省名师优质课赛课一等奖课件
- 相交线教案市名师优质课比赛一等奖市公开课获奖课件
- 初中数学分层次教学方法与策略研究-课题材料-立项申报书
- 蓄水池检验批质量验收记录(海绵城市质检表格)
- 模板方案危大工程一级交底记录
- 急性髓系白血病诊疗指南课件
评论
0/150
提交评论