canvasgraph.html revision 106cc795c2891f2d2d142772cadefbcb5975bcfa
<html>
<head>
<style>
/*Supplemental CSS for the YUI distribution*/
#custom-doc { width: 95%; min-width: 950px; }
</style>
<!-- BEGIN EXAMPLE CODE -->
<body>
<script>
var starttime;
var mydate = new Date();
starttime = mydate.valueOf();
function writeToDiv(message)
{
var mydate = new Date();
var diff = mydate.valueOf() - starttime;
message += ": " + diff;
document.getElementById("output").innerHTML += "<br/>" + message;
}
var getData = function()
{
var bigArray = new Array();
var tempObj = new Object();
var i = (Math.floor(Math.random()*12)) + 1;
var end = i + 23;
var month;
var year;
var expensesValue = 8000;
for(i;i <= end; i++)
{
month = i;
year = 2009;
if(i > 24)
{
month = i -24;
year +=2;
}
else if(i > 12)
{
month = i - 12;
year +=1;
}
bigArray = bigArray.concat(getMonthOfDates(month, getNumberOfDays(month, year), year, expensesValue))
}
return bigArray;
}
function getNumberOfDays(mon, year)
{
if(mon == 4 || mon == 6 || mon == 9 || mon ==11)
{
return 30;
}
if(mon == 2)
{
return year%4==0?29:28;
}
return 31;
}
function getMonthOfDates(mon, max, year, value)
{
var month = new Array();
dValue = value;
for(var i = 1; i <= max; i++)
{
var obj = new Object();
dValue = dValue - 1;
}
return month;
}
</script>
<div>
<h1>Chart with Multiple Axes</h1>
<div id="chart" style="width:800px;height:400px;background-color:#ffffff;border:2px solid #5577AF"></div>
<div id="output"></div>
<script>
YUI({}).use('node', 'json', 'event-custom', 'base', 'graphic', 'infographics', function (Y)
{
// Create data
var mydata = getData();
var expensegraphstyles = {
color:"#5577AF",
marker:{fillColor:"#5577AF"},
weight:"2",
showMarkers:false
};
// Add revenue graph styles
var revenuegraphstyles = {
color:"#FF0000",
marker:{fillcolor:"#ff0000"},
weight:"2",
showMarkers:false
};
var dataProvider = {data:mydata};
var timeaxis = new Y.TimeAxis({dataProvider:dataProvider});
var numericaxis = new Y.NumericAxis({dataProvider:dataProvider});
timeaxis.addKey("date");
numericaxis.addKey("revenue");
var linegraph = new Y.LineSeries({parent:"chart", xAxis:timeaxis, yAxis:numericaxis, xKey:"date", yKey:"revenue", styles:expensegraphstyles});
});
</script>
<!-- END EXAMPLE CODE -->
</div>
</body>
</html>