jquery 繪圖工具 flot 使用

今天想做一個統計圖表,像163博客的流量統計一樣的,藉助 flot 實現了,而且很簡單。

flot網址:http://code.google.com/p/flot/
下載 JS 文件,使用方法和 jquery 一樣。 
注意:flot是自動繪製在畫布標籤(canvas)內的,IE不支持,需要添加 excanvas.min.js ,此文件可以在上面給出的flot網址中下載
 
示例網址:http://people.iola.dk/olau/flot/examples/
參數說明:http://wenku.baidu.com/view/d504613331126edb6f1a1008.html
上面的兩個網址已經將基礎說的很清楚了。
 
示例說明:
語法: $.plot(id, data, options);
1.id :放置 canvas 的 div 的ID
2.data :數據,一般爲二維數組的形式。
例如:[[x1,y1],[x2,y2],[x3,y3] , ...]
如果某個數據爲空,則對應點將被忽略,且改點前後兩個點將不再用直線連接。
3.options :樣式,用於設置顯示樣式。 options 的格式:
var options = {
  lines: { show: true },
  points: { show: true },
  xaxis: { tickDecimals: 0, tickSize: 1 }
  };
參數:
 1.lines { }  顯示直線
 show: true 顯示
    color: "#FFFFFF" 線條顏色
   steps: true 階梯形 
2.points { }  顯示點
3.bars { } 顯示直方圖
4.xaxis { } 橫座標的樣式
  
例一:http://people.iola.dk/olau/flot/examples/basic.html
語法示例:$.plot($("#name"), [ d1,d2,d3 ]);
參數①:name 爲畫布所在 div 的 id 。
參數②:d2,d3 一般爲數列數組 [x,y],x和y分別表示每個點的橫軸和縱軸,例如可以定義如下:
var d1 = [];
for (var i = 0; i < 14; i += 0.5)
d1.push([i, Math.sin(i)]);
var d2 = [[0, 3], [4, 8], [8, 5], [9, 13]];
var d3 = [[0, 12], [7, 12], null, [7, 2.5], [12, 2.5]];
flot會依據其最大值和畫布大小自動設置刻度,例如設置div如下 
 <div id="placeholder" style="width:100px;height:100px;"></div>
則x方向每個像素表示 9/100=0.09 個單位,y方向每個像素表示 12/100=0.12 個單位。
 
例二:http://people.iola.dk/olau/flot/examples/graph-types.html
語法示例: 
<span style="font-size:12px;">$.plot($("#placeholder"), [
    {
        data: d1,
        lines: { show: true, fill: true }
    },
    {
        data: d2,
        bars: { show: true }
    },
    {
        data: d3,
        points: { show: true }
    },
    {
        data: d4,
        lines: { show: true }
    },
    {
        data: d5,
        lines: { show: true },
        points: { show: true }
    },
    {
        data: d6,
        lines: { show: true, steps: true }
    }
]);</span>
參數說明:lins 表示直線,參數 steps:true 表示梯形圖,bars 表示直方圖,points 表示點狀圖。與示例一比較,實例二將示例一中的數據用花括號括起,此時需要用 "data:" 指定數據源,逗號之後指定其顯示樣式。
 
 
例三:指定刻度顯示的內容
用法實例:
<span style="font-size:12px;">$.plot($("#placeholder"), [{ label: "", data: vData}],
{
    series: { lines: { show: true }, points: { show: true} },
    xaxis: { ticks: [[1, "1月"], [3, "3月"], [5, "5月"], [7, "7月"], [9, "9月"], [11, "11月"]], min: 1, max: 12 },  //指定固定的顯示內容
    yaxis: { ticks: 5, min: 0 }  //在y軸方向顯示5個刻度,此時顯示內容由 flot 根據所給的數據自動判斷
}
    );</span>
其中 vData 爲自定義數據
var vData = [[1, 103], [2, 28], [3, 135], [4, 130], [5, 145], [6, 155], [7, 155], [8, 155], [9, 155], [10, 155], [11, 155], [12, 155]];         

顯示效果爲:


關鍵參數爲 ticks 。可以看到本例中 x軸刻度的顯示內容是自己指定的,y軸讓 flot 自動劃分,當然也可以指定y軸。


本文來自:http://www.cnblogs.com/xiangniu/archive/2011/03/12/1982163.html

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章