基於 HTML5 Canvas 的智能安防 SCADA 巡邏模塊

来源:https://www.cnblogs.com/htdaydayup/archive/2019/02/11/10360708.html
-Advertisement-
Play Games

隨著大數據時代的來臨,物聯網的日益發展,原先的 SCADA 系統本身也在求新求變,從最開始的專業電腦和操作系統,到通用電腦和相關軟體,再到現在基於 HTML5 Canvas 的新型組態開發,其應用的範圍也從最初的電力,逐漸發展到應用於電力、冶金、化工、自動化群控等等大部分工控場景中,本文是將傳統... ...


基於 HTML5 Canvas 的智能安防 SCADA 巡邏模塊

前言

隨著大數據時代的來臨,物聯網的日益發展,原先的 SCADA 系統本身也在求新求變,從最開始的專業電腦和操作系統,到通用電腦和相關軟體,再到現在基於 HTML5 Canvas 的新型組態開發,其應用的範圍也從最初的電力,逐漸發展到應用於電力、冶金、化工、自動化群控等等大部分工控場景中,本文是將傳統安防結合 SCADA 系統,製作的智能安防中的巡邏監控模塊,主要採用 HT for Web 作為開發環境。

image

代碼實現

繪製背景色

首先結合 addBottomPainter() 在 HT 拓撲圖形組件 graphView 底層上使用 Canvas 畫筆進行繪製背景色。

// 畫背景
graphView.addBottomPainter(function (g) {
    g.save();
    g.beginPath();
    g.rect(0, 0, 2000, 1600);
    g.fillStyle = "rgb(39,48,74)";
    g.fill();
    g.restore();
});

載入基礎圖元

然後將視圖背景、人員視角俯視圖和提示通過 setImage() 在拓撲組件 graphView 上以圖元的形式載入出來,用 setScale() 控製圖元的縮放比例使視圖更具有真實感,用 setAnchor() 更改錨點,以便旋轉時有視角旋轉的感覺,最後通過加入 dataModel 的方式使圖元載入到拓撲組件 graphView 上,其設計原理是 Object View Mapping (OVM),通過統一的模型驅動視圖組件。

image

// 載入人物基礎圖元
var people = new ht.Node();
// 設置 Tag
people.setTag(id + 'People');
people.setImage('people');
// 設置縮放倍數
people.setScale(10, 10);
people.setPosition(100, 100);
// 設置錨點
people.setAnchor(.5, .2);
dataModel.add(people);

設置人員屬性

將巡邏路徑和相關人員屬性以對象形式設置,其中巡邏路徑按照點的形式保存在 points ,其中的轉折邏輯通過 segments 進行控制,其規則如下:

  • 1: moveTo,占用1個點信息,代表一個新路徑的起點
  • 2: lineTo,占用1個點信息,代表從上次最後點連接到該點
  • 3: quadraticCurveTo,占用2個點信息,第一個點作為曲線控制點,第二個點作為曲線結束點
  • 4: bezierCurveTo,占用3個點信息,第一和第二個點作為曲線控制點,第三個點作為曲線結束點
  • 5: closePath,不占用點信息,代表本次路徑繪製結束,並閉合到路徑的起始點

image

var people4 = {
    id: '437904',
    source: {x: 270,y: 352,},
    target: {x: 270,y: 352,},
    points: [
       {x: 262,y: 220,},{x: 380,y: 228,},{x: 509,y: 234,},{x: 509,y: 316,},{x: 513,y: 452,},{x: 382,y: 454,},{x: 278,y: 454,}
    ],
    segments: [1, 3, 3, 3, 3]
};

獲得路徑上點和角度

通過 getPercentPosition() 和 getPercentAngle() 獲得路徑 edge 上的點和角度,從而可以通過 setPosition() 控制基礎圖元位置,再加上動畫函數 startAnim() , 從而達到在路徑上進行運動旋轉的效果。

var position = graphView.getPercentPosition(data, i);
var angle = graphView.getPercentAngle(data, i) - Math.PI * .5;

根據路線轉角大小控製圖元在轉角停留時間

image

