use of net.parostroj.timetable.model.freight.FreightConnectionPath in project grafikon by jub77.
the class TrainTableModel method getValueAt.
@Override
public Object getValueAt(int rowIndex, int columnIndex) {
TimeInterval interval = train.getTimeIntervalList().get(rowIndex);
TrainDiagram diagram = train.getDiagram();
Object retValue = null;
TrainTableColumn column = TrainTableColumn.getColumn(columnIndex);
switch(column) {
// node name
case NODE:
if (interval.isNodeOwner()) {
retValue = interval.getOwnerAsNode().getName();
} else {
retValue = "";
}
break;
// arrival
case START:
if (!interval.isFirst()) {
retValue = converter.convertIntToText(interval.getStart(), true);
}
break;
// departure
case END:
if (!interval.isLast()) {
retValue = converter.convertIntToText(interval.getEnd(), true);
}
break;
// stop time
case STOP:
if (interval.isNodeOwner() && rowIndex != 0 && rowIndex != lastRow && interval.getOwnerAsNode().getType() != NodeType.SIGNAL) {
retValue = converter.convertIntToMinutesText(interval.getLength());
}
break;
// speed
case SPEED_LIMIT:
if (interval.isLineOwner()) {
retValue = interval.getSpeedLimit();
}
break;
// used speed
case SPEED:
retValue = interval.getSpeed();
break;
// added time
case ADDED_TIME:
if (interval.isLineOwner() && interval.getAddedTime() != 0) {
retValue = converter.convertIntToMinutesText(interval.getAddedTime());
}
break;
// platform
case PLATFORM:
if (interval.isNodeOwner()) {
if (interval.getOwnerAsNode().getTracks().size() > 1) {
retValue = interval.getTrack();
}
} else if (interval.isLineOwner()) {
// only for more than one track per line
if (interval.getOwnerAsLine().getTracks().size() > 1) {
return interval.getTrack();
}
}
break;
// problems
case CONFLICTS:
StringBuilder builder = new StringBuilder();
for (TimeInterval overlap : interval.getOverlappingIntervals()) {
if (builder.length() != 0) {
builder.append(", ");
}
builder.append(overlap.getTrain().getDefaultName());
}
retValue = builder.toString();
break;
// comment
case COMMENT:
LocalizedString lComment = interval.getComment();
retValue = lComment == null ? null : lComment.getDefaultString();
break;
case OCCUPIED_ENTRY:
retValue = interval.getAttributes().getBool(TimeInterval.ATTR_OCCUPIED);
break;
case SHUNT:
retValue = interval.getAttributes().getBool(TimeInterval.ATTR_SHUNT);
break;
case COMMENT_SHOWN:
retValue = interval.getAttributes().getBool(TimeInterval.ATTR_COMMENT_SHOWN);
break;
case REAL_STOP:
if (interval.isNodeOwner() && rowIndex != 0 && rowIndex != lastRow && interval.getOwnerAsNode().getType() != NodeType.SIGNAL) {
int stop = interval.getLength() / 60;
// celculate with time scale ...
Double timeScale = diagram.getAttributes().get(TrainDiagram.ATTR_TIME_SCALE, Double.class);
retValue = stop / timeScale;
}
break;
case WEIGHT:
// weight info
if (interval.isLineOwner()) {
retValue = TrainsHelper.getWeight(interval);
}
break;
case LENGTH:
// length info
retValue = TrainsHelper.getLength(interval);
break;
case SET_SPEED:
// train speed
retValue = interval.getAttribute(TimeInterval.ATTR_SET_SPEED, Object.class);
break;
case IGNORE_LENGTH:
// ignore station length
retValue = interval.getAttributes().getBool(TimeInterval.ATTR_IGNORE_LENGTH);
break;
case MANAGED_FREIGHT:
// managed freight
retValue = false;
if (train.isManagedFreight() && interval.isNodeOwner()) {
retValue = (interval.getLength() > 0 || rowIndex == 0 || rowIndex == lastRow) && !interval.getAttributeAsBool(TimeInterval.ATTR_NOT_MANAGED_FREIGHT);
}
break;
case REGION_CENTER_TRANSFER:
// transfer in region center
retValue = false;
if (interval.isNodeOwner() && train.isManagedFreight()) {
if (interval.getOwnerAsNode().isCenterOfRegions() && !interval.getAttributeAsBool(TimeInterval.ATTR_NO_REGION_CENTER_TRANSFER) && rowIndex != 0) {
retValue = true;
}
}
break;
case FREIGHT_TO_STATIONS:
FreightConnectionStrategy strategy = train.getDiagram().getFreightNet().getConnectionStrategy();
if (rowIndex % 2 == 0 && (interval.isFreight() || interval.isFreightConnection())) {
StringBuilder result = new StringBuilder();
Map<Train, List<FreightConnectionPath>> passedCargoDst = strategy.getFreightPassedInNode(interval);
for (Map.Entry<Train, List<FreightConnectionPath>> entry : passedCargoDst.entrySet()) {
List<FreightConnectionPath> mList = entry.getValue();
result.append('(').append(freightUtil.freightListToString(mList, Locale.getDefault()));
result.append(" > ").append(entry.getKey().getDefaultName()).append(')');
}
if (interval.isFreightFrom()) {
List<FreightConnectionPath> cargoDst = strategy.getFreightToNodes(interval);
List<FreightConnectionPath> mList = cargoDst;
if (!cargoDst.isEmpty() && result.length() > 0) {
result.append(' ');
}
result.append(freightUtil.freightListToString(mList, Locale.getDefault()));
}
retValue = result.toString();
}
break;
// default (should not be reached)
default:
// nothing
assert false : "Unexpected column";
break;
}
return retValue;
}
Aggregations