成人性生交大片免费看视频r_亚洲综合极品香蕉久久网_在线视频免费观看一区_亚洲精品亚洲人成人网在线播放_国产精品毛片av_久久久久国产精品www_亚洲国产一区二区三区在线播_日韩一区二区三区四区区区_亚洲精品国产无套在线观_国产免费www

主頁 > 知識庫 > HTML5 WebGL 實現(xiàn)民航客機飛行監(jiān)控系統(tǒng)

HTML5 WebGL 實現(xiàn)民航客機飛行監(jiān)控系統(tǒng)

熱門標簽:會聲會影怎樣做地圖標注效果 平頂山電子地圖標注怎么修改 高德地圖標注錯誤怎么修改 電銷機器人視頻 搜狗星級酒店地圖標注 江蘇高頻外呼系統(tǒng)線路 標準智能外呼系統(tǒng) 洛陽市伊川縣地圖標注中心官網(wǎng) 地圖標注自己去過的地方

前言

前些日子出差,在飛機上看到頭頂?shù)谋O(jiān)控面板,除了播放電視劇和廣告之外,還會時不時的切換到一個飛機航行的監(jiān)控系統(tǒng),不過整個監(jiān)控系統(tǒng)讓人感到有一點點的簡陋,所以我就突發(fā)奇想制作了一個采用 HT for Web 的升級版監(jiān)控系統(tǒng),demo 的效果還行,發(fā)出來大家相互學習下。


 

demo

實現(xiàn)過程

云中穿行效果

為了達到飛機云中穿行的效果,最開始我遇到的問題是飛機飛行的層次感,也就通常所說的透視效果,這里我采用的是云通道和云背景以不同的速度流動,制造一種飛行的透視效果。

云我采用的是貼圖的方式呈現(xiàn)的,但是僅僅是貼圖會遮擋天空和飛機,非常影響飛機飛行的觀感,所以我開啟了相應(yīng)圖元的 transparent 和 opacity ,云背景和云通道設(shè)置不同的透明度,不僅增加了層次感,還會讓人產(chǎn)生云朵從眼前飄過的錯覺。

云通道采用的是 ht.Polyline 類型,通道縮放拉大了 Y 軸的比例,使云通道有更大的縱向空間,設(shè)置 reverse.flip 背拷貝使云通道內(nèi)部也顯示出貼圖,仿佛讓飛機置身于云海中穿梭;云背景采用 ht.Node 類型,只設(shè)置一個面顯示充當云背景。

整體的云流動效果采用 offset 偏移實現(xiàn),改變相應(yīng)圖元或相應(yīng)圖元面的貼圖偏移量來達到飛機云中穿行的效果, 代碼如下:
 

var i = 1, 
    p = 0;
setInterval(() => {
    i -= 0.1; p += 0.005;
    clouds.s('shape3d.uv.offset', [i, 0]);
    cloudBackground.s('all.uv.offset', [p, 0]);
}, 100);

升降顛簸效果

雖然達到了飛機云中穿行的效果,但是如果飛機只是直直的飛行,那也會降低飛行的實感,相信坐過飛機的朋友肯定都遇到過因氣流產(chǎn)生的顛簸,也經(jīng)常感受到飛機飛行途中的爬升和下降,這其實是因為飛機的航線并不是一直固定在一個高度上,有時會爬升有時會下降,所以我就用 ht-animation.js HT 動畫擴展插件去實現(xiàn)飛機顛簸效果,代碼如下:

dm.enableAnimation(20);
plane.setAnimation({
    back1: {
        from: 0,
        to: 160,
        easing: 'Cubic.easeInOut',
        duration: 8000,
        next: "up1",
        onUpdate: function (value) {
            value = parseInt(value);
            var p3 = this.p3();
            this.p3(value, p3[1], p3[2]);
        }
    },
    //...省略相似
    start: ["back1"]
});

球扇形視角限制

