国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發(fā) > HTML5 > 正文

基于HTML5 Canvas 實現(xiàn)商場監(jiān)控實例詳解

2024-09-05 07:19:06
字體:
供稿:網(wǎng)友

伴隨國內(nèi)經(jīng)濟的高速發(fā)展,人們對安全的要求越來越高。為了防止下列情況的發(fā)生,您需要考慮安裝安防系統(tǒng): 提供證據(jù)與線索:很多工廠銀行發(fā)生偷盜或者事故相關(guān)機關(guān)可以根據(jù)錄像信息偵破案件,這個是非常重要的一個線索。還有一些糾紛或事故,也可以通過錄像很容易找出相關(guān)人員的責(zé)任。 人防成本高:現(xiàn)在很多地方想到安全就想到要雇傭保安,每個保安每個月 800,每天 3 班倒,一班人員一年就需要將近 4 萬元,相比于電子安防設(shè)備成本并不便宜,而且使用電子安防設(shè)備幾年內(nèi)就不太需要更換。所以人防成本相對也很高。人防輔助:多數(shù)情況下,完全靠人來保證安全是一件很困難的事情,很多事情需要電子保安器材(如監(jiān)視器、報警器)輔助才更完美。特殊場合必須使用:在一些惡劣條件下(高熱、寒冷、封閉等),人很難用肉眼觀察清楚,或者環(huán)境根本不適合人的停留,必須使用電子安防設(shè)備。隱蔽性:使用電子安防設(shè)備,一般人不會感覺時時被監(jiān)控,具有隱蔽性。24 小時安全保證:要達(dá)到 24 小時不間斷的安全需要,電子設(shè)備是必須考慮的。遠(yuǎn)程監(jiān)控:隨著計算機技術(shù)與網(wǎng)絡(luò)技術(shù)的發(fā)展,遠(yuǎn)程監(jiān)控觀看異地圖象已經(jīng)成為可能,現(xiàn)在已經(jīng)有很多公司的負(fù)責(zé)人已經(jīng)可以 INTERNET 及時觀看世界各地的任何分公司情況,有利于及時了解情況。圖象保存:數(shù)字錄像技術(shù)的發(fā)展,使得影象可以通過計算機數(shù)字存儲設(shè)備得以保存,可以保存時間更長,圖象更清晰。生產(chǎn)管理:管理人員可以及時、直觀的了解生產(chǎn)第一線的情況,便于指揮與管理。

鑒于監(jiān)控系統(tǒng)在國內(nèi)的需求量較大,我們今天來給大家介紹一下如何創(chuàng)建一個監(jiān)控系統(tǒng)的前端部分。

http://www.hightopo.com/demo/metro/demo2.html 進(jìn)入頁面右鍵“審查元素”可查看例子源代碼。

本例的動態(tài)效果如下:

 我們先來搭建基礎(chǔ)場景,在 HT 中,非常常用的一種方法來將外部場景導(dǎo)入到內(nèi)部就是靠解析 JSON 文件,用 JSON 文件來搭建場景的好處之一就是可以循環(huán)利用,我們今天的場景就是利用 JSON 畫出來的。接下來 HT 將利用  ht.Default.xhrLoad 函數(shù)載入 JSON 場景,并用 HT 封裝的 DataModel.deserialize(json) 來反序列化,并將反序列化的對象加入 DataModel:

