canvas圖表(4) - 散點圖

来源:http://www.cnblogs.com/edwardloveyou/archive/2017/11/24/7890013.html
-Advertisement-
Play Games

原文地址: "canvas圖表(4) 散點圖" 今天開始完成散點圖,做完這一節,我的canvas圖表系列就算是完成了,畢竟平時最頻繁用到的就是這幾類圖表了:柱狀,折線,餅圖,散點。經過編寫canvas圖表項目的實踐,我對canvas也做到了比較深入的理解,也是越來越喜歡電腦圖形相關的知識了。接下來 ...


原文地址:canvas圖表(4) - 散點圖
今天開始完成散點圖,做完這一節,我的canvas圖表系列就算是完成了,畢竟平時最頻繁用到的就是這幾類圖表了:柱狀,折線,餅圖,散點。經過編寫canvas圖表項目的實踐,我對canvas也做到了比較深入的理解,也是越來越喜歡電腦圖形相關的知識了。接下來canvas的學習會告一段落,我會繼續接著學習webGL,同時學習使用blender建立簡單的3D模型。

本節效果請看:散點氣泡圖https://edwardzhong.github.io/sites/demo/dist/chartpoint.html
it

經過學習之前的其他圖表後,就會發現很多地方都是相似的,只是具體的細節有些區別,所以這次主要就是講解散點圖不同的部分,功能點包括:

  1. 組織數據;
  2. 畫面繪製;
    3. 數據動畫的實現;
    4. 位移坐標繪製
    5. 滑鼠事件的處理。

使用方式

用法基本跟柱狀圖和折線圖類似,數據使用的是Echart的樣例上的,但是它的數據格式太反人道了,我重新組織了數據格式,這樣更符合我們的使用習慣。

    var con=document.getElementById('container');
    var point =new Point(con);
    point.init({
        title:'1990 與 2015 年各國家人均壽命與 GDP',
        xAxis:{
            name:'GDP',
            data:[10000,20000,30000,40000,50000,60000,70000],
            formatter:'$ {value}'
        },
        yAxis:{
            name:'AGE'
        },
        desc:{
            xVal:'gdp',
            yVal:'age',
            num:'number'
        },
        series:[{
            name:'1990',
            data:[
                {xVal:28604,yVal:77,num:17096869,name:'Australia'},
                {xVal:31163,yVal:77.4,num:27662440,name:'Canada'},
                {xVal:1516,yVal:68,num:1154605773,name:'China'},
                {xVal:13670,yVal:74.7,num:10582082,name:'Cuba'},
                {xVal:28599,yVal:75,num:4986705,name:'Finland'},
                {xVal:29476,yVal:77.1,num:56943299,name:'France'},
                {xVal:31476,yVal:75.4,num:78958237,name:'Germany'},
                {xVal:28666,yVal:78.1,num:254830,name:'Iceland'},
                {xVal:1777,yVal:57.7,num:870601776,name:'India'},
                {xVal:29550,yVal:79.1,num:122249285,name:'Japan'},
                {xVal:2076,yVal:67.9,num:20194354,name:'North Korea'},
                {xVal:12087,yVal:72,num:42972254,name:'South Korea'},
                {xVal:24021,yVal:75.4,num:3397534,name:'New Zealand'},
                {xVal:43296,yVal:76.8,num:4240375,name:'Norway'},
                {xVal:10088,yVal:70.8,num:38195258,name:'Poland'},
                {xVal:19349,yVal:69.6,num:147568552,name:'Russia'},
                {xVal:10670,yVal:67.3,num:53994605,name:'Turkey'},
                {xVal:26424,yVal:75.7,num:57110117,name:'United Kingdom'},
                {xVal:37062,yVal:75.4,num:252847810,name:'United States'}]
            },
            {
            name:'2015',
            data:[
                {xVal:44056,yVal:81.8,num:23968973,name:'Australia'},
                {xVal:43294,yVal:81.7,num:35939927,name:'Canada'},
                {xVal:13334,yVal:76.9,num:1376048943,name:'China'},
                {xVal:21291,yVal:78.5,num:11389562,name:'Cuba'},
                {xVal:38923,yVal:80.8,num:5503457,name:'Finland'},
                {xVal:37599,yVal:81.9,num:64395345,name:'France'},
                {xVal:44053,yVal:81.1,num:80688545,name:'Germany'},
                {xVal:42182,yVal:82.8,num:329425,name:'Iceland'},
                {xVal:5903,yVal:66.8,num:1311050527,name:'India'},
                {xVal:36162,yVal:83.5,num:126573481,name:'Japan'},
                {xVal:1390,yVal:71.4,num:25155317,name:'North Korea'},
                {xVal:34644,yVal:80.7,num:50293439,name:'South Korea'},
                {xVal:34186,yVal:80.6,num:4528526,name:'New Zealand'},
                {xVal:64304,yVal:81.6,num:5210967,name:'Norway'},
                {xVal:24787,yVal:77.3,num:38611794,name:'Poland'},
                {xVal:23038,yVal:73.13,num:143456918,name:'Russia'},
                {xVal:19360,yVal:76.5,num:78665830,name:'Turkey'},
                {xVal:38225,yVal:81.4,num:64715810,name:'United Kingdom'},
                {xVal:53354,yVal:79.1,num:321773631,name:'United States'}]
        }]
    });