飛行效果完善之后,這時我就遇到了一個比較棘手的問題,因為實際上雖然看著飛機是在云海中穿梭,但是僅僅是在通道中飛行,背景其實也只是平面貼圖,所以當視角到達某種程度的時候就會有強烈的違和感和不真實感,就需要一個視角限制,使視角的調(diào)整剛剛好在一個范圍內(nèi)。

視角限制的話一般是限制 g3d 的 eye 和 center ,不太了解的朋友可以去看 hightopo 官網(wǎng)中的 3d 手冊,里面有詳細的說明,這里我就不再贅述了;因為視角范圍的關(guān)系,所以我決定固定 center 的位置,代碼如下:
 

g3d.addPropertyChangeListener(e => {
    // 固定中心點
    if (e.property === 'center') {
        e.newValue[0] = center[0];
        e.newValue[1] = center[1];
        e.newValue[2] = center[2];
    }
}

然后再把 eye 限制在某一個范圍內(nèi)就大功告成了,然而這里卻并不是那么簡單,最開始我把 eye 限制在一個立方體的空間內(nèi),但交互效果很不理想,考慮到 g3d 默認交互中,鼠標拖拽平移視角變換時,實際上 eye 是在一個以 center 為球心的球面上運動的,所以我決定從這個球中挖出來一塊作為 eye 的限制空間,也就是球扇形,不太理解的朋友可以參考這個圖:


 

球扇形視角限制,一共需要三個參數(shù),分別是中心參考軸、中心軸和外邊所成角度、所在球限制半徑,其中中心參考軸可根據(jù)初始 eye 和 center 的連接延長線確定,所在球限制半徑又分最大限制和最小限制,代碼如下:

 

function limitEye(g3d, eye, center, options) {
    var limitMaxL   = options.limitMaxL,
        limitMinL   = options.limitMinL,
        limitA      = options.limitA;

    g3d.addPropertyChangeListener(e => {
        // 固定中心點
        if (e.property === 'center') {
            e.newValue[0] = center[0];
            e.newValue[1] = center[1];
            e.newValue[2] = center[2];
        }
        // 限制視角
        if (e.property === 'eye') {
            var newEyeV = new ht.Math.Vector3(e.newValue),
                centerV = new ht.Math.Vector3(center),
                refEyeV = new ht.Math.Vector3(eye),
                refVector = refEyeV.clone().sub(centerV),
                newVector = newEyeV.clone().sub(centerV);

            if (centerV.distanceTo(newEyeV) > limitMaxL) {
                newVector.setLength(limitMaxL);
                e.newValue[0] = newVector.x;
                e.newValue[1] = newVector.y;
                e.newValue[2] = newVector.z;
            }
            if (centerV.distanceTo(newEyeV) < limitMinL) {
                newVector.setLength(limitMinL);
                e.newValue[0] = newVector.x;
                e.newValue[1] = newVector.y;
                e.newValue[2] = newVector.z;
            }
            if (newVector.angleTo(refVector) > limitA) {
                var oldLength = newVector.length(),
                    oldAngle  = newVector.angleTo(refVector),
                    refLength = oldLength * Math.cos(oldAngle),
                    vertVector,
                    realVector,
                    realEye;

                refVector.setLength(refLength);

                newEyeV = newVector.clone().add(centerV);
                refEyeV = refVector.clone().add(centerV);
                vertVector = newEyeV.clone().sub(refEyeV);
                vertLength = refLength * Math.tan(limitA);

                vertVector.setLength(vertLength);

                realVector = vertVector.clone().add(refEyeV).sub(centerV);

                realVector.setLength(oldLength);

                realEye = realVector.clone().add(centerV);

                // 防止移動角度大于 180 度,視角反轉(zhuǎn)
                if (oldAngle > Math.PI / 2) {
                    realEye.negate();
                }

                e.newValue[0] = realEye.x;
                e.newValue[1] = realEye.y;
                e.newValue[2] = realEye.z;
            }  
        }
    })
}

飛機監(jiān)控系統(tǒng)

當然作為監(jiān)控系統(tǒng),自然要有監(jiān)控了,增加右下角的小地圖,并提供三種模式,分別是聚焦飛機,聚焦飛行軌跡和聚焦地圖,并根據(jù)飛機的飛行方向控制飛行軌跡的流動效果,其中聚焦飛機會跟隨飛機移動進行 fitData ,使飛機一直處于小地圖的中心,代碼如下:

 

var fitFlowP = function (e) {
    if (e.property === 'position' && e.data === plane) {
        mapGV.fitData(plane, false);
    }
};
buttonP.s({
    'interactive': true,
    'onClick': function (event, data, view, point, width, height) {
        map.a('fitDataTag', 'plane2D');
        mapGV.fitData(plane, false);
        mapDM.md(fitFlowP);
    }
});
buttonL.s({
    'interactive': true,
    'onClick': function (event, data, view, point, width, height) {
        mapDM.umd(fitFlowP);
        map.a('fitDataTag', 'flyLine');
        mapGV.fitData(flyLine, false);
    }
});
// ...省略

增加鼠標移到飛機相應(yīng)位置進行名稱的提示、雙擊后顯示飛機相應(yīng)位置的信息面板并將視角聚焦到面板上、點擊飛機任意地方切換回飛機飛行模式等效果。


 

左側(cè)增加監(jiān)控面板替代上面提到的雙擊相應(yīng)位置這步操作直接聚焦到相應(yīng)位置的信息面板上,這里按鈕開啟了交互并添加了相應(yīng)的交互邏輯,代碼如下:

 

button_JC.s({
    'interactive': true,
    'onClick': function (event, data, view, point, width, height) {
        event.preventDefault();
        let g3d = G.g3d,
            g3dDM = G.g3d.dm();
        g3d.fireInteractorEvent({
            kind: 'doubleClickData',
            data: g3dDM.getDataByTag(data.getTag())
        })
    }
});
//...省略

天空渲染效果

既然是監(jiān)控系統(tǒng)肯定是 24 小時無差別的監(jiān)控,這就涉及到一個問題,我總不可能半夜的時候飛機也從瓦藍瓦藍的天空上飛過,這就很欠缺真實性了,所以要有一個天空從亮到暗再從暗到亮的過程,這個過程我暫定到 06:00-06:30 和19:00-19:30 這兩個時間段。

天空采用的是 shape3d : 'sphere' 球形,包裹整個場景,然后使用 reverse.flip 背拷貝 和 blend 染色,之后天空就可以渲染成我想要的顏色,如果按照時間改變天空明暗只要改變?nèi)旧稻涂梢粤恕?/p>

