笔者在开发一个基于Web的应用程序提供对人物和项目事件的管理。项目需要一个甘特图控件可视化表示任务列表,笔者尝试寻找自由可用的解决方案(因 为不想增加开销)。笔者找到了一些例子,不过并不满意。于是,决定创建一个自己的甘特图控件。此次是笔者工作的最初成果。这个SIcon的最初版本只做了 几个小时,所以仍会有些问题。尽管如此,笔者还是希望与各位分享,希望能帮助大家。
-
-
-
-
-
-
-
-
-
-
-
- function Task(from, to, task, resource, progress)
- {
- var _from = new Date();
- var _to = new Date();
- var _task = task;
- var _resource = resource;
- var _progress = progress;
- var dvArr = from.split('/');
- _from.setFullYear(parseInt(dvArr[2], 10), parseInt(dvArr[0], 10) - 1,
- parseInt(dvArr[1], 10));
- dvArr = to.split('/');
- _to.setFullYear(parseInt(dvArr[2], 10), parseInt(dvArr[0], 10) - 1,
- parseInt(dvArr[1], 10));
-
- this.getFrom = function(){ return _from};
- this.getTo = function(){ return _to};
- this.getTask = function(){ return _task};
- this.getResource = function(){ return _resource};
- this.getProgress = function(){ return _progress};
- }
-
- function Gantt(gDiv)
- {
- var _GanttDiv = gDiv;
- var _taskList = new Array();
- this.AddTaskDetail = function(value)
- {
- _taskList.push(value);
-
- }
- this.Draw = function()
- {
- var _offSet = 0;
- var _dateDiff = 0;
- var _currentDate = new Date();
- var _maxDate = new Date();
- var _minDate = new Date();
- var _dTemp = new Date();
- var _firstRowStr = "
'border-collapse:collapse'>
-
'2' width='200px' style='width:200px;'>
-
class='GTaskTitle' style='width:200px;'>Task | ";
- var _thirdRow = "";
- var _gStr = "";
- var _colSpan = 0;
- var counter = 0;
-
- _currentDate.setFullYear(_currentDate.getFullYear(), _currentDate.getMonth(),
- _currentDate.getDate());
- if(_taskList.length > 0)
- {
- _maxDate.setFullYear(_taskList[0].getTo().getFullYear(),
- _taskList[0].getTo().getMonth(), _taskList[0].getTo().getDate());
- _minDate.setFullYear(_taskList[0].getFrom().getFullYear(),
- _taskList[0].getFrom().getMonth(), _taskList[0].getFrom().getDate());
- for(i = 0; i < _taskList.length; i++)
- {
- if(Date.parse(_taskList[i].getFrom()) < Date.parse(_minDate))
- _minDate.setFullYear(_taskList[i].getFrom().getFullYear(),
- _taskList[i].getFrom().getMonth(), _taskList[i].getFrom().getDate());
- if(Date.parse(_taskList[i].getTo()) > Date.parse(_maxDate))
- _maxDate.setFullYear(_taskList[i].getTo().getFullYear(),
- _taskList[i].getTo().getMonth(), _taskList[i].getTo().getDate());
- }
-
-
-
-
- if(_maxDate.getMonth() == 11)
- {
- if(_maxDate.getDay() + 5 > getDaysInMonth(_maxDate.getMonth() + 1,
- _maxDate.getFullYear()))
-
- _maxDate.setFullYear(_maxDate.getFullYear() + 1, 1, 5);
- else
-
- _maxDate.setFullYear(_maxDate.getFullYear(), _maxDate.getMonth(),
- _maxDate.getDate() + 5); }
- else
- {
- if(_maxDate.getDay() + 5 > getDaysInMonth(_maxDate.getMonth() + 1,
- _maxDate.getFullYear()))
-
- _maxDate.setFullYear(_maxDate.getFullYear(), _maxDate.getMonth() + 1,
- 5);
- else
-
- _maxDate.setFullYear(_maxDate.getFullYear(), _maxDate.getMonth(),
- _maxDate.getDate() + 5);
- }
-
-
-
- _gStr = "";
- _gStr += "
";
- _thirdRow = "
| ";
- _dTemp.setFullYear(_minDate.getFullYear(), _minDate.getMonth(),
- _minDate.getDate());
- while(Date.parse(_dTemp) <= Date.parse(_maxDate))
- {
- if(_dTemp.getDay() % 6 == 0)
- {
- _gStr += "
" +
- _dTemp.getDate() + "
| ";
- if(Date.parse(_dTemp) == Date.parse(_currentDate))
- _thirdRow += "
+ (counter++) +
- "' class='GToDay' style='height:" +
- (_taskList.length * 21) + "'>
| ";
- else
- _thirdRow += "
+ (counter++) +
- "' class='GWeekend' style='height:" + (_taskList.length * 21) +
- "'>
| ";
- }
- else
- {
- _gStr += "
" +
- _dTemp.getDate() + "
| ";
- if(Date.parse(_dTemp) == Date.parse(_currentDate))
- _thirdRow += "
+ (counter++) +
- "' class='GToDay' style='height:" + (_taskList.length * 21) +
- "'>
| ";
- else
- _thirdRow += "
+ (counter++) +
- "' class='GDay'>
| ";
- }
- if(_dTemp.getDate() < getDaysInMonth(_dTemp.getMonth() + 1,
- _dTemp.getFullYear()))
- {
- if(Date.parse(_dTemp) == Date.parse(_maxDate))
- {
- _firstRowStr += "
+
- (_colSpan + 1) + "'>T" + (_dTemp.getMonth() + 1) + "/" +
- _dTemp.getFullYear() + "
| ";
- }
- _dTemp.setDate(_dTemp.getDate() + 1);
- _colSpan++;
- }
- else
- {
- _firstRowStr += "
+
- (_colSpan + 1) + "'>T" + (_dTemp.getMonth() + 1) +
- "/" + _dTemp.getFullYear() + "
| ";
- _colSpan = 0;
- if(_dTemp.getMonth() == 11)
- {
- _dTemp.setFullYear(_dTemp.getFullYear() + 1, 0, 1);
- }
- else
- {
- _dTemp.setFullYear(_dTemp.getFullYear(),
- _dTemp.getMonth() + 1, 1);
- }
- }
- }
- _thirdRow += "
";
- _gStr += "
" + _thirdRow;
- _gStr += "
";
- _gStr = _firstRowStr + _gStr;
- for(i = 0; i < _taskList.length; i++)
- {
- _offSet = (Date.parse(_taskList[i].getFrom()) - Date.parse(_minDate)) /
- (24 * 60 * 60 * 1000);
- _dateDiff = (Date.parse(_taskList[i].getTo()) -
- Date.parse(_taskList[i].getFrom())) / (24 * 60 * 60 * 1000) + 1;
- _gStr += "
+ (20 * (i + 2)) +
- "; left:" + (_offSet * 27 + 204) + "; width:" +
- (27 * _dateDiff - 1 + 100) + "'>
+
- _taskList[i].getTask() + "' class='GTask' style='float:left; width:" +
- (27 * _dateDiff - 1) + "px;'>" +
- getProgressDiv(_taskList[i].getProgress()) +
- "
" +
- _taskList[i].getResource() + "
";
- _gStr += "
+
- (20 * (i + 2) + 1) + "; left:5px'>" + _taskList[i].getTask() +
- "
";
- }
- _GanttDiv.innerHTML = _gStr;
- }
- }
- }
-
- function getProgressDiv(progress)
- {
- return "
+ progress +
- "%; overflow:hidden'>
"
- }
-
- function getDaysInMonth(month, year)
- {
-
- var days;
- switch(month)
- {
- case 1:
- case 3:
- case 5:
- case 7:
- case 8:
- case 10:
- case 12:
- days = 31;
- break;
- case 4:
- case 6:
- case 9:
- case 11:
- days = 30;
- break;
- case 2:
- if (((year% 4)==0) && ((year% 100)!=0) || ((year% 400)==0))
- days = 29;
- else
- days = 28;
- break;
- }
- return (days);
- }
-
在你的HTML, ASCX, ASPX或PHP文档的Body部分,把下面几行代码拷贝到你想表示甘特图的地方
- <body>
- <h3>Diagramh3>
- <div style="position:relative" class="Gantt" id="GanttChart">div>
- body>
- <script>
- var g = new Gantt(document.all.GanttChart);
- g.AddTaskDetail(new Task('2/11/2008', '2/12/2008',
- '<b>Sample task 1 1b>', 'Dathq', 50));
- g.AddTaskDetail(new Task('2/16/2008', '2/19/2008',
- '... Sample task 1.1', 'Dathq, Thanhdd', 30));
- g.AddTaskDetail(new Task('2/12/2008', '3/4/2008', 'Sample task 2', 'Hanhnd', 60));
- g.AddTaskDetail(new Task('2/11/2008', '2/16/2008', 'Sample task 3', 'Dathq', 50));
-
- g.Draw();
- script>
使用var g = new Gantt(document.all.GanttChart);语句指定你要显示的甘特图到命名为"GanttChart"的DIV元素(你可以在body中看到它)。
g.AddTaskDetail()方法添加任务到任务列表。你可以使用AJAX或任何你喜欢的方式来生成这些命令以添加任务的集合。
使用g.Draw()来渲染基于追加到甘特图对象的任务列表的甘特图。
这里笔者定义了一些类用来自定义甘特图的样式,为此提供了全部代码。你可以定义更多的类并且更轻易地改变甘特图控件的外观。
通过改变样式表,并且在代码中添加属性到任务对象,你可以为你自己创建更加智能的甘特图。例如:为任务条设置不同的颜色,漂亮的背景图片,更好的图标提示等等。
-
-
-
-
- .Gantt
- {
- font-family:tahoma, arial, verdana;
- font-size:11px;
- }
-
- .GTaskTitle
- {
- font-family:tahoma, arial, verdana;
- font-size:11px;
- font-weight:bold;
- }
-
- .GMonth
- {
- padding-left:5px;
- font-family:tahoma, arial, verdana;
- font-size:11px;
- font-weight:bold;
- }
-
- .GToday
- {
- background-color: #FDFDE0;
- }
-
- .GWeekend
- {
- font-family:tahoma, arial, verdana;
- font-size:11px;
- background-color:#F5F5F5;
- text-align:center;
- }
-
- .GDay
- {
- font-family:tahoma, arial, verdana;
- font-size:11px;
- text-align:center;
- }
-
- .GTask
- {
- border-top:1px solid #CACACA;
- border-bottom:1px solid #CACACA;
- height:14px;
- background-color:yellow;
- }
-
- .GProgress
- {
- background-color:black;
- height:2px;
- overflow: hidden;
- margin-top:5px;
- }
图表
- var g = new Gantt(document.all.GanttChart);
- g.AddTaskDetail(new Task('2/11/2008', '2/19/2008', 'Sample task 1 1', 'Dathq', 50));
- g.AddTaskDetail(new Task('2/16/2008', '2/19/2008', '... Sample task 1.1',
- 'Dathq, Thanhdo', 30));
- g.AddTaskDetail(new Task('2/12/2008', '3/2/2008', 'Sample task 2', 'Hanhnd', 60));
- g.AddTaskDetail(new Task('2/11/2008', '2/16/2008', 'Sample task 3', 'Dathq', 50));
- g.AddTaskDetail(new Task('2/11/2008', '2/19/2008', 'Sample task 1 1', 'Dathq', 50));
- g.AddTaskDetail(new Task('2/16/2008', '2/19/2008', '... Sample task 1.1',
- 'Dathq, Thanhdo', 30));
- g.AddTaskDetail(new Task('2/12/2008', '3/2/2008', 'Sample task 2', 'Hanhnd', 60));
- g.AddTaskDetail(new Task('2/11/2008', '2/16/2008', 'Sample task 3', 'Dathq', 50));
- g.AddTaskDetail(new Task('2/11/2008', '2/19/2008', 'Sample task 1 1', 'Dathq', 50));
- g.AddTaskDetail(new Task('2/16/2008', '2/19/2008', '... Sample task 1.1',
- 'Dathq, Thanhdo', 30));
- g.AddTaskDetail(new Task('2/12/2008', '3/2/2008', 'Sample task 2', 'Hanhnd', 60));
- g.AddTaskDetail(new Task('2/11/2008', '2/16/2008', 'Sample task 3', 'Dathq', 50));
-
- g.AddTaskDetail(new Task('2/11/2008', '2/19/2008', 'Sample task 1 1', 'Dathq', 50));
- g.AddTaskDetail(new Task('2/16/2008', '2/19/2008', '... Sample task 1.1',
- 'Dathq, Thanhdo', 30));
- g.AddTaskDetail(new Task('2/12/2008', '3/2/2008', 'Sample task 2', 'Hanhnd', 60));
- g.AddTaskDetail(new Task('5/11/2008', '5/16/2008', 'Sample task 3', 'Dathq', 50));
-
- g.Draw();
亮点
你会先注意到图标运行起来速度很快。
SIcon甘特图是通过javascript创建的,这意味着你可以在众多的Web开发环境中使用它。我比较喜欢ASP.NET,所以我会把此控件和 ASP.NET一起使用。另外,你可以使用AJAX创建更酷的应用。你可以自定义CSS类得到更好看的甘特图。我将试图添加链接到任务用来描述他们的关 系,并将显示一个父任务,就像我们在MS Project中看到的一样。
甘特图通过HTML显示,因为它使用的是轻量级结构,所以你可以添加更多的功能到图表。例如,提示、链接、图片等,在JScript中使用一些基本的变化就可以获得。
最后,它是全免费的,编码愉快!
原文地址: http://www.codeproject.com/KB/scripting/SIcon_Gantt_Chart.aspx
文件下载: http://www.codeproject.com/KB/scripting/SIcon_Gantt_Chart/GanttChart.zip
翻译: 崔驰坤(JOSHUA TSUEI, http://www.cnblogs.com/JOSHUATSUEI )
点击下载此文件
本文作者:佚名 来源:http://www.kaiyuan8.org/Article/IAVTEnsTDnxzGLShYi
CIO之家 www.ciozj.com 微信公众号:imciow
免责声明:本站转载此文章旨在分享信息,不代表对其内容的完全认同。文章来源已尽可能注明,若涉及版权问题,请及时与我们联系,我们将积极配合处理。同时,我们无法对文章内容的真实性、准确性及完整性进行完全保证,对于因文章内容而产生的任何后果,本账号不承担法律责任。转载仅出于传播目的,读者应自行对内容进行核实与判断。请谨慎参考文章信息,一切责任由读者自行承担。