數據動畫

清除屏幕,然後重繪,實現動畫效果。實現了氣泡半徑的縮放和氣泡的位移動畫,為了更加的美觀,氣泡使用了徑向漸變createRadialGradient和陰影shadow,之前已經介紹過,不再詳述。要註意的是,要謹慎使用陰影特性,因為它挺消耗性能,數據量一大,會卡的不要不要的

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

-Advertisement-
Play Games
更多相關文章
  • HTML 中的預留字元必須被替換為字元實體。 HTML 實體 在 HTML 中,某些字元是預留的。 在 HTML 中不能使用小於號(<)和大於號(>),這是因為瀏覽器會誤認為它們是標簽。 如果希望正確地顯示預留字元,我們必須在 HTML 源代碼中使用字元實體(character entities)。 ...
  • ECMAScript 6.0(簡稱 ES6)是 JavaScript 語言的下一代標準,它於2015 年 6 月正式發佈。ECMAScript 和 JavaScript 的關係是,前者是後者的規格,後者是前者的一種實現。ECMAScript實現還有Jscript和ActionScript。 ...
  • 最近做一個自定義視覺效果的Switch組件,用到了 input:radio 和 label,併在label里用偽元素 :before 模擬狀態的切換效果。 但是同事評審的時候說可以不用label,直接用input的微元素就可以實現。之前一直以為input這樣的自閉合元素沒有偽元素,做了個測試看一下到 ...
  • 最近幾年web前端開發領域最熱的話題當屬HTML5,HTML5從根本上改變了開發商開發web應用的方式,從桌面瀏覽器到移動應用,這種語言和標準都正在影響並將繼續影響著各種操作平臺。 ...
  • 前言 一直在學習 javascript,也有看過《犀利開發 Jquery 內核詳解與實踐》,對這本書的評價只有兩個字犀利,可能是對 javascript 理解的還不夠透徹異或是自己太笨,更多的是自己不擅於思考懶得思考以至於裡面說的一些精髓都沒有太深入的理解。 鑒於想讓自己有一個提升,進不了一個更加廣 ...
  • 轉載:http://blog.csdn.net/piaoxuan1987/article/details/8541839 equest.getRealPath() 這個方法已經不推薦使用了,代替方法是: request.getSession().getServletContext().getReal ...
  • 目錄 前言&介紹 安裝Pomelo 創建項目並啟動 創建項目 項目結構說明 啟動 測試連接 聊天伺服器 新建gate和chat伺服器 配置master.json 配置servers.json 配置adminServer.json 解決伺服器分配問題 實現gate.gateHandler.queryE ...
  • 什麼是標記語言? 標記語言是一種用語義上可區分文本的方式來註釋文檔的系統。這個想法和術語是從紙上手稿的“標記”,即編輯們的修改指示演變而來的,傳統上用藍色鉛筆寫在作者的手稿上。 標記語言的歷史? 標記來源於傳統的標記手稿的出版實踐。當需要出版一部手稿的時候,首先手稿被交給“標記人”,他們在手稿上標記 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...