// 轉角大小
var rotationAngle = Math.abs((people.getRotation() - angle) % (Math.PI * 2));
// 通過轉角大小判斷是否需要動畫
if (rotationAngle > .2) {
    // 判斷轉角是否大於180度
    if (rotationAngle > Math.PI) {
        if (people.getRotation() - angle < 0) {
            people.setRotation(angle + (Math.PI * 2 - rotationAngle));
        } else {
            people.setRotation(angle - (Math.PI * 2 - rotationAngle));
        }
    }

計算路徑總距離,控制行進速度

通過路徑上各個點的距離計算出總路徑然後按距離控制控制路徑百分比獲得相應的點和旋轉角度。

// 計算路徑長短
var distance = 0;
for (let i = 0; i + 1 < path.points.length; i++) {
    var x = path.points[i + 1].x - path.points[i].x;
    var y = path.points[i + 1].y - path.points[i].y;
    var pathDistance = Math.sqrt(x * x + y * y);
    distance += pathDistance;
}

增加監聽顯示標記ID

image

var preMoveData, preClickData;
// 增加滑鼠移動標記顯示
graphView.getView().addEventListener('mousemove', (e) => {
    const data = graphView.getDataAt(e);
    if (preMoveData === preClickData && (!data || !data.mark)) return;
    if (!data || !data.mark) {
        preMoveData && preMoveData.mark && preMoveData.mark.s('2d.visible', false);
        return;
    }
    data.mark.s('2d.visible', true);
    preMoveData = data;
});
// 增加滑鼠點擊標記顯示
graphView.mi(e => {
    if (e.kind === 'clickData' && e.data.mark) {
        preClickData && preClickData.mark.s('2d.visible', false);
        e.data.mark.s('2d.visible', true);
        if (preClickData === e.data) {
            e.data.mark.s('2d.visible', false);
            preClickData = undefined;
        }else {
            preClickData = e.data;
        }
    }
})

總結

HT for Web 除了適用於電信網路拓撲和設備管理,以及電力、燃氣等工業自動化 SCADA 領域,也可以將 SCADA 和其他傳統行業相結合,將可視化和組態化的特色充分的應用於其他領域,除了此 Demo 中的智能安防,也可以應用於像是智能樓宇等等其他領域。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 配置資料庫表首碼 "ABP踩坑記錄 目錄" 本篇其實和ABP關係並不大,主要是EF Core的一些應用 . 。 起因 支持資料庫表首碼應該是很多應用中比較常見的功能,而在ABP中並沒直接提供這一功能,所以在我們的應用中,我們轉而藉助EF Core的配置來實現資料庫表首碼的配置。 解決方案 這裡我結合 ...
  • 介紹 新年之際,給大家介紹個我自己開發的ORM類庫Insql。TA是一個輕量級的.NET ORM類庫 . 對象映射基於Dapper , Sql配置靈感來自於Mybatis。簡單優雅性能是TA的追求。 "github" | "gitee" 閑聊 以下可跳過 : ) 自己為什麼會開發Insql? 1. ...
  • 之前獲取上傳文件都是使用Request.Form.Files獲取,直到這次改成定義形參 IFormFile時才遇到這個問題。 不知道這是不是微軟的一個bug? 解決方案有兩種 方案一:去除[ApiController]這個Attribute 方案二:在[FromForm]里添加Name屬性:[Fro ...
  • 音效系統 1.個人思路 1.情景假設 一天,小明想聽歌。於是,他拿起手機,找到音樂播放軟體,選擇歌曲,按下播放鍵,聽到了想聽的歌 2.過程分析 1 小明想聽歌 聽歌的對象,歌曲信息接收者 2 打開音樂播放軟體 播放音樂的對象,音效源 3 選擇歌曲 選擇的數據,音效資源 3.實現思路 AudioLis ...
  • 一、screen安裝 yum install screen #CentOS安裝 sudo apt-get install screen #ubuntu安裝 二、screen常用命令 screen -S mariadb #新建一個叫mariadb的session screen -r mariadb # ...
  • Homebrew 是 MacOSX 上的軟體包管理工具。 安裝 檢查是否安裝正確 維護 升級 安裝軟體包 卸載軟體包 其他命令 參考 brew官方網站 Mac入門(三)使用brew安裝軟體 ...
  • 在 Termianl ...
  • 1.問題描述 select deptno ,avg(sal) from emp where count(*)>3 group by deptno; 在where 句中使用聚合函數count(*),報出錯誤:ORA-00934: group function is not allowed here 那 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...