Other articles


  1. Three.js赛车游戏

    赛车坐标系

    先不讨论场景和光线的配置,光是赛车本身涉及到的一些座标变换就足够复杂的了。先假设汽车模型摆放在坐标轴中心,如下图所示:

    Car icon

    一般情况下坐标系为右手系表示,即图中的红,绿,蓝分别代表x,y,z轴。假设汽车要向前移动的话,那么车身和车轮都需要沿着坐标系z轴作平移变换,同时前轮需要绕着前轮车轴为中心沿着x轴方向旋转变换。直白地说,就是车子在往前走的时候轮子也需要滚动。

    直行时的情况比较简单,但是如果需要旋转就比较麻烦了。先来考虑真实的情况,轮子在转动的时候不是一下子就旋转到位的,而是有个缓慢转动的过程,在转动的过程中车身也一直在前进。我们需要记录下来车身此时面对的方向以及轮子此时面对的方向。我们需要将坐标系拆分成两个部分,一个是车子和整个场景所在的世界坐标系,一个是以车子自身位中心的单位坐标系。我们需要在单位坐标系下对轮子做相对于车身的座标变换,在世界坐标系下更新车子当前的座标和面对的方向。

    前期准备

    实际上上面的内容Three.js里面的例子已经有现成的代码了,之前还花了好多时间研究诸如cannon.js,Physijs等等JavaSript物理引擎,出来的结果不是车子不停的打转就是动弹不得。还是先考虑没有物理引擎的情况吧。

    Car.js的文件可以在Three.js的github源码中找到,在example目录下的js文件夹里面。也可以在我的github里面这个demo的代码中找到,但是我稍微修改了一下里面的参数。

    首先我们需要将Three.js库以及Car.js添加到源文件当中

    <script src='js/libs/three …
    read more

    There are comments.

  2. 用WebGL编写一个3D图形网站

    自己的学生生涯也差不多结束了,感觉是时候把自己这一年来学的东西做一个总结,顺便回顾一下以前做过的东西。这几天多动动手,争取写多一些内容。

    WebGL简单介绍

    如果有听说过OpenGL的话,那么WebGL理解起来就不是那么困难了,简单来说其实就是OpenGL在HTML5的JavaScript移植版。要是OpenGL没听说过,那就把它当成是一个在网页上的图形引擎吧。我们可以在HTML5的网页上创建Canvas(画布)来配置我们的WebGL绘制图形的过程。

    要想从最基本的开始写一个很简单的程序也不是那么容易的,写过OpenGL程序的人肯定都知道,想要显示一个简单的正方形也不是一句代码就能解决的事。你得设置好视角,然后你得定义绘图方式,标出矩形每一个顶点的位置,再转换到世界坐标系等等。总之就是一切都是计算机图形学基础的东西,要想好好用WebGL这个写一个能看的动画估计就得花好长时间了。所以我们还是用点现成的东西吧,目前关于WebGL可用的库有很多,比较常用的就是Three.js。

    Three.js

    这个库已经写的比较完整了,已经有很多很炫的例子,可以在官网上找到。有了Three.js,很多事情变简单了许多。绘制一个3D画面的步骤就变成这样了:

    1. 在HTML网页里配置基本的画布
    2. 在画布上布置WebGL基本元素,比如立方体,球体等等
    3. 配置好Camera,加入光源,着色器等等
    4. 如果需要的话,加入对输入设备的检测,比如鼠标的点击动作
    5. 最后就是加入一个计时器不断地刷新页面,比如动态显示水面的波纹 …
    read more

    There are comments.

links

social