ht.Default.xhrLoad('demo2.json', function(text) {    var json = ht.Default.parse(text);    if(json.title) document.title = json.title;//將 JSON 文件中的 titile 賦給全局變量 titile     dataModel.deserialize(json);//反序列化    graphView.fitContent(true);//縮放平移拓?fù)湟哉故舅袌D元,即讓所有的元素都顯示出來});

在 HT 中,Data 類型對象構(gòu)造時內(nèi)部會自動被賦予一個 id 屬性,可通過 data.getId() 和 data.setId(id) 獲取和設(shè)置,Data 對象添加到 DataModel 之后不允許修改 id 值,可通過 dataModel.getDataById(id) 快速查找 Data 對象。一般建議 id 屬性由 HT 自動分配,用戶業(yè)務(wù)意義的唯一標(biāo)示可存在 tag 屬性上,通過 Data#setTag(tag) 函數(shù)允許任意動態(tài)改變 tag 值,通過DataModel#getDataByTag(tag) 可查找到對應(yīng)的 Data 對象,并支持通過 DataModel#removeDataByTag(tag) 刪除 Data 對象。我們這邊通過在 JSON 中設(shè)置 Data 對象的 tag 屬性,在代碼中通過 dataModel.getDataByTag(tag) 函數(shù)來獲取該 Data 對象:

var fan1 = dataModel.getDataByTag('fan1');var fan2 = dataModel.getDataByTag('fan2');var camera1 = dataModel.getDataByTag('camera1');var camera2 = dataModel.getDataByTag('camera2');var camera3 = dataModel.getDataByTag('camera3');var redAlarm = dataModel.getDataByTag('redAlarm');var yellowAlarm = dataModel.getDataByTag('yellowAlarm');

我在下圖中做了各標(biāo)簽對應(yīng)的元素:

接著我們對需要旋轉(zhuǎn)、閃爍的對象進(jìn)行設(shè)置,HT 中對“旋轉(zhuǎn)”封裝了 setRotation(rotation) 函數(shù),通過獲得對象當(dāng)前的旋轉(zhuǎn)角度,在這個角度的基礎(chǔ)上再增加某個弧度,通過 setInterval 定時調(diào)用,這樣就能在一定的時間間隔內(nèi)旋轉(zhuǎn)相同的弧度:

setInterval(function(){    var time = new Date().getTime();    var deltaTime = time - lastTime;    var deltaRotation = deltaTime * Math.PI / 180 * 0.1;    lastTime = time;    fan1.setRotation(fan1.getRotation() + deltaRotation*3);    fan2.setRotation(fan2.getRotation() + deltaRotation*3);    camera1.setRotation(camera1.getRotation() + deltaRotation/3);    camera2.setRotation(camera2.getRotation() + deltaRotation/3);    camera3.setRotation(camera3.getRotation() + deltaRotation/3);    if (time - stairTime > 500) {        stairIndex--;        if (stairIndex < 0) {            stairIndex = 8;        }        stairTime = time;    }    for (var i = 0; i < 8; i++) {//因為有一些相似的元素我們設(shè)置的 tag 名類似,只是在后面換成了1、2、3,所以我們通過 for 循環(huán)來獲取        var color = stairIndex === i ? '#F6A623' : '#CFCFCF';        dataModel.getDataByTag('stair_1_' + i).s('shape.border.color', color);        dataModel.getDataByTag('stair_2_' + i).s('shape.border.color', color);    }    if (new Date().getSeconds() % 2 === 1) {        yellowAlarm.s('shape.background', null);        redAlarm.s('shape.background', null);    }    else {        yellowAlarm.s('shape.background', 'yellow');        redAlarm.s('shape.background', 'red');    }}, 5);

HT 還封裝了 setStyle 函數(shù)用來設(shè)置樣式,可簡寫為 s,具體樣式請參考 HT for Web 樣式手冊:

for (var i = 0; i < 8; i++) {//因為有一些相似的元素我們設(shè)置的 tag 名類似,只是在后面換成了1、2、3,所以我們通過 for 循環(huán)來獲取    var color = stairIndex === i ? '#F6A623' : '#CFCFCF';    dataModel.getDataByTag('stair_1_' + i).s('shape.border.color', color);    dataModel.getDataByTag('stair_2_' + i).s('shape.border.color', color);}

我們還對“警告燈”的閃爍進(jìn)行了定時控制,如果是偶數(shù)秒的時候,就將燈的背景顏色設(shè)置為“無色”,否則,如果是 yellowAlarm 則設(shè)置為“黃色”,如果是 redAlarm 則設(shè)置為“紅色”:

if (new Date().getSeconds() % 2 === 1) {    yellowAlarm.s('shape.background', null);    redAlarm.s('shape.background', null);}else {    yellowAlarm.s('shape.background', 'yellow');    redAlarm.s('shape.background', 'red');}

整個例子就這么輕松地解決了,簡直太輕松了。。。

總結(jié)

以上所述是小編給大家介紹的基于HTML5 Canvas 實現(xiàn)商場監(jiān)控實例詳解,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對武林網(wǎng)網(wǎng)站的支持!

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 永胜县| 嘉兴市| 兴和县| 尚志市| 将乐县| 临西县| 东城区| 马山县| 鹤岗市| 深圳市| 巫山县| 广南县| 新乡市| 泸溪县| 江永县| 宁化县| 格尔木市| 阿勒泰市| 凤阳县| 丰县| 根河市| 景洪市| 平湖市| 新干县| 江陵县| 大荔县| 贵德县| 深泽县| 蓬莱市| 商丘市| 铜陵市| 广饶县| 桃源县| 临湘市| 大洼县| 苏尼特右旗| 温州市| 道孚县| 班玛县| 铜山县| 鄂托克前旗|