但是由于白天和晚上光照情況的不同,云反射光的強度也不同,就導致了白天和晚上云的差異,所以也要調(diào)整云道和云背景的貼圖的 opacity 透明度,晚間更為透明度,代碼如下:

if ((hour > 6 && hour < 19) || (hour == 6 && minutes >= 30)) {
    timePane && timePane.a({
        'morning.visible': false,
        'day.visible': true,
        'dusk.visible': false,
        'night.visible': false,
        'day.opacity': 1
    })
    skyBox.s({
        "shape3d.blend": 'rgb(127, 200, 240)',
    })
    cloudBackground.s({
        "back.opacity": 0.7,
    })
    clouds.s({
        "shape3d.opacity": 0.7,
    })
} else if ((hour < 6 || hour > 19) || (hour == 19 && minutes >= 30)) {
//...省略
} else if (hour == 6 && minutes < 15 ) {
//...省略
} else if (hour == 6 && minutes >= 15 && minutes < 30) {
//...省略
} else if (hour == 19 && minutes < 15) {
//...省略
} else if (hour == 19 && minutes >= 15 && minutes < 30) {
//...省略
}

這里我還增加了對右上角時間面板時間狀態(tài)圖標的支持,并增加了圖標切換時的漸隱漸顯效果,同時給時間面板狀態(tài)圖標位置增加了點擊切換到下一時間狀態(tài)的功能。

