基於 H5 Canvas 及 3D 組態實現樓宇新風系統

来源:https://www.cnblogs.com/htdaydayup/archive/2020/02/24/12330936.html
-Advertisement-
Play Games

現如今,新型冠狀病毒疫情牽動著每一個人的神經,每天起床後的第一件事就是打開疫情地圖,看看最新的疫情數據。如何防控對於普通居民來說,減少外出,註意衛生等都是有效措施,另外保持室內通風換氣也是至關重要的,無論是飛沫傳播還是流傳的氣溶膠傳播,環境密閉導致空氣渾濁,易造成病菌滋生,增加人體感染疾病的風險。勤... ...


 

 

前言

現如今,新型冠狀病毒疫情牽動著每一個人的神經,每天起床後的第一件事就是打開疫情地圖,看看最新的疫情數據。

http://www.hightopo.com/demo/coronavirus/

如何防控對於普通居民來說,減少外出,註意衛生等都是有效措施,另外保持室內通風換氣也是至關重要的,無論是飛沫傳播還是流傳的氣溶膠傳播,環境密閉導致空氣渾濁,易造成病菌滋生,增加人體感染疾病的風險。勤通風可有效地排除微生物等有害物質含量,保障我們呼吸環境的健康。

智能新風系統,不受寒冷的天氣或是戶型限制,現已被很多智能樓宇、智能家居廣泛利用,今天就帶大家一起打造一個超級實用新風監控系統。

https://hightopo.com/demo/smart-building-wind-system/

代碼實現

首先,我們還是要對整體界面做一下基礎設置,這樣養成好習慣,避免落下不容易發現的小問題:

gv.getSelectWidth = function() { return 0 } // 隱藏選中邊框
gv.setMovableFunc(function() { return false }) // 禁止圖元移動
gv.handleScroll = function() {} // 禁止滑鼠縮放
gv.handlePinch = function() {} // 禁止 touch 下雙指縮放
gv.setPannable(false) // 禁止平移
gv.setRectSelectable(false) // 禁止框選
gv.setScrollBarVisible(false) // 隱藏滾動條
window.document.oncontextmenu = function() { return false } // 全局設置右鍵菜單禁用

然後打開圖紙,我們需要將裡面的模塊封裝,使整體結構更加整齊且有利於我們後續的驅動和復用性。這裡就不做過多介紹了。下麵我們一起來從頭看看每一部分的實現過程。

風格切換功能為了匹配不同人所中意的顏色風格,這裡我們做了一個稍稍偏亮綠的護眼色,來面對長期使用顯示屏的人群。圖標的旋轉應用了動畫函數:

ht.Default.startAnim({
    duration: 500,
    easing: function(t) { return t },
    action: function(v, t) {
        data.a('rotation', (oldValue + (newValue + oldValue) * v) * Math.PI / 180)
    }
})

http://www.hightopo.com/guide/guide/core/beginners/ht-beginners-guide.html#ref_animation

duration 是動畫周期毫秒數,HT 將在指定時間周期內完成動畫,easing 參數用於通過數學公式控制動畫,如勻速變化、先慢後快等效果。action 函數的第一個參數 v 代表通過 easing(t) 函數運算後的值,t 代表當前動畫進行的進度 [0~1],一般屬性變化根據 v 參數進行。我們通過對圖元定義的 'rotation' 屬性值來驅動它的旋轉一周效果,用起始值與目標值進行計算並轉化弧度制。顏色的切換以及懸浮穿的顯隱都是把所涉及到的元素的相關屬性做處理。

這其中每一處可交互的地方都加上滑鼠 hover 效果,增強交互體驗感:

view.setCursor('pointer')
view.setCursor('default')

時間和日期用了格式轉化插件,加個定時器去修改所對應的文本屬性來使其動態變化:

background.timer = setInterval(function() {
    background.a('time', DateUtil.format(new Date(), 'HH:mm:ss'))
    background.a('date', DateUtil.format(new Date(), 'yyyy.MM.dd'))
    if (!background.dm()) {
        clearInterval(background.timer)
    }
}, 1000)

接下來是左側的一塊智能數據監控面板,滑鼠懸浮時會在關聯的設備上面顯示一個懸浮氣泡來對應,並且數據會跳動:

數據我們就不多說了,demo 中採用了一些隨機數去動態來展示應用性,那麼這些氣泡是怎麼實現的呢:

我們要先構思好實現的方式,這裡我們先看一下氣泡的動效,我們將氣泡單獨封裝為一個圖標,然後調整好光環的位置和大小,綁定橫縮放、縱縮放、透明度,基本就完成了,我們控制它的橫縱縮放來達到擴大的效果,然後再調整透明來實現消散的效果,且迴圈播放:

function bubbleAnim() {
    ht.Default.startAnim({
        duration: 1000,
        easing: function(t) { return t },
        action: function(v, t) {
            bubble.a('opacity', 1 - v) // 透明度
            bubble.a('scaleX', v) // 橫縮放
            bubble.a('scaleY', v) // 縱縮放
        },
        finishFunc: function() {
            bubbleAnim()
        }
    })
}
bubbleAnim()

