I have written a cross-platform xGantt chart Class.
History.
After having read this thread, i begun to think about it and wrote a first demostrator version.
Then, seeing that there was some interest in this thread, I posted this first version.
And continued to improve it, as a kind of challenge, to see what can be done and left it, because i do not use it.
These days an interest raised again in this thread and i posted my latest version.
Further improvements would mean to write a full project management program, and this is not in my to do list.
As there is some interest, i publish the current version as it is.
It is open source, any member can use, reuse, improve it in any way.
Attached the demo program with the xGantt.bas module.
I have not (yet) made a b4xlib library.
Depending on the interest i can / will give more details in the future.
Missing features.
1. Official holidays or free days are not taken into account, only Saturdays an Sundays.
2. Optimistic and pessimistic time estimations with the corresponding chart display.
3. Critical path.
4. Hour time line, only days are supported.
etc.
The class:
There exist two types of display.
The chart:
The table.
Data structure:
A xGantt chart is a composed of rows.
Each row has these properties:
1. The ID of the objcet
2. One of the three object types.
2.1. Task
2.2. Group
2.3. Milestone
Objects:
2.1. Task
This is the main object with different properties:
1. ID - a string that identifies the task.
2. Row - the row number in the chart.
3. Name - a string with the name of the task.
4. Color - only for the display.
5. Responsible - the name of the person in charge of the task
6. BeginDate - the begin date of the task.
This date could be calculated in function of the dependency on other tasks.
7. Duration - the duration in days.
8. Dependency - dependency on other tasks.
Five dependencies do exist:
- None - no dependency, this is always the case for the first task.
The EndDate is calculated with the Duration.
- FS - Finish to Start. The task starts when its predecessor task is finished with a lag or lead. Example Task 1.2
The BeginDate is calculated with the predecessors EndDate and the lag or lead and the EndDate is calculated with the duration.
- FF - Finish to Finish. The task must finish at the same time as its predecessor with a lag or lead. Example Task 2.5
The EndDate is calculated with the predecessors EndDate and the lag or lead and the BeginDate is calculated with the duration.
- SS - Start to Start. The task must start at the dame time as its predecessor with a lag or lead. Example Task 1.4
The BeginDate is calculated with the predecessors BeginDate and the lag or lead and the EndDate is calculated with the duration.
- SF - Start to Finish. The task must be finished when its predecessor starts with a lag or lead. Example Task 1.5
The EndDate is calculated with the predecessors BeginDate and the lag or lead and the BeginDate is calculated with the duration.
9. Completion - percentage of completion of the task.
10. PredecessorID - ID of the predecessor task in the dependency hierarchy.
11 SuccessorIDs - List of the IDs of the successor tasks in the dependency hierarchy. These values are calculated.
12. LagLead - the number of days before or after the begin or end of a task in the hierarchy, when there is a dependency.
13. EndDate - the end date of the task. This value is calculated.
2.2 Group
1. ID - a string that identifies the group.
2. Row - the row number in the chart.
3. Name - a string with the name of the group.
4. Color - only for the display.
5. Begin Task ID - the ID of the first task.
6. End Task ID - the ID of the last task.
2.3 Milestone
1. ID - a string that identifies the milestone.
2. Row - the row number in the chart.
3. Name - a string with the name of the milestone.
4. Color - only for the display.
5. Dependency - dependency on tasks.
- None - no dependency.
- TB Task Begin - begin of the task.
- TE Task End - end of the task.
6.1 Date of the milestone when there is no dependency.
6.2 Task ID - the ID of the task, if there is a dependency, and the date is calculated.
History.
After having read this thread, i begun to think about it and wrote a first demostrator version.
Then, seeing that there was some interest in this thread, I posted this first version.
And continued to improve it, as a kind of challenge, to see what can be done and left it, because i do not use it.
These days an interest raised again in this thread and i posted my latest version.
Further improvements would mean to write a full project management program, and this is not in my to do list.
As there is some interest, i publish the current version as it is.
It is open source, any member can use, reuse, improve it in any way.
Attached the demo program with the xGantt.bas module.
I have not (yet) made a b4xlib library.
Depending on the interest i can / will give more details in the future.
Missing features.
1. Official holidays or free days are not taken into account, only Saturdays an Sundays.
2. Optimistic and pessimistic time estimations with the corresponding chart display.
3. Critical path.
4. Hour time line, only days are supported.
etc.
The class:
There exist two types of display.
The chart:
The table.
Data structure:
A xGantt chart is a composed of rows.
Each row has these properties:
1. The ID of the objcet
2. One of the three object types.
2.1. Task
2.2. Group
2.3. Milestone
Objects:
2.1. Task
This is the main object with different properties:
1. ID - a string that identifies the task.
2. Row - the row number in the chart.
3. Name - a string with the name of the task.
4. Color - only for the display.
5. Responsible - the name of the person in charge of the task
6. BeginDate - the begin date of the task.
This date could be calculated in function of the dependency on other tasks.
7. Duration - the duration in days.
8. Dependency - dependency on other tasks.
Five dependencies do exist:
- None - no dependency, this is always the case for the first task.
The EndDate is calculated with the Duration.
- FS - Finish to Start. The task starts when its predecessor task is finished with a lag or lead. Example Task 1.2
The BeginDate is calculated with the predecessors EndDate and the lag or lead and the EndDate is calculated with the duration.
- FF - Finish to Finish. The task must finish at the same time as its predecessor with a lag or lead. Example Task 2.5
The EndDate is calculated with the predecessors EndDate and the lag or lead and the BeginDate is calculated with the duration.
- SS - Start to Start. The task must start at the dame time as its predecessor with a lag or lead. Example Task 1.4
The BeginDate is calculated with the predecessors BeginDate and the lag or lead and the EndDate is calculated with the duration.
- SF - Start to Finish. The task must be finished when its predecessor starts with a lag or lead. Example Task 1.5
The EndDate is calculated with the predecessors BeginDate and the lag or lead and the BeginDate is calculated with the duration.
9. Completion - percentage of completion of the task.
10. PredecessorID - ID of the predecessor task in the dependency hierarchy.
11 SuccessorIDs - List of the IDs of the successor tasks in the dependency hierarchy. These values are calculated.
12. LagLead - the number of days before or after the begin or end of a task in the hierarchy, when there is a dependency.
13. EndDate - the end date of the task. This value is calculated.
2.2 Group
1. ID - a string that identifies the group.
2. Row - the row number in the chart.
3. Name - a string with the name of the group.
4. Color - only for the display.
5. Begin Task ID - the ID of the first task.
6. End Task ID - the ID of the last task.
2.3 Milestone
1. ID - a string that identifies the milestone.
2. Row - the row number in the chart.
3. Name - a string with the name of the milestone.
4. Color - only for the display.
5. Dependency - dependency on tasks.
- None - no dependency.
- TB Task Begin - begin of the task.
- TE Task End - end of the task.
6.1 Date of the milestone when there is no dependency.
6.2 Task ID - the ID of the task, if there is a dependency, and the date is calculated.
Attachments
Last edited: