`

Flot example

    博客分类:
  • web
阅读更多

Flot is an open source javascript charting tool. I need to plot an interest rate curve in a web page, so the x-axis is date.

 

Here is an example modified from the file interacting.html in the flot example package

 

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
 <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
    <title>Flot Examples</title>
    <link href="layout.css" rel="stylesheet" type="text/css"></link>
	<script language="javascript" type="text/javascript" src="flotjs/excanvas.min.js"></script>
    <script language="javascript" type="text/javascript" src="flotjs/jquery.js"></script>
    <script language="javascript" type="text/javascript" src="flotjs/jquery.flot.js"></script>
 </head>
    <body>
    <h1>Flot Examples</h1>

    <div id="placeholder" style="width:600px;height:300px"></div>   

    <p id="hoverdata">Mouse hovers at
    (<span id="x">0</span>, <span id="y">0</span>). <span id="clickdata"></span></p>

<script id="source" language="javascript" type="text/javascript">
$(function () {
    var sin = [], cos = [];
    for (var i = 0; i < 50; i += 1) {
	    var date1 = new Date(); 
		date1 = date1.setDate(i+1);
        sin.push([date1, Math.sin(i)]);
    }

    var plot = $.plot($("#placeholder"),
           [ { data: sin, label: "sin(x)"} ], {
               series: {
                   lines: { show: true },
                   points: { show: true }
               },
               grid: { hoverable: true, clickable: true },
			   xaxis: { mode: 'time', timeformat: "%m/%d", ticks: 10},
               yaxis: { min: -1.2, max: 1.2 }
             });

    function showTooltip(x, y, contents) {
        $('<div id="tooltip">' + contents + '</div>').css( {
            position: 'absolute',
            display: 'none',
            top: y + 5,
            left: x + 5,
            border: '1px solid #fdd',
            padding: '2px',
            'background-color': '#fee',
            opacity: 0.80
        }).appendTo("body").fadeIn(200);
    }

    var previousPoint = null;
    $("#placeholder").bind("plothover", function (event, pos, item) {
        $("#x").text(pos.x.toFixed(2));
        $("#y").text(pos.y.toFixed(2));
        
		if (item) {
			if (previousPoint != item.datapoint) {
				previousPoint = item.datapoint;
				
				$("#tooltip").remove();
				var x = item.datapoint[0].toFixed(2),
					y = item.datapoint[1].toFixed(2);
				
				var ddd = new Date();
				ddd.setTime(x);
				var mmm = ddd.getMonth() + 1;
				var mdd = ddd.getDate() ;
				showTooltip(item.pageX, item.pageY,
							"(" + mmm + "/" + mdd + ", " + y + ")");
			}
		}
		else {
			$("#tooltip").remove();
			previousPoint = null;            
		}
        
    });

    $("#placeholder").bind("plotclick", function (event, pos, item) {
        if (item) {
            $("#clickdata").text("You clicked point " + item.dataIndex + " in " + item.series.label + ".");
            plot.highlight(item.series, item.datapoint);
        }
    });
});
</script>

 </body>
</html>

 

The result is like this:

 

The tooltip values are useful for users.

  • 大小: 48.8 KB
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics