DocumentServer/OfficeWeb/sdk/Common/Charts/docs/adjusting_gantt.html
nikolay ivanov a8be6b9e72 init repo
2014-07-05 18:22:49 +00:00

210 lines
9.2 KiB
HTML

<!DOCTYPE html>
<html>
<head>
<meta http-equiv="X-UA-Compatible" content="chrome=1">
<!--
/**
* o------------------------------------------------------------------------------o
* | This file is part of the OfficeExcel package - you can learn more at: |
* | |
* | http://www.OfficeExcel.net |
* | |
* | This package is licensed under the OfficeExcel license. For all kinds of business |
* | purposes there is a small one-time licensing fee to pay and for non |
* | commercial purposes it is free to use. You can read the full license here: |
* | |
* | http://www.OfficeExcel.net/LICENSE.txt |
* o------------------------------------------------------------------------------o
*/
-->
<title>Adjusting the Gantt chart interactively</title>
<meta name="keywords" content="OfficeExcel html5 canvas chart adjusting docs " />
<meta name="description" content="Information about adjusting the Gantt chart interactively" />
<meta name="googlebot" content="NOODP">
<meta property="og:title" content="OfficeExcel: HTML5 Javascript charts library" />
<meta property="og:description" content="A charts library based on the HTML5 canvas tag" />
<meta property="og:image" content="http://www.OfficeExcel.net/images/logo.png"/>
<link rel="stylesheet" href="../css/website.css" type="text/css" media="screen" />
<link rel="icon" type="image/png" href="../images/favicon.png">
<!-- Place this tag in your head or just before your close body tag -->
<script type="text/javascript" src="https://apis.google.com/js/plusone.js"></script>
<script src="../libraries/OfficeExcel.common.core.js" ></script>
<script src="../libraries/OfficeExcel.common.adjusting.js" ></script>
<script src="../libraries/OfficeExcel.gantt.js" ></script>
<!--[if lt IE 9]><script src="../excanvas/excanvas.original.js"></script><![endif]-->
<script>
window.onload = function (e)
{
var gantt_events = [
[31, 28, null, 'Richard'],
[0, 120, null, 'Bob'],
[84, 16, null, 'Fred'],
[35, 45, null, 'Charles'],
[0, 35, null, 'Kev'],
[0, 28, null, 'Wayne'],
[31, 28, null, 'John']
];
var gantt = new OfficeExcel.Gantt('myc');
gantt.Set('chart.xmax', 120);
gantt.Set('chart.events', gantt_events);
gantt.Set('chart.defaultcolor', 'rgba(255,0,0,0.5)');
gantt.Set('chart.labels', ['January', 'February', 'March', 'April']);
gantt.Set('chart.title', 'An adjustable Gantt chart');
if (!OfficeExcel.isOld()) {
gantt.Set('chart.adjustable', true);
}
gantt.Set('chart.vbars', [
[0, 31, 'rgba(230,230,230,0.8)'],
[59, 31, 'rgba(230,230,230,0.8)']
]);
gantt.Draw();
/**
* This is how to get notified once adjusting has ended
*/
OfficeExcel.AddCustomEventListener(gantt, 'onadjustend',function (obj)
{
var events = obj.Get('chart.events');
var conf = OfficeExcel.Registry.Get('chart.adjusting.gantt');
var idx = conf['index'];
document.getElementById("eventID").value = idx;
document.getElementById("eventStart").value = events[idx][0];
document.getElementById("eventDuration").value = events[idx][1];
});
/**
* This is how to get notified during the adjusting
*/
OfficeExcel.AddCustomEventListener(gantt, 'onadjust',function (obj)
{
var events = obj.Get('chart.events');
var conf = OfficeExcel.Registry.Get('chart.adjusting.gantt');
var idx = conf[0];
document.getElementById("eventID").value = conf['index'];
document.getElementById("eventStart").value = events[conf['index']][0];
document.getElementById("eventDuration").value = events[conf['index']][1];
});
}
</script>
<?php PrintAnalyticsCode() ?>
</head>
<body>
<!-- Social networking buttons -->
<?php
$prefix = substr($_SERVER['SERVER_NAME'], 0, 3);
require("/OfficeExcel.{$prefix}/social.html");
?>
<!-- Social networking buttons -->
<div id="breadcrumb">
<a href="../index.html">OfficeExcel: HTML5 Javascript charts library</a>
>
<a href="./index.html">Documentation</a>
>
<a href="adjusting.html">Adjusting charts interactively</a>
>
Gantt chart
</div>
<h1>Adjusting <span>your charts interactively - Gantt chart</span></h1>
<script>
if (OfficeExcel.isOld()) {
document.write('<div style="background-color: #fee; border: 2px dashed red; padding: 5px"><b>Important</b><br /><br /> Internet Explorer does not natively support the HTML5 canvas tag, so if you want to see the charts, you can either:<ul><li>Install <a href="http://code.google.com/chrome/chromeframe/">Google Chrome Frame</a></li><li>Use ExCanvas. This is provided in the OfficeExcel Archive.</li><li>Use another browser entirely. Your choices are Firefox 3.5+, Chrome 2+, Safari 4+ or Opera 10.5+. </li></ul> <b>Note:</b> Internet Explorer 9 fully supports the canvas tag.</div>');
}
</script>
<p>
The Gantt chart can be adjusted by dragging the bars left or right, or the events can be resized if you place the cursor at the
right edge of the event. To get the details of the bar being dragged you can use the
<i>onadjustend</i> event, and in that you can look at the OfficeExcel registry - <i>OfficeExcel.Registry.Get('chart.adjusting.gantt')</i> The
returned array consists of:
<ul>
<li>The numerical index of the event being adjusted (corresponding to the chart.events array that you set).</li>
<li>The chart object</li>
<li>The starting X position of the bar (before the chart was adjusted)</li>
<li>The starting Y position of the bar (before the chart was adjusted)</li>
<li>The original numerical value (in relation to your chart.xmax) that the bar started at</li>
</ul>
</p>
<p>
When adjusting is complete the <i>chart.events</i> array is updated. So you can use the numerical index that you find in
the registry (as above) with the <i>chart.events</i> array to get up-to-date event information.
</p>
<p>
<b>Note:</b>
The Gantt chart uses console.log() to send notifications. Press CTRL+SHIFT+J in Chrome to see the console, or use Firebug in
Firefox. Other browsers will vary.
</p>
<canvas id="myc" width="1000" height="250">[No canvas support]</canvas>
Event ID: <input type="text" id="eventID" readonly />
Event start: <input type="text" id="eventStart" readonly />
Event duration: <input type="text" id="eventDuration" readonly />
<pre class="code">
&lt;script&gt;
window.onload = function (e)
{
gantt_events = [
[31, 28, null, 'Richard'],
[0, 120, null, 'Bob'],
[84, 16, null, 'Fred'],
[35, 45, null, 'Charles'],
[0, 35, null, 'Kev'],
];
var gantt = new OfficeExcel.Gantt('myc');
gantt.Set('chart.xmax', 120);
gantt.Set('chart.events', gantt_events);
gantt.Set('chart.defaultcolor', '#0c0');
gantt.Set('chart.labels', ['January', 'February', 'March', 'April']);
gantt.Set('chart.borders', false);
gantt.Set('chart.adjustable', true);
gantt.Draw();
/**
* This is how to get notified once adjusting has ended
*/
OfficeExcel.AddCustomEventListener(gantt, 'onadjustend',function (obj)
{
var idx = OfficeExcel.Registry.Get('chart.adjusting.gantt')[0];
});
/**
* This is how to get notified during the adjusting
*/
OfficeExcel.AddCustomEventListener(gantt, 'onadjust',function (obj)
{
var events = obj.Get('chart.events');
var conf = OfficeExcel.Registry.Get('chart.adjusting.gantt');
var idx = conf[0];
document.getElementById("eventID").value = conf[0];
document.getElementById("eventStart").value = events[conf[0]][0];
document.getElementById("eventDuration").value = events[conf[0]][1];
});
}
&lt;/script&gt;
</pre>
</body>
</html>