/* ======================================================================== * PlantUML : a free UML diagram generator * ======================================================================== * * (C) Copyright 2009-2024, Arnaud Roques * * Project Info: https://plantuml.com * * If you like this project or if you find it useful, you can support us at: * * https://plantuml.com/patreon (only 1$ per month!) * https://plantuml.com/paypal * * This file is part of PlantUML. * * PlantUML is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * PlantUML distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public * License for more details. * * You should have received a copy of the GNU General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, * USA. * * * Original Author: Arnaud Roques * * */ package net.sourceforge.plantuml.sequencediagram.teoz; import net.sourceforge.plantuml.klimt.UTranslate; import net.sourceforge.plantuml.klimt.creole.Display; import net.sourceforge.plantuml.klimt.drawing.UGraphic; import net.sourceforge.plantuml.klimt.font.StringBounder; import net.sourceforge.plantuml.klimt.geom.XDimension2D; import net.sourceforge.plantuml.real.Real; import net.sourceforge.plantuml.sequencediagram.Event; import net.sourceforge.plantuml.sequencediagram.Note; import net.sourceforge.plantuml.sequencediagram.NotePosition; import net.sourceforge.plantuml.sequencediagram.Participant; import net.sourceforge.plantuml.sequencediagram.Reference; import net.sourceforge.plantuml.skin.Area; import net.sourceforge.plantuml.skin.Component; import net.sourceforge.plantuml.skin.ComponentType; import net.sourceforge.plantuml.skin.Context2D; import net.sourceforge.plantuml.style.ISkinParam; public class ReferenceTile extends AbstractTile implements Tile { private final Reference reference; private final TileArguments tileArguments; private Real first; private Real last; private final YGauge yGauge; private Component noteLeft; private Component noteRight; public Event getEvent() { return reference; } public ReferenceTile(Reference reference, TileArguments tileArguments, YGauge currentY) { super(tileArguments.getStringBounder(), currentY); this.reference = reference; this.tileArguments = tileArguments; this.yGauge = YGauge.create(currentY.getMax(), getPreferredHeight()); for (Note noteOnMessage : reference.getNoteOnMessages()) { final ISkinParam skinParam2 = noteOnMessage.getSkinParamBackcolored(tileArguments.getSkinParam()); final Component note = tileArguments.getSkin().createComponentNote(noteOnMessage.getUsedStyles(), noteOnMessage.getNoteStyle().getNoteComponentType(), skinParam2, noteOnMessage.getDisplay(), noteOnMessage.getColors()); if (noteOnMessage.getPosition() == NotePosition.RIGHT) noteRight = note; else noteLeft = note; } } @Override public YGauge getYGauge() { return yGauge; } private void init(StringBounder stringBounder) { if (first != null) return; for (Participant p : reference.getParticipant()) { final LivingSpace livingSpace = tileArguments.getLivingSpace(p); final Real pos = livingSpace.getPosC(stringBounder); if (first == null || pos.getCurrentValue() < first.getCurrentValue()) this.first = livingSpace.getPosB(stringBounder); if (last == null || pos.getCurrentValue() > last.getCurrentValue()) this.last = livingSpace.getPosD(stringBounder); } final Component comp = getComponent(stringBounder); final XDimension2D dim = comp.getPreferredDimension(stringBounder); if (reference.getParticipant().size() == 1) this.last = this.last.addAtLeast(0); this.last.ensureBiggerThan(this.first.addFixed(dim.getWidth())); } private Component getComponent(StringBounder stringBounder) { Display strings = Display.empty(); strings = strings.add("ref"); strings = strings.addAll(reference.getStrings()); final Component comp = tileArguments.getSkin().createComponent(reference.getUsedStyles(), ComponentType.REFERENCE, null, tileArguments.getSkinParam(), strings); return comp; } public void drawU(UGraphic ug) { final StringBounder stringBounder = ug.getStringBounder(); init(stringBounder); final Component comp = getComponent(stringBounder); final XDimension2D dim = comp.getPreferredDimension(stringBounder); final Area area = Area.create(last.getCurrentValue() - first.getCurrentValue(), dim.getHeight()); comp.drawU(ug.apply(UTranslate.dx(first.getCurrentValue())), area, (Context2D) ug); if (noteLeft != null) { final double wn = noteLeft.getPreferredWidth(stringBounder); final double hn = noteLeft.getPreferredHeight(stringBounder); noteLeft.drawU(ug.apply(UTranslate.dx(first.getCurrentValue() - wn)), new Area(new XDimension2D(wn, hn)), (Context2D) ug); } if (noteRight != null) { final double wn = noteRight.getPreferredWidth(stringBounder); final double hn = noteRight.getPreferredHeight(stringBounder); noteRight.drawU(ug.apply(UTranslate.dx(last.getCurrentValue())), new Area(new XDimension2D(wn, hn)), (Context2D) ug); } } public double getPreferredHeight() { final Component comp = getComponent(getStringBounder()); final XDimension2D dim = comp.getPreferredDimension(getStringBounder()); return dim.getHeight(); } public void addConstraints() { } public Real getMinX() { init(getStringBounder()); if (noteLeft != null) { final double wn = noteLeft.getPreferredWidth(getStringBounder()); return this.first.addFixed(-wn); } return this.first; } public Real getMaxX() { init(getStringBounder()); if (noteRight != null) { final double wn = noteRight.getPreferredWidth(getStringBounder()); return this.last.addFixed(wn); } return this.last; } }