可視化D3.js庫(6)-比例尺

D3.js庫-6-比例尺的使用

比例尺在D3中是一個非常實用的工具,可以這樣理解比例尺:\color{red}{一種一一映射}的關(guān)系握童,從domain映射到range醇王。因為在建立比例尺的過程中會經(jīng)常使用到兩個函數(shù):domain()和range()。本文中介紹兩種常用的比例尺

  • 線性比例尺scaleLinear

  • 序數(shù)比例尺scaleOrdinal

線性比例尺scaleLinear

在線性比例尺中慎式,domainrange都是連續(xù)變化的抹缕。關(guān)系類似于線性函數(shù)

image

代碼解釋:

var scaleLinear = d3.scaleLinear()
                    .domain([min,max])
                    .range([0,300]);

表示將數(shù)據(jù)從[0.9,5]映射到了[0,300]之間,定義的變量scaleLinear好比是一個函數(shù)墨辛,能夠直接傳入?yún)?shù)進行計算

注意在D3中如何進行換行操作

序數(shù)比例尺scaleOrdinal()

domainrange都是離散化的卓研,可以說都是數(shù)組的形式,不是連續(xù)的

同樣的,在定義了比例尺之后奏赘,可以當(dāng)做函數(shù)來使用寥闪,傳入?yún)?shù)

image
<script>
      // 離散化比例尺
      var index = [0,1,2,3,4];
      var color = ["red","blue","yellow","black","green"];
      var scaleOrdinal = d3.scaleOrdinal()
            .domain(index)   //將index中的值和color中的顏色一一對應(yīng)
            .range(color);

        document.write("scaleOrdinal(1)輸出:"+scaleOrdinal(1));
        d3.select("body").append("br");//換行
        document.write("scaleOrdinal(2)輸出:"+scaleOrdinal(2));
        d3.select("body").append("br");
        document.write("scaleOrdinal(4)輸出:"+scaleOrdinal(4));
</script>

比例尺作圖

利用線性比例尺來做柱狀圖

<body>
    <svg width="960" height="600"></svg>
    <script>
        // 定義畫布邊距、數(shù)組
        var marge = {top:60,bottom:60,left:60,right:60}
        var dataset = [ 2.5 , 2.1 , 1.7 , 1.3 , 0.9 ];  
        //定義一個線性比例尺
        var scaleLinear = d3.scaleLinear()
            .domain([0,d3.max(dataset)])   //指定domain和range
            .range([0,300]);
        
        var svg = d3.select("svg");   // 選擇元素
        var g = svg.append("g")   // 指定分組
            .attr("transform", "translate("+marge.top+","+marge.left+")");
        
        var rectHeight = 30;
        
        g.selectAll("rect")
            .data(dataset)
            .enter()
            .append("rect")
                .attr("x", 20)
                .attr("y",function(d,i){
                    return i * rectHeight;
                })
                .attr("width",function(d){
                    return scaleLinear(d);   // 使用比例尺
                })
                .attr("height", rectHeight-5)
                .attr("fill","red")
    </script>
</body>
image

利用比例尺加上刻度線來作圖

<body>
    <script>
        // 定義畫布大小和數(shù)組
        var dataArray = [5, 40, 50, 60];
        var width = 500;
        var height = 500;

        //定義線性比例尺
        var widthScale = d3.scaleLinear()  // D3 v4之后不再使用該寫法磨淌,請用d3.scaleLinear()
                            .domain([0,60])
                            .range([0,width]);
        // 定義顏色的漸變比例尺
        var color = d3.scaleLinear()
                            .domain([0,60])
                            .range(['red', 'blue']);

        var axis = d3.axisBottom(widthScale)  // 定義一個axis疲憋,方向朝下,10個刻度
                            .ticks(10);

        // 定義畫布(代碼記琢褐弧)
        var svg = d3.select('body')
                    .append('svg')  // 追加一個svg元素
                        .attr('width', width)
                        .attr('height', height)
                    .append('g')
                        .attr('transform', 'translate(20,0)')
                        .call(axis);   // 最終調(diào)用axis刻度
                    

        var bars = svg.selectAll('rect')   // 選擇svg中的全部矩形
                    .data(dataArray)   // 綁定數(shù)組
                    .enter()  // 指定選擇集的enter部分
                    .append('rect')  // 添加足夠數(shù)量的矩形元素
                        .attr('x', 20)   // 距離原點的距離缚柳,默認(rèn)是0
                        .attr('width',function(d) {return widthScale(d);})
                        .attr('height',50)
                        .attr('fill',function(d) { return color(d); })  // 填充顏色改變   
                        .attr('y',function(d,i){ return i * 100 });  // d表示被綁定的數(shù)據(jù),i是索引號
    
    svg.append('g')
            .attr("transform", "translate(0,400)")
            .call(axis);
    
    </script>
</body>
image
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末搪锣,一起剝皮案震驚了整個濱河市秋忙,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌构舟,老刑警劉巖灰追,帶你破解...
    沈念sama閱讀 219,039評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異狗超,居然都是意外死亡弹澎,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,426評論 3 395
  • 文/潘曉璐 我一進店門努咐,熙熙樓的掌柜王于貴愁眉苦臉地迎上來苦蒿,“玉大人,你說我怎么就攤上這事麦撵」舫Γ” “怎么了?”我有些...
    開封第一講書人閱讀 165,417評論 0 356
  • 文/不壞的土叔 我叫張陵免胃,是天一觀的道長音五。 經(jīng)常有香客問我,道長羔沙,這世上最難降的妖魔是什么躺涝? 我笑而不...
    開封第一講書人閱讀 58,868評論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮扼雏,結(jié)果婚禮上坚嗜,老公的妹妹穿的比我還像新娘。我一直安慰自己诗充,他們只是感情好苍蔬,可當(dāng)我...
    茶點故事閱讀 67,892評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著蝴蜓,像睡著了一般碟绑。 火紅的嫁衣襯著肌膚如雪俺猿。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,692評論 1 305
  • 那天格仲,我揣著相機與錄音押袍,去河邊找鬼。 笑死凯肋,一個胖子當(dāng)著我的面吹牛谊惭,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播侮东,決...
    沈念sama閱讀 40,416評論 3 419
  • 文/蒼蘭香墨 我猛地睜開眼圈盔,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了苗桂?” 一聲冷哼從身側(cè)響起药磺,我...
    開封第一講書人閱讀 39,326評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎煤伟,沒想到半個月后癌佩,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,782評論 1 316
  • 正文 獨居荒郊野嶺守林人離奇死亡便锨,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,957評論 3 337
  • 正文 我和宋清朗相戀三年围辙,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片放案。...
    茶點故事閱讀 40,102評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡姚建,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出吱殉,到底是詐尸還是另有隱情掸冤,我是刑警寧澤,帶...
    沈念sama閱讀 35,790評論 5 346
  • 正文 年R本政府宣布友雳,位于F島的核電站稿湿,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏押赊。R本人自食惡果不足惜饺藤,卻給世界環(huán)境...
    茶點故事閱讀 41,442評論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望流礁。 院中可真熱鬧涕俗,春花似錦、人聲如沸神帅。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,996評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽找御。三九已至询刹,卻和暖如春谜嫉,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背凹联。 一陣腳步聲響...
    開封第一講書人閱讀 33,113評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留哆档,地道東北人蔽挠。 一個月前我還...
    沈念sama閱讀 48,332評論 3 373
  • 正文 我出身青樓,卻偏偏與公主長得像瓜浸,于是被迫代替她去往敵國和親澳淑。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,044評論 2 355