Código para cambiar el color de las subtareas en Gantt Chart

Necesito cambiar el color de las subtareas en un diagtwig de Gantt . Mi ejemplo se basa en GanttDemo2 con el siguiente conjunto de datos y procesador. En diferentes foros encontré algunas discusiones relacionadas con este tema, pero no encontré un ejemplo de trabajo claro y simple. En particular, puedo cambiar el color de las tareas, pero no sé cómo extraer subtareas.

 private IntervalCategoryDataset createSampleDataset() { final TaskSeries s1 = new TaskSeries("Scheduled"); final Task t1 = new Task( "Design", date(1, Calendar.APRIL, 2001), date(1, Calendar.MAY, 2001)); t1.addSubtask(new Task("Design 1", date(1, Calendar.APRIL, 2001), date(15, Calendar.APRIL, 2001))); t1.addSubtask(new Task("Design 2", date(16, Calendar.APRIL, 2001), date(25, Calendar.APRIL, 2001))); t1.addSubtask(new Task("Design 3", date(26, Calendar.APRIL, 2001), date(1, Calendar.MAY, 2001))); s1.add(t1); final Task t2 = new Task( "Proposal", date(1, Calendar.JUNE, 2001), date(1, Calendar.JULY, 2001)); t2.addSubtask(new Task("Proposal 1", date(1, Calendar.JUNE, 2001), date(15, Calendar.JUNE, 2001))); t2.addSubtask(new Task("Proposal 2", date(16, Calendar.JUNE, 2001), date(25, Calendar.JUNE, 2001))); t2.addSubtask(new Task("Proposal 3", date(26, Calendar.JUNE, 2001), date(1, Calendar.JULY, 2001))); s1.add(t2); final TaskSeriesCollection collection = new TaskSeriesCollection(); collection.add(s1); return collection; } class MyRenderer extends GanttRenderer { private static final Color subtask1Color = Color.blue; private static final Color subtask2Color = Color.cyan; private static final Color subtask3Color = Color.green; private static final long serialVersionUID = 1L; public MyRenderer() { super(); } @Override public Paint getItemPaint(int row, int col) { System.out.println(row + " " + col + " " + super.getItemPaint(row, col)); if (row == 0) { return subtask1Color; } else if (row == 1) { return subtask2Color; } else if (row == 2) { return subtask3Color; } else { return super.getItemPaint(row, col); } } } 

Como se sugiere aquí , un renderizador personalizado puede consultar el modelo para condicionar el resultado devuelto por getItemPaint() . En este ejemplo, las subtareas se representan utilizando una paleta de saturaciones variables del color predeterminado para una serie determinada. El enfoque asume que el procesador hace dos pases; se debe tener cuidado al documentar la dependencia.

GanttSubtaskDemo

 /** @see https://stackoverflow.com/questions/8938690 */ private static class MyRenderer extends GanttRenderer { private static final int PASS = 2; // assumes two passes private final List clut = new ArrayList(); private final TaskSeriesCollection model; private int row; private int col; private int index; public MyRenderer(TaskSeriesCollection model) { this.model = model; } @Override public Paint getItemPaint(int row, int col) { if (clut.isEmpty() || this.row != row || this.col != col) { initClut(row, col); this.row = row; this.col = col; index = 0; } int clutIndex = index++ / PASS; return clut.get(clutIndex); } private void initClut(int row, int col) { clut.clear(); Color c = (Color) super.getItemPaint(row, col); float[] a = new float[3]; Color.RGBtoHSB(c.getRed(), c.getGreen(), c.getBlue(), a); TaskSeries series = (TaskSeries) model.getRowKeys().get(row); List tasks = series.getTasks(); // unchecked int taskCount = tasks.get(col).getSubtaskCount(); taskCount = Math.max(1, taskCount); for (int i = 0; i < taskCount; i++) { clut.add(Color.getHSBColor(a[0], a[1] / i, a[2])); } } } 

O bien, podría ampliar la tarea y usar una variable local de subproceso para realizar un seguimiento del último elemento al que accedió el representador:

 private ThreadLocal lastSubTask = new ThreadLocal(); ... private class MyTask extends Task { ... public Task getSubtask(int index) { lastSubTask.set(index); return super.getSubtask(index); } } ... private class MyRenderer extends GanttRenderer { ... public Paint getCompletePaint() { Integer index = lastSubTask.get(); return getColorForSubTask(index); } ... } 

Esto puede ser potencialmente más resistente a los cambios en jfreechart.