摘要:畫布的基本布局如下圖實現(xiàn)過程如下先定義畫圖的容器的尺寸定義元素設(shè)置再通過添加一個元素,這段代碼添加了兩個元素,為了比較和添加第一個添加第二個,并把這個元素賦值給變量定義要畫的曲線的數(shù)組將成比例縮放軸縮放使用中的函數(shù)進行縮放,因為是線
d3畫布的基本布局如下圖
var width = 500, height = 200, margin = { left: 50, top: 30, right: 20, bottom: 20 }, g_width = width - margin.left - margin.right, g_height = height - margin.top - margin.bottom;定義svg元素
var svg = d3.select("#container") .append("svg") // 設(shè)置width,height .attr("width", width) //attribute .attr("height", height)再通過append()添加一個g元素,這段代碼添加了兩個g元素,為了比較select和selectAll
d3.select("svg").append("g")//添加第一個g var g = d3.select("svg") .append("g") //添加第二個g,并把這個元素賦值給變量g .attr("transform", "translate(" + margin.left + "," + margin.top + ")") //定義要畫的曲線的數(shù)組data[] var data = [2, 12, 3, 4, 5, 6, 22]將g成比例縮放
var scale_x = d3.scale.linear() //使用d3中的scale函數(shù)進行縮放,因為是線性的所以使用linear .domain([0, data.length - 1]) //domain定義輸入范圍 .range([0, g_width]) //range()定義輸出范圍
var scale_y = d3.scale.linear() .domain([0, d3.max(data)]) //domain定義輸入范圍 .range([0, g_height]) //range()定義輸出范圍通過d3下面的svg下面的line()實現(xiàn)line_generator函數(shù)
var line_generator = d3.svg.line() .x(function(d, i) { return scale_x(i); }) //x坐標點的值為data數(shù)組的下標,參數(shù)d表示傳進來的數(shù)據(jù),i表示下標 .y(function(d) { return scale_y(d) }) //y坐標的值為數(shù)組中實際的每一項的值 .interpolate("cardinal") //讓線條變得光滑,不是折線而是光滑的曲線 // d3.select("g") // .append("path") // .attr("d", line_generator(data)) //通過d屬性值,添加line_generator函數(shù) // // 其實d就是 path-data 的縮寫,d= "M"當頁面有多個相同元素,select只能選擇符合條件的第一個元素,想要選擇其中某一個指定的元素,可以把那個元素賦給一個變量,然后使用變量名去實現(xiàn) 如下所示,g表示上面賦值的那個變量g,而不是標簽
g.append("path").attr("d", line_generator(data)) //通過d屬性值,添加line_generator函數(shù) // 其實d就是 path-data 的縮寫,d= "M0,2Q0.7999999999999999,11.9,1,12C1.3,12.15,1.7,4.2,2,3S2.7,3.7,3,4S3.7,4.7,4,5S4.7,3.4499999999999997,5,6Q5.2,7.7,6,22"沒有縮放的初始圖 加縮放后的效果 縮放代碼:將
var scale_x = d3.scale.linear() //使用d3中的scale函數(shù)進行縮放,因為是線性的所以使用linear .domain([0, data.length - 1]) //domain定義輸入范圍 .range([0, g_width]) //range()定義輸出范圍 var scale_y = d3.scale.linear() .domain([0, d3.max(data)]) //domain定義輸入范圍 .range([0, g_height]) //range()定義輸出范圍給path設(shè)置css后的樣子 css代碼:
path { /*定義畫出的線條無填充,*/ fill: none; /* 線顏色*/ stroke: brown; /*線條粗細*/ stroke-width: 2; }設(shè)置平滑之后的樣子
.interpolate("cardinal") //讓線條變得光滑,不是折線而是光滑的曲線
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/90238.html
摘要:畫布的基本布局如下圖實現(xiàn)過程如下先定義畫圖的容器的尺寸定義元素設(shè)置再通過添加一個元素,這段代碼添加了兩個元素,為了比較和添加第一個添加第二個,并把這個元素賦值給變量定義要畫的曲線的數(shù)組將成比例縮放軸縮放使用中的函數(shù)進行縮放,因為是線 d3畫布的基本布局如下圖 showImg(https://segmentfault.com/img/bVZMKl?w=759&h=410); 實現(xiàn)過程如下...
摘要:實現(xiàn)這樣一個曲線動畫可以點擊這里查看在線演示在寫代碼之前,先了解一下什么是貝塞爾曲線吧。繪制二次貝賽爾曲線路徑這樣就完成了基本的繪制二次貝塞爾曲線的方法了。 我的github博客地址 https://github.com/hujiulong/... 前言 在前端開發(fā)中,貝賽爾曲線無處不在: 它可以用來繪制曲線,在svg和canvas中,原生提供的曲線繪制都是使用貝賽爾曲線 它也可以...
摘要:本人也做過一些數(shù)據(jù)可視化相關(guān)的產(chǎn)品,下面聊聊對數(shù)據(jù)可視化的一些思考。這也是數(shù)據(jù)可視化最麻煩的一直,一般我們借助的地圖,或者百度地圖,高德地圖等來開發(fā),其實百度地圖也出了個地圖可視化的庫,展示效果沒有好。。。。 最近幾年隨著大數(shù)據(jù)的興起,以及瀏覽器性能的提升,數(shù)據(jù)可視化成為了一個熱點,前端也冒出來了很多數(shù)據(jù)可視化的崗位。本人也做過一些數(shù)據(jù)可視化相關(guān)的產(chǎn)品,下面聊聊對數(shù)據(jù)可視化的一些思考。...
摘要:本人也做過一些數(shù)據(jù)可視化相關(guān)的產(chǎn)品,下面聊聊對數(shù)據(jù)可視化的一些思考。這也是數(shù)據(jù)可視化最麻煩的一直,一般我們借助的地圖,或者百度地圖,高德地圖等來開發(fā),其實百度地圖也出了個地圖可視化的庫,展示效果沒有好。。。。 最近幾年隨著大數(shù)據(jù)的興起,以及瀏覽器性能的提升,數(shù)據(jù)可視化成為了一個熱點,前端也冒出來了很多數(shù)據(jù)可視化的崗位。本人也做過一些數(shù)據(jù)可視化相關(guān)的產(chǎn)品,下面聊聊對數(shù)據(jù)可視化的一些思考。...
閱讀 2781·2021-10-14 09:42
閱讀 839·2021-10-11 10:57
閱讀 785·2019-08-30 15:54
閱讀 1927·2019-08-30 13:50
閱讀 1693·2019-08-30 11:19
閱讀 943·2019-08-29 12:38
閱讀 1436·2019-08-26 11:51
閱讀 1402·2019-08-26 10:48