關於它的位置變化我們是這樣設計的,因為界面上只會同時出現一個,所以我們圖紙上只需要一個氣泡圖標就可以了,通過所關聯的不同的設備圖標的位置,來動態改變氣泡的位置,然後通過顯示隱藏來讓它在某位置出現或隱藏:

view.dm().each(function(datas) {
    if (datas.getDisplayName() === '送風機設備' && datas.getParent().s('2d.visible')) {
        bubble.p(datas.p().x, datas.p().y - 50)
        bubble.s('2d.visible', true)
    }
})

因為下麵還有一個系統切換菜單,所以多加了一步判斷來保護一下。那就直接來說一下這個功能:

風機的轉動是旋轉角度屬性,風向流動是根據裁切方向改變了裁切比例,都是基於動畫來實現,參考我們之前提到過的方法,這裡不做過多贅述。在這個菜單中,其實也應用到了動畫,比如其整體的一個上下滑動,但是有個前提,我們要註意給圖標設置好裁切 clip 屬性,這樣下麵的部分就相當於隱藏了,滑動上來才能出現。因為在選定系統後,名稱也會變化,所以我們不能直接用這個菜單,而是平時將菜單隱藏,只顯示名稱,點擊後再它倆的狀態再反過來,然後再執行我們的操作就不會衝突了:

// 文字隱藏
data.a('textV', false)
// 菜單顯示
data.a('menuV', true)
// 框上移
ht.Default.startAnim({
    duration: 200,
    easing: function(t) { return t },
    action: function(v, t) {
        data.a('frameP', [0.13932, 71.90718 + (0.00079 - 71.90718) * v, 591.86062, 44.88772])
    }
})
// 菜單上移
ht.Default.startAnim({
    duration: 200,
    easing: function(t) { return t },
    action: function(v, t) {
        data.a('menuP', [228.19231, 80.78752 + (8.88113 - 80.78752) * v, 135, 99])
    }
})

當我們選擇一個選項後不要忘記切換狀態和更新名稱並且將氣泡隱藏掉,這種小 bug 一定要註意。至於切換系統我們只需在前期準備過程中把同一系統的圖元放在一個組裡,然後我們在選擇時控制各組的顯示和隱藏就好了,對於 2D 圖標來說我們來對它的 '2d.visible' 屬性選擇性的賦予 true / false 布爾值就行了。

總結

整個新風系統基本搭建完成了,我們可以把它廣泛應用於各種不同樓宇的智能數字可視化監控。未來將會有更多的智慧 + 數據可視化等著我們,邁入新的信息化時代要掌握強而有力的技術!

 

HT for Web :(http://www.hightopo.com/demos/cn-index.html)

 


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

-Advertisement-
Play Games
更多相關文章
  • 前言 我們知道Vue框架劇本雙向數據綁定功能,在我們使用方便的同時,還有一些細節問題我們並不知道,接下來一起探討一些吧 雙向數據綁定 js變數改變影響頁面 頁面改變影響js變數 Vue2是如何做到數據綁定的 以上需要說的就是: Vue中data函數返回的對象,會經過層層遍歷,最後將所有的對象通過以上 ...
  • <router-view> 是基本的動態組件,所以我們可以用 <transition> 組件給它添加一些過渡效果: <transition name="slide-left" mode="out-in"> <router-view /> </transition> 過渡的類名 在進入/離開的過渡中, ...
  • 在CSS中,根據元素顯示模式的不同元素標簽被分為了兩類:行內元素(inline-level)、塊級元素(block-level)。 1,首先介紹什麼是行內元素,什麼又是塊級元素? 1.1,行內元素就是不會獨占一行的元素,例如:span buis strong em ins del等 1.2,塊級元素 ...
  • 一、CSS偽元素 CSS 偽元素用於向某些選擇器設置特殊效果。 偽元素的用法如下: selector:pseudo-element {property:value;} CSS 類也可以和偽元素搭配使用 selector.class:pseudo-element {property:value;} 二 ...
  • 參考 博客 1、 "中高級前端面試題(萬字長文)" 2、 "大前端弔打面試官系列" 資料 1、 "HTML 5 教程" 2、 "CSS3 教程" 3、 "JavaScript 教程" 收費小冊 "前端面試之道" 註:某大佬這本收費小冊乾貨很多,有些參考其中的問題,就不列答案了。 寫在前面的話 因為一 ...
  • RX.js變化 RxJS 6主要用於Angular應用程式,從Angular 6開始,它是一個強制依賴。 與RxJS版本5相比,RxJS 6(或更高版本)引入了兩個重要更改: 1. import的導入結構發生變化 // 以前: import { Observable } from 'rxjs/Obs ...
  • 一、Overview angular 入坑記錄的筆記第二篇,介紹組件中的相關概念,以及如何在 angular 中通過使用組件來完成系統功能的實現 對應官方文檔地址: "顯示數據" "模板語法" "用戶輸入" "組件之間的交互" "管道" "生命周期鉤子" 配套代碼地址: "angular pract ...
  • 簡介 WebSocket 使得客戶端和伺服器之間的數據交換變得更加簡單, 允許服務端主動向客戶端推送數據。 在 WebSocket API 中,瀏覽器和伺服器只需要完成一次握手,兩者之間就直接 可以創建持久性的連接,併進行雙向數據傳輸。 現在,很多網站為了實現 推送技術 ,所用的技術都是 Ajax ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...