d3.js製作蜂巢圖錶帶動畫效果

来源:https://www.cnblogs.com/eagle1098/archive/2019/07/11/11169856.html
-Advertisement-
Play Games

以上是效果圖,本圖表使用d3.js v4製作。圖表主要功能是在六邊形格子中顯示數據,點擊底部圖標可以切換指定格子高亮顯示,圖表可以隨瀏覽器任意縮放。 1.圖表的主體結構是由正六邊形組成,使用d3生成六邊形可以使用d3-hexbin.js,生成六邊形比較方便,只要給定中心點坐標和半徑即可生成六邊形路徑 ...


  以上是效果圖,本圖表使用d3.js v4製作。圖表主要功能是在六邊形格子中顯示數據,點擊底部圖標可以切換指定格子高亮顯示,圖表可以隨瀏覽器任意縮放。

  1.圖表的主體結構是由正六邊形組成,使用d3生成六邊形可以使用d3-hexbin.js,生成六邊形比較方便,只要給定中心點坐標和半徑即可生成六邊形路徑,例如:

var r = 10; // 六邊形半徑
var pos = [[5,5],[10,10]]; // 六邊形中心點坐標數組
var hexbin = d3.hexbin() // 使用hexbin.hexagon()即可生成路徑
      .radius(r);
var bins = hexbin(pos); // 得到生成後的六邊形中心點坐標數組

2.圖表的主體使用了高斯模糊濾鏡,使畫面表現出發光效果,背景高亮顏色使用了顏色漸變濾鏡。在svg中使用濾鏡,必須定義在defs中。

高斯模糊濾鏡:

// 創建defs
var defs = svg.append("defs");
// 添加模糊濾鏡
var filterBlur = defs.append('filter')
 .attr('id', 'filterBlur')
 .attr('x', -1.2)
 .attr('y', -1.2)
 .attr('width', 4)
 .attr('height', 4);
// 添加輔助濾鏡
filterBlur.append('feOffset')
 .attr('result', 'offOut')
 .attr('in', 'SourceGraphic')
 .attr('dx', 0)
 .attr('dy', 0);
// 添加模糊濾鏡
filterBlur.append('feGaussianBlur')
 .attr('result', 'blurOut')
 .attr('in', 'SourceGraphic')
 .attr('stdDeviation', 2);
// 添加輔助濾鏡
filterBlur.append('feBlend')
 .attr('in', 'SourceGraphic')
 .attr('in2', 'blurOut')
 .attr('mode', 'multiply');

重點說一下最後的feBlend,它的作用是把濾鏡效果和原圖混合起來。使用濾鏡的話,直接給元素添加style('filter', 'url(#filterBlur)')即可。

背景高亮使用了顏色漸變濾鏡:

// 添加放射性變換,生成空心填充顏色
var warnBg = defs.append("radialGradient")
        .attr("id", "bg")
        .attr('cx', 0.5)
        .attr('cy', 0.5)
        .attr('r', 0.5);
// 添加顏色
warnBg.append('stop')
        .attr('offset', 0.5)
        .attr('style', 'stop-color:rgb(200,200,200);stop-opacity:0.4');
warnBg.append('stop')
        .attr('offset', 1)
        .attr('style', 'stop-opacity:1;stop-color:rgb(123,123,123)');

其中涉及到的關鍵性技術就是這些,其他方面只要使用通用的d3方法就可實現。

需要註意的是,程式的結構要預先規劃好,最好把主要的功能模塊放在單獨一個函數中,方便調用和後期修改。

如果大家有什麼想法或意見可以交流一下。


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

-Advertisement-
Play Games
更多相關文章
  • 編譯和解釋 var a = 0; console.log(a); var b = "abc"; 編譯: 一次性把代碼轉換成 CPU 可以看懂的語言,一行一行執行; 解釋:一行一行解析,解析一行執行一行; C、 C++、 C 、 Java 屬於編譯型語言。 在速度方面編譯型語言更快,所以 JavaSc ...
  • 1、 什麼是路由? 註意:作為vue的插件,需要單獨引入js文件,且必須在vue.js之後引入。 <router-link to=“跳轉路徑”></router-link>:該標簽會預設被解析成<a>標簽 <router-view></router-view>:該標簽用於展示組件中的內容,是路由的出 ...
  • 一半出現於view嵌套view的情況,當父子控制項的點擊都設置為 bindtap的時候,會出現點擊觸發了父view的點擊監聽。 要想父子view各監聽到自己的實踐,需要將子view的點擊改為catchtap ,並添加:hover-stop-propagation='true' , 父容器繼續用bind ...
  • 序號 類目 關鍵詞 操作 {% f... ...
  • 今天遇到了這個方法,便去度娘瞭解了下 函數功能:該函數在屬於當前線程的指定視窗里設置滑鼠捕獲。一旦視窗捕獲了滑鼠,所有滑鼠輸入都針對該視窗,無論游標是否在視窗的邊界內。同一時刻只能有一個視窗捕獲滑鼠。如果滑鼠游標在另一個線程創建的視窗上,只有當滑鼠鍵按下時系統才將滑鼠輸入指向指定的視窗。 setCa ...
  • 需求 在開發vue的項目中有遇到了這樣一個需求:一個視頻列表頁面,展示視頻名稱和是否收藏,點擊進去某一項觀看,可以收藏或者取消收藏,返回的時候需要記住列表頁面的頁碼等狀態,同時這條視頻的收藏狀態也需要更新, 但是從其他頁面進來視頻列表頁面的時候不緩存這個頁面,也就是進入的時候是視頻列表頁面的第一頁 ...
  • 一、什麼是組件? 組件 (Component) 是 Vue.js 最強大的功能之一。組件可以擴展 HTML 元素,封裝可重用的代碼。在較高層面上,組件是自定義元素,Vue.js 的編譯器為它添加特殊功能。在有些情況下,組件也可以表現為用 is 特性進行了擴展的原生 HTML 元素。 <body> < ...
  • 本文介紹TypeScript中泛型的概念,以簡單直白的方式,向那些不瞭解此概念,但渴望在工作中使用它的開發者,提供入門指導。 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...