如何用 JS 实现 3D 赛车效果
本文将分享如何用 JS 写出一个 3D 赛车,我之前曾在技术交流会上也讲过一次(这里是当时用的 PPT),后来有同学反馈说讲得太深奥没听懂。其实 PPT 里说的更多的是三维图形的基础知识,实现原理体现的稍微少一些,那么本文将着重从实现原理这块做一些补充。
先看赛车的示例:http://ucren.com/racing/,还是半成品状态,很多功能没有实现,不过目前也没有后续的开发计划。
准备工作:
1) 图片素材:图片素材是每一个网页游戏必不可少的,本游戏中素材涉及到白云、远山、N 棵不同的树、小车、时速表盘、时速表针以及其它一些背景图片等。为了实现延伸,这里的白云及远山等图片素材一定要做成首尾相接看起来平滑的,中间不能出现交界痕迹,这样的图片可以从网上找到素材,再用 PhotoShop 进行处理。
2) 矢量绘图库:矢量绘画部分没有必要自己从头写起,我们应该将关注点放在游戏的业务逻辑部分,可以从网上找个自己用得顺手的基础库,比如 excanvas、Raphael 等,如果不考虑浏览器兼容的话,也可以使用 HTML5 提供的
实现原理:
实际上赛车的实现过程中考虑了很多细节的问题,由于篇幅有限,这里只挑一些重点的来介绍。
1) 白云及远山:这两个都是
2) 路面:路面最重要的构成是两条贝赛尔曲线,贝塞尔曲线有几个重要的参数――起点、控制点一、控制点二和终点,这样的四个点即构成一条贝赛尔曲线。SVGPath 里的 C 指令可以完成贝塞尔曲线的绘制。路面变换弯度是如何实现的呢?幸好 vml/svg 节点的 path 属性是允许动态改变的,可以通过改变它的 path 来完成弯度的变化,这点 Raphael 库提供了很大的便利。如果是
3) 树木:本游戏中树木是由 6 张图片随机产生的,它们由远及近地运动来向玩家表达车子向前跑的状态,运动是通过不断改变树木的坐标和大小实现的,这里的坐标由路沿的两条贝塞尔曲线来确定。树木的运动有三个特点:a、离观察者越远的树越小,所以运动使树木不断变大,同时也使相邻树木的间距变大;b、由于前面的过程,树木的 y 坐标(top 值)不一定在逐渐增大,有时反而在减小;c、离观察者近的树,层次要位于离得远的树之上。
4) 车子:车子是由一张集合了 13 个可能出现的方向的图片组合而成(见上述图片素材部分),你可能会奇怪这样的图片怎么制作,其实很简单,我是拿 3dsmax 软件做成的,从网上找了一个 3d 车子模型,用 3dsmax 软件改改样子,并导出不同方向的图片,最终用 PhotoShop 合成。在网页上,用这张图片做为一个
5) 时速表:时速表由表盘和表针组成,表盘是静止的,表针是可以转动的。转动的原理是改变表针的 rotate 属性,这点在 Raphael 库也有也对应的方法实现,参见 Raphael 文档中的 rotate 方法。为了更加逼真,指针加入了抖动策略,具体为:如果车子处于匀速状态下,指针将在当前速度附近抖动,你可以将车子开满 180km/h 看看效果。
6) 速度:这是本游戏中最重要的参数之一,本游戏中将速度量化为 0-1,1 为满速,0 为静止不动。速度参数将决定网页上很多物件的移动:除了车子上述复杂过程外,还有白云和远山的位移速度、路面改变弯道的快慢程度、树木运动的快慢、时速表指针旋转的角度等。
关于实现原理就介绍到这里,下面说说我原来的一些想法:
后续可以做的:
1) 小地图:使路况与小地图结合起来,模拟真实世界。
2) 起点和终点:这是一个赛车游戏必备的。
3) 耗油:起跑时,油箱是满的,在车子跑动过程中,结合速度、路况、玩家控制、阻力等因素来消耗汽油,在到达终点之前油用完就 Game Over,考验玩家的驾驶水平。
4) 敌车:路上不可能只有一个车子嘛。
5) 复杂路况:可以用草丛、沙地、小石头、水坑等物体来复杂化路况,增加游戏的难度和趣味性。
6) 路边风景:结合小地图,可以在路边实现一些河流、建筑物等,纯树木还是很单调的。
by huangzhilong
建议继续学习:
- 翻转吧,界面!-3D UI概述 (阅读:2470)
- JS 3D 模型 (阅读:2242)
- 玩的就是速度-AI的3D效果 (阅读:2208)
- 在 Unity3D 的 Mono 虚拟机中嵌入 Lua 的一个方案 (阅读:1108)
- 创造流动的瞬间—探讨移动端交互动效设计 (阅读:1029)
扫一扫订阅我的微信号:IT技术博客大学习
- 作者:editor 来源: 搜索研发部官方博客
- 标签: 3D 赛车
- 发布时间:2011-11-06 22:30:41
- [51] WEB系统需要关注的一些点
- [49] Go Reflect 性能
- [48] Oracle MTS模式下 进程地址与会话信
- [46] IOS安全–浅谈关于IOS加固的几种方法
- [45] android 开发入门
- [45] Twitter/微博客的学习摘要
- [45] find命令的一点注意事项
- [44] 图书馆的世界纪录
- [44] 如何拿下简短的域名
- [44] 【社会化设计】自我(self)部分――欢迎区