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
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...