`
xhload3d
  • 浏览: 208313 次
社区版块
存档分类
最新评论

基于HTML5 Canvas的工控SCADA模拟飞机飞行

阅读更多

昨天看到一篇文章说是学习如何开飞机的,然后我就想,如果我也可以开飞机那就好玩了,每个人小时候都想做飞行员!中国飞行员太难当了,再说也不轻易让你开飞机!后来我就想如果能用 HT 开飞机那就是真的有趣了,哈哈,这个实现的效果还是很不错的,可以让你满足一下开飞机的虚荣心偷笑

Demo 地址: http://hightopo.com/guide/guide/plugin/obj/examples/example_path.html

来看下具体实现的效果:

这个例子基本上完全模拟了飞机的飞行模式,包括起飞跑道,包括飞机的移动路径,螺旋桨的旋转,机尾的指示灯等部分。

首先,最重要的是我们的飞机模型,前面有文章写到过,HT 内部封装了一个方法 ht.Default.loadObj 来加载 OBJ 文件:

ht.Default.loadObj('obj/plane.obj', 'obj/plane.mtl', {                    
    center: true,
    r3: [0, -Math.PI/2, 0], // make plane face right
    s3: [0.15, 0.15, 0.15], // make plane smaller
    finishFunc: function(modelMap, array, rawS3){
        if(modelMap){                            
            modelMap.propeller.r3 = {//propeller 螺旋桨
            func: function(data){
                return [data.a('angle'), 0, 0]; 
            }
        };                             
        // make propeller a litter bigger
        modelMap.propeller.s3 = [1, 1.2, 1.2]; 
        modelMap.propeller.color = 'yellow';
    } 
});

 

这里面的 modelMap.propeller 是 OBJ 文件中定义好的 modelMap 对象中的 propeller 对象,你可以试着打印 modelMap 看看输出结果。

这个方法里的 finishFunc(modelMap, array, rawS3) 用于加载后的回调处理,具体查阅 HT for Web OBJ 手册,我们还添加了一个在 OBJ 模型中没有的飞机尾部的“红色闪烁指示灯”,这里用到的是组合模型 array(所有材质组成的数组,里面有至少一个模型),我们在 array中加入一个新的球模型:

// add a sphere model as an indicator light 指示灯
array.push({
    shape3d: ht.Default.createSmoothSphereModel(),
    t3: [-40, 10, 0],
    s3: [6, 6, 6],
    color: {
        func: function(data){
            return data.a('light') ? 'red': 'black';
        }
    }
});

这里的 shape3d 是 HT 封装的一个属性名,通过 setShape3dModel(name, model) 函数注册的或者是通过 getShape3dModel(name) 函数返回的注册过的 3D 模型,如何注册 3D 模型可查阅 HT for Web 建模手册

 

color 属性名对应了一个对象,这边的定义是这样的,color 直接通过 data.getAttr('a') 获取 data.setAttr(‘a’, value) 中的值,这样做有两个好处,一是可以不污染 HT 的常用属性操作,所以 HT 专门定义了这个 attr 属性类型,是 HT 预留给用户存储业务数据的;二是这样也很方便数据绑定,我们可以通过在需要更改属性的地方调用 setAttr 方法,非常方便。

接着我们通过 ht.Default.setShape3dModel(name, model) 来将我们刚刚组合好的模型 array 注册成我们要的“plane”模型:

ht.Default.setShape3dModel('plane', array);

注册好模型后肯定是要调用这个模型,我们可以通过 shape3d 属性来调用这个模型,并且在这个模型中自定义上面代码中出现过的 light 属性和 angle 属性:

plane = new ht.Node();
plane.s3(200, 200, 200);
plane.s3(rawS3);
plane.s({
    'shape3d': 'plane',
    'shape3d.scaleable': false,
    'wf.visible': true,//线框是否可见
    'wf.color': 'white',
    'wf.short': true //是否显示封闭的线框,true为不封闭的短线框
});
plane.a({
    'angle': 0,
    'light': false
});

 

因为飞机还有螺旋桨、指示灯两个功能,我们还得对这两个模型做动画效果,可查阅 HT for Web 动画手册,通过用户在 form 表单上选择的结果来决定飞机飞行持续时间、看飞机的视角、飞机沿着“航线”飞行所要旋转的角度、机尾指示灯的“闪烁”功能等等,最后别忘了飞机停止飞行时,如果要让飞机继续飞行,就得回调这个动画,并且设置灯不再闪烁,别忘了要启动动画:

params = {
    delay: 1500,
    duration: 20000,
    easing: function(t){ 
        return (t *= 2) < 1 ? 0.5 * t * t : 0.5 * (1 - (--t) * (t - 2));
    },
    action: function(v, t){
        var length = g3d.getLineLength(polyline),
        offset = g3d.getLineOffset(polyline, length*v),
        point = offset.point,
        px = point.x,
        py = point.y,
        pz = point.z,
        tangent = offset.tangent,
        tx = tangent.x,
        ty = tangent.y,
        tz = tangent.z;
        plane.p3(px, py, pz);
        plane.lookAt([px + tx, py + ty, pz + tz], 'right');
                        
        var camera = formPane.v('Camera');
        if(camera === 'Look At'){
            g3d.setCenter(px, py, pz);
        }
        else if(camera === 'First Person'){                            
            g3d.setEye(px - tx * 400, py - ty * 400 + 30, pz - tz * 400);
            g3d.setCenter(px, py, pz);                            
        }
                        
        plane.a('angle', v*Math.PI*120);                        
        if(this.duration * t % 1000 > 500){
            plane.a('light', false);
        }else{
            plane.a('light', true);
        }                        
    },
    finishFunc: function(){
        animation = ht.Default.startAnim(params);
        plane.a('light', false);
    }                  
};                               
                
animation = ht.Default.startAnim(params);

其实最让我们好奇的是描绘的路径跟飞机本身的飞行并没有关系,还有那么多左拐右拐的,要如何做才能做到呢?

接下来我们来描绘路径,首先这个路径是由 ht.Polyline 作为基础来描绘的:

polyline = new ht.Polyline();   
polyline.setThickness(2);
polyline.s({
    'shape.border.pattern': [16, 16],
    'shape.border.color': 'red',
    'shape.border.gradient.color': 'yellow',
    'shape3d.resolution': 300,
    '3d.selectable': false
});
dataModel.add(polyline);

上面的代码只是向 datamodel 数据模型中添加了一个 polyline 管线而已,不会显示任何东西,要显示“航道”首先就要设置航道所在的点,我们先设置航道的初始点:

points = [{ x: 0, y: 0, e: 0 }];
segments = [1];

这个 points 和 segments 是 HT for Web Shape 手册中定义的,points 是 ht.List 类型数组的定点信息,顶点为 { x: 100, y: 200 } 格式的对象;segments 是 ht.List 类型的线段数组信息,代表 points 数组中的顶点按数组顺序的连接方式。

图中“航道”左侧的多个圆形轨道也是通过设置 points 和 segments 来设置的:

for(var k=0; k<count+1; k++){
    var angle = k * Math.PI * 2 * round / count;
    points.push({
        x: cx + radius * Math.cos(angle),
        y: cy + radius * Math.sin(angle),
        e: k * height / count
    }); 
    segments.push(2);
}

接下来几个拐点也是这种方法来实现的,这里就不赘述了,如果你还没看手册的话,这里标明一点,segments 只能取值 1~5,1 代表一个新路径的起点;2 代表从上次最后点连接到该点;3 占用两个点信息,第一个点作为曲线控制点,第二个点作为曲线结束点;4 占用3个点信息,第一和第二个点作为曲线控制点,第三个点作为曲线结束点;5 不占用点信息,代表本次绘制路径结束,并闭合到路径的起始点:

points.push({ x: cx+radius, y: 0, e: height/2 });
points.push({ x: 0, y: 0, e: height/2 });
segments.push(3);
     
points.push({ x: radius, y: -radius, e: height/2*0.7 });
points.push({ x: radius*2, y: radius, e: height/2*0.3 });
points.push({ x: radius*3, y: 0, e: 0 });
segments.push(4);   

points.push({ x: 0, y: 0, e: 0 });
segments.push(2);  

 

我们已经把路径上的点都添加进“航道”中了,接下来要把点都设置到管道上去才会显示在界面上:

polyline.setPoints(points);
polyline.setSegments(segments);  

 

“跑道”就比较简单了,只是一个 Node 节点然后设置基础效果而已,没什么特别的:

runway = new ht.Node();
runway.s3(-cx+radius*3, 1, 200);
runway.p3(cx+runway.getWidth()/2, -22, 0);
runway.s({
    'all.color': '#FAFAFA',
    'all.transparent': true,
    'all.reverse.cull': true,
    'all.opacity': 0.8,
    '3d.selectable': false
});
dataModel.add(runway);

最后,在界面上添加一个 formPane 表单面板,定义好之后可以直接添加到 body 上,这样就不会跟 graph3dView 有显示的联系了。

formPane 可以用 formPane.addRow 方法动态添加行,这个方法中可以直接对动态变化的数据进行交互,例如本例中的是否有动画 Animation,我们利用 checkBox 来记录选中或者非选中的状态:

{
    checkBox: {
        label: 'Animation',
        selected: true,
        onValueChanged: function(){
            if(this.isSelected()){
                animation.resume();
            }else{
                animation.pause();
            }                               
        }
    }
}

也可以通过设置“id”来记录动态改变的值,然后 formPane就会通过调用 formPane.v(id) 来获取当前值。

 

 

至此,整个 Demo 的解释到此为止,如果还有不懂的可以先查阅我们官网 HT for Web,之后还有不懂的可以私信我,但还是希望你们能仔细阅读,不然很浪费我们双方的时间,谢谢~

分享到:
评论

相关推荐

    HTML5 canvas飞机飞行轨迹动画.zip

    在这个“HTML5 canvas飞机飞行轨迹动画”示例中,我们看到一个利用Canvas API创建的飞机飞行轨迹动画,这涉及到多个重要的HTML5和JavaScript知识点。 1. **HTML5 Canvas API**: HTML5 Canvas是一个基于矢量图形的...

    html5 canvas制作3D飞行的飞机动画特效

    在这个特定的案例中,“html5 canvas制作3D飞行的飞机动画特效”是一个涉及到JavaScript编程、Canvas API以及可能的WebGL技术的主题。我们将深入探讨这些关键知识点。 1. HTML5 Canvas: HTML5 Canvas是一个基于...

    HTML5 canvas飞机空中飞行动画代码.zip

    要实现飞机飞行动画,我们需要理解以下几个核心概念: 1. **Canvas API**: 包括`context`对象,它是实际进行绘图操作的对象,提供了各种方法如`fillRect`, `strokeRect`, `clearRect`, `beginPath`, `moveTo`, `...

    three.js+Canvas飞机飞行场景动画特效

    【标题】"three.js+Canvas飞机飞行场景动画特效"是一个基于WebGL的3D渲染库Three.js和HTML5 Canvas技术创建的互动性飞行场景。它展示了飞机在树林上空飞行的动态效果,允许用户通过鼠标操作来改变飞机的飞行方向,...

    html5 canvas纸飞机跟随鼠标飞行动画特效

    5. 纸飞机飞行:根据预先设定的飞行速度和角度,计算新的位置,然后在Canvas上清除旧图像,绘制新位置的纸飞机。 通过这样的实现,用户在浏览网页时,会看到纸飞机随着鼠标移动而飞行,周围还有圆点在不断漂浮,...

    HTML5 Canvas五彩烟雾模拟动画

    之前我们利用HTML5技术在Canvas上模拟了很多东西,比如最近刚分享的HTML5 Canvas 多种炫酷3D...这次给大家带来的也是一款基于HTML5 Canvas的动画特效,它模拟了五彩烟雾的流动效果,这在Canvas上实现还是比较简单的。

    html5 canvas纸飞机跟随鼠标飞行特效源码.zip

    "html5 canvas纸飞机跟随鼠标飞行特效源码.zip"这个压缩包包含了一个利用HTML5 Canvas实现的有趣应用:纸飞机跟随鼠标飞行的特效。这个特效能够增加网站的趣味性和互动性,吸引用户的注意力。 首先,我们要理解...

    HTM5 Canvas实现3D飞机飞行动画特效.zip

    总的来说,"HTM5 Canvas实现3D飞机飞行动画特效"是一个结合了HTML5 Canvas、Three.js库和WebGL技术的项目,通过这些技术,可以在网页上创建出引人入胜的3D动画效果,为用户带来沉浸式的交互体验。学习并掌握这些技术...

    Canvas飞机树林上空飞行特效.zip

    《Canvas与Three.js实现飞机飞行特效详解》 在现代网页设计中,动态视觉效果已经成为吸引用户注意力的重要手段。其中,JavaScript库Three.js以其强大的3D渲染能力,为开发者提供了丰富的可能性。今天我们将深入探讨...

    unity3d模拟飞机飞行源码

    在这个“unity3d模拟飞机飞行源码”项目中,开发者利用Unity3D的强大功能,构建了一个高度逼真的飞行模拟器,支持iOS和Android移动设备。 首先,我们要理解飞行模拟的核心是飞行动力学模型。这个模型包含了飞机在...

    html5 canvas模拟满天星空背景动画特效

    "html5 canvas模拟满天星空背景动画特效"是一个利用Canvas API实现的网页背景效果,旨在为用户提供一种沉浸在璀璨星空下的视觉体验。 在HTML5 Canvas中,我们可以通过JavaScript控制画布上的每一个像素,从而实现...

    html5 canvas纸飞机跟随鼠标飞行动画特效.zip

    "html5 canvas纸飞机跟随鼠标飞行动画特效.zip"是一个利用HTML5 Canvas和jQuery实现的互动动画示例,它展示了如何通过JavaScript编程使纸飞机跟随用户的鼠标移动。这个特效代码适用于那些想要为网站添加趣味性和互动...

    canvas拼图游戏,基于html + canvas画布实现

    canvas拼图游戏,基于html + canvas画布实现

    基于html2canvas生成带二维码的活动海报

    本项目"基于html2canvas生成带二维码的活动海报"提供了一个纯前端解决方案,使得开发者无需后端支持也能快速实现此类功能。html2canvas是一个JavaScript库,它能够将网页的DOM(文档对象模型)渲染为图片,从而解决...

    HTML5 Canvas飞机线条弧度飞行动画特效.zip

    总结来说,这个压缩包提供了一个基于HTML5 Canvas的飞机飞行动画特效,使用了jQuery库进行操作,并涉及到Canvas的绘图API,如`arc()`、`lineTo()`等。它展示了如何在网页上创建动态的、交互式的视觉效果,同时也为...

    一个基于 html5 canvas 的流程图demo..zip

    这个"一个基于html5 canvas的流程图demo.zip"文件很可能包含了一个使用HTML5 Canvas技术实现的流程图示例项目。下面将详细探讨HTML5 Canvas以及其在多媒体和游戏开发中的应用。 HTML5 Canvas是一个基于矢量图形的...

    基于html2canvas将当前页面保存为图片Demo

    它不直接操作浏览器的原生Canvas API,而是模拟这个过程。 - 它支持大部分CSS样式,包括背景色、边框、阴影、文本等,但对某些复杂布局和Web字体可能支持有限。 - 渲染完成后,可以使用Canvas的toDataURL方法将...

    canvas实现3D飞机飞行动画特效

    利用html5中的canvas技术实现3d飞机的飞行动画特效~~~

    HTML5 Canvas飞机线条弧度飞行动画特效

    总的来说,这个HTML5 Canvas飞机飞行动画特效结合了Canvas的基本绘图方法、动画循环以及数学计算,为网页带来了动态的视觉体验。开发者可以根据需求调整飞机的样式、飞行轨迹和动画参数,以适应不同的应用场景。

Global site tag (gtag.js) - Google Analytics