為了演示效果我增加了時間倍速按鈕,下圖是 500 倍時間流速下的變化情況:


 

總結(jié)

通過這個 demo ,我發(fā)現(xiàn)生活中有很多沒有被人所注意到的細節(jié)都存在數(shù)據(jù)可視化的可能,在這個大數(shù)據(jù)的時代更多的可能性值得被人發(fā)掘出來,不要錯個身邊每一個值得數(shù)據(jù)可視化的細節(jié),這樣不僅可以更好的挖掘 HT for Web 的潛力,也可以加強自身身為一個程序員的綜合素質(zhì)。

標簽:常德 廣西 鄂爾多斯 松原 蚌埠 廣東 果洛 阿克蘇

巨人網(wǎng)絡(luò)通訊聲明:本文標題《HTML5 WebGL 實現(xiàn)民航客機飛行監(jiān)控系統(tǒng)》,本文關(guān)鍵詞  HTML5,WebGL,實現(xiàn),民航,客機,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《HTML5 WebGL 實現(xiàn)民航客機飛行監(jiān)控系統(tǒng)》相關(guān)的同類信息!
  • 本頁收集關(guān)于HTML5 WebGL 實現(xiàn)民航客機飛行監(jiān)控系統(tǒng)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    中文字幕日本乱码精品影院| 又黄又湿又爽又免费又色| 久久久久综合| 欧美三级在线播放| 在线观看久久久久久| 一区二区三区免费在线看| 日韩av片免费在线观看| 国产男女猛烈无遮挡在线喷水| 国产精欧美一区二区三区| 最近2019免费中文字幕视频三| 国产免费无遮挡| 欧美性色视频在线| 日韩精品在线观看网站| 欧美成人免费高清视频| 日本xxxxx18| 久久女同互慰一区二区三区| 一区二区三区 在线观看视| 九九热这里有精品视频| 超碰人人草人人| 日本免费一区二区三区视频| 91亚洲一区| 久久伦理中文字幕| 91精品中国老女人| 69久成人做爰电影| 国产精品无码午夜福利| 日日碰狠狠添天天爽| 亚洲精品乱码久久久久久按摩观| 99热国产在线| 日韩av电影手机在线观看| www.久久草.com| 欧美日韩卡一卡二| 日韩有码一区二区三区| 四虎影视免费看电影| 亚洲第一天堂久久| 精品一区在线播放| av网站无病毒在线| 夜色资源网av在先锋网站观看| 成a人片在线观看www视频| 国产一区二区三区四区五区传媒| 91色在线看| 综合久久综合久久| 国产精品久久国产愉拍| 色欧美88888久久久久久影院| 国产精品日韩高清| 国产午夜亚洲精品午夜鲁丝片| 欧美午夜a级限制福利片| 欧美91精品| 成人国产精品入口免费视频| 亚洲综合图片一区| 在线中文资源天堂| 男女无套免费视频网站动漫| 性欧美极品另类| 欧美网站免费观看| 久久久99精品视频| 国产强被迫伦姧在线观看无码| 精品无码久久久久成人漫画| 国精产品视频一二二区| 成人黄色激情网站| 久久福利一区二区| av动漫免费观看| 男人打飞机网站| 久久精品国产第一区二区三区最新章节| 日韩欧美亚洲国产一区| 一色屋免费视频| 日韩在线综合| 欧美一级欧美一级在线播放| caoprom在线| 91精品久久久久久久久久另类| 中文字幕精品一区二区精品| 色中色在线视频| 精品无人区无码乱码毛片国产| 亚洲第一精品区| 亚洲欧美韩国| 一区二区三区美女视频| www在线免费观看视频| 在线视频日本亚洲性| 国产福利三区| 国产精品三级在线观看| 国产国语videosex另类| 大黑人xxx| 中文精品视频一区二区在线观看| 中文字幕五月欧美| 在线播放精品视频| 在线中文字幕-区二区三区四区| 德国性xxxx| 成人永久免费| 国产又大又黄又爽| 国产又色又爽又黄又免费| 91精品99| 成人午夜大片免费观看| 欧美性受xxxxxx黑人xyx性爽| 日韩欧美在线视频播放| 在线免费观看黄| 国产精品伦子伦| 黄视频在线播放| 日韩av不卡在线播放| 亚洲精品国产setv| 99re热这里只有精品免费视频| 制服丝袜影音| 日本一区免费观看| 精品亚洲美女网站| 亚洲免费观看在线观看| 精品少妇一区二区| 日韩成人短视频| 免费久久网站| 在线视频二区| 久久欧美一区二区| xvideos入口| 欧美激情综合亚洲一二区| 午夜一区二区三区免费| 亚洲av无码一区二区二三区| 女生裸体视频网站免费观看| 亚洲www永久成人夜色| 91免费看蜜桃| 羞羞视频网站| 欧美性生交xxxxx| 久久久久一本一区二区青青蜜月| 日韩美女在线播放| 欧美亚洲国产激情| 超碰成人在线播放| 中文字幕av一区二区三区佐山爱| 香蕉人妻av久久久久天天| 亚洲精品久久久久久无码色欲四季| 91国产免费观看| 精品久久五月天| 丰满少妇高潮在线观看| www日韩在线观看| 日韩中文有码在线视频| 9l视频自拍蝌蚪9l视频成人| 日韩一级欧美一级| 成人福利资源| 国产成人精品午夜视频免费| 欧美三根一起进三p| 精品久久久久久久| 免费看污污网站| 亚洲一级Av无码毛片久久精品| 深夜福利久久| 日本中文字幕不卡| 日本三级一区二区三区| 国产精品白丝av嫩草影院| 国产成人亚洲综合a∨婷婷| 成人情视频高清免费观看电影| 欧美日韩精品综合| 沈樵精品国产成av片| 草民午夜欧美限制a级福利片| 青青在线视频一区二区三区| 欧美一区二区激情| 在线成年人视频| 国产精品天干天干在线综合| 午夜精品亚洲一区二区三区嫩草| 亚洲一级免费毛片| 一区二区三区中文字幕在线观看| 国产精品久久久久久网站| 亚洲色图一二三区| 亚洲精品激情| 欧美色图亚洲自拍| 亚洲电影免费观看高清| 日韩免费视频在线观看| 麻豆久久婷婷| 精品国产91亚洲一区二区三区www| 微拍福利一区二区| 亚洲精品免费在线观看| 美乳在线观看| 久久久久久国产精品日本| 欧美特黄级在线| 国产精品国内免费一区二区三区| 国产精品 欧美 日韩| 精品欧美国产一区二区三区不卡| 国产欧美一区二区三区精品观看| 先锋成人av| 国产精品国产三级国产三级人妇| 黄色小视频免费| 国产精品v欧美精品v日韩精品| 免费在线观看的毛片| 亚洲一区二区三区高清| 国产欧美一区二区在线观看| 免费一级特黄毛片| 97免费中文视频在线观看| 欧美日韩免费看片| 在线看免费毛片| 亚洲精品xxx| 91成年人视频| 亚洲精品麻豆| 欧美日韩在线一二三| 狠狠色丁香婷婷综合久久片| 亚洲一区二区三区四区中文| 亚洲一区和二区| 亚洲精品在线播放| 国产 欧美 日韩 在线| 欧美激情在线观看视频免费| 国产视频一区欧美| 中文字幕av免费观看| 91极品女神私人尤物在线播放| 天天操天天干天天做| 男人插入女人视频| 激情视频免费在线| 国产性猛交96| 日韩免费一二三区| 色诱视频在线观看| 牛牛精品视频在线| 成人手机在线| 成人污污视频在线观看| 一区二区三区四区在线看| 国产精品人人爱一区二区白浆| 国产成人精品www牛牛影视| 欧洲人成人精品| aaa一级黄色片| 亚洲视频网站在线| 老熟女高潮一区二区三区| 在线观看免费91| 国产精品视频午夜| 欧美大波大乳巨大乳| 亚洲国产美女精品久久久久∴| 亚洲国产一区在线| 全球成人中文在线| 少妇无套高潮一二三区| 国产精品国产精品国产专区不片| 色综合久久一区二区三区| 国产情侣自拍小视频| 免费观看一二区视频网站| 国产精品久久久久9999赢消| 欧美成人免费电影| 亚洲熟女少妇一区二区| 一本色道久久99精品综合| 久久艹这里只有精品| 久久久久久亚洲综合影院红桃| 一本岛在线视频| 精品综合免费视频观看| 精品自拍视频| 亚洲最大成人在线视频| 丰满人妻一区二区三区53视频| 亚洲xxxx3d| 欧美特级xxxxbbbb毛片| 97视频在线观看免费高清完整版在线观看| 国产精品123区| 日韩三级av| 最近中文字幕无免费| 99麻豆久久久国产精品免费| 中国成人一区| av日韩电影| 欧美日韩国产一区精品一区| 国产成人一区二区三区影院| 久久久久久三级| 日韩一区二区视频在线观看| 亚洲一级片在线播放| 午夜精品免费看| 777米奇影视第四色| 国模吧一区二区三区| 五月婷婷深深爱| 热re66久久精品国产99热| 99久久久精品免费观看国产蜜| 欧美黑人经典片免费观看| 日韩一本精品| 国产日产亚洲精品| 亚洲毛茸茸少妇高潮呻吟| 17婷婷久久www| 亚洲成人网在线| 亚洲视频一二区| 久久伊人蜜桃av一区二区| 翔田千里在线视频| 亚洲一级Av无码毛片久久精品| 琪琪亚洲精品午夜在线| 少妇高潮一69aⅹ| 中文字幕亚洲欧美日韩在线不卡| 99中文字幕在线| 欧美高清视频| 午夜av区久久| 亚洲自拍偷拍色图| 99久久婷婷国产精品综合| 动漫性做爰视频| 91浏览器在线视频| 日本一本视频| 久久免费视频在线| 人人爱人人爽| 欧美日韩国产中字| 亚洲男女av一区二区| 成人免费福利在线| 久久久www免费人成精品| 在线观看亚洲视频| 亚洲综合丁香婷婷六月香| 久久99精品国产自在现线小黄鸭| 欧美视频在线一区| 黑人巨茎大战欧美白妇| 91系列在线播放| 人妻av中文系列| 国产精品免费视频一区一| 黄色在线一区| 久久精品91久久久久久再现| 精品视频偷偷看在线观看| 无码播放一区二区三区| 久久电影一区| 国产精品久久久久久久久久东京| 日韩中文一区二区三区| 懂色一区二区三区av片| 欧美精品第一页| 欧美色欧美亚洲高清在线视频| 久久精品一区二区| 国产视频久久| 久久久久国产一区| 在线精品亚洲一区二区不卡| 99国产精品久久久久久久久久久| www.五月婷婷| 超碰97人人人人人蜜桃| 欧洲精品视频在线观看| 亚洲电影第1页| 欧美在线三级电影| 亚洲av网址在线| 精品欧美久久| av文字幕在线观看| 欧美一级一片| 奶水喷射视频一区| 国产在线免费观看| 五月天国产视频| 白嫩情侣偷拍呻吟刺激| 亚洲电影二区| 色婷婷综合在线| 国产精品超碰| 久久99精品国产.久久久久| 香蕉久久a毛片| 亚洲aⅴ优女av综合久久久| 中文字幕在线免费观看视频| 丁香婷婷久久久综合精品国产| 美洲精品一卡2卡三卡4卡四卡| 色妇色综合久久夜夜| 欧美一激情一区二区三区| 涩涩涩在线视频| 欧美一区二区三区日韩视频| 一区二区日韩电影|