mirror of
https://github.com/octoleo/plantuml.git
synced 2025-01-08 17:24:15 +00:00
Minor bug fix
This commit is contained in:
parent
51b9bfb05a
commit
ebf7613792
@ -70,17 +70,17 @@ public class ConstraintSet {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public Constraint getConstraint(Pushable p1, Pushable p2) {
|
public Constraint getConstraint(Pushable p1, Pushable p2) {
|
||||||
if (p1 == null || p2 == null || p1 == p2) {
|
if (p1 == null || p2 == null || p1 == p2)
|
||||||
throw new IllegalArgumentException();
|
throw new IllegalArgumentException();
|
||||||
}
|
|
||||||
final int i1 = participantList.indexOf(p1);
|
final int i1 = participantList.indexOf(p1);
|
||||||
final int i2 = participantList.indexOf(p2);
|
final int i2 = participantList.indexOf(p2);
|
||||||
if (i1 == -1 || i2 == -1) {
|
if (i1 == -1 || i2 == -1)
|
||||||
throw new IllegalArgumentException();
|
throw new IllegalArgumentException();
|
||||||
}
|
|
||||||
if (i1 > i2) {
|
if (i1 > i2)
|
||||||
return getConstraint(p2, p1);
|
return getConstraint(p2, p1);
|
||||||
}
|
|
||||||
final List<Pushable> key = Arrays.asList(p1, p2);
|
final List<Pushable> key = Arrays.asList(p1, p2);
|
||||||
Constraint result = constraints.get(key);
|
Constraint result = constraints.get(key);
|
||||||
if (result == null) {
|
if (result == null) {
|
||||||
@ -108,16 +108,16 @@ public class ConstraintSet {
|
|||||||
|
|
||||||
private Pushable getOtherParticipant(Pushable p, int delta) {
|
private Pushable getOtherParticipant(Pushable p, int delta) {
|
||||||
final int i = participantList.indexOf(p);
|
final int i = participantList.indexOf(p);
|
||||||
if (i == -1) {
|
if (i == -1)
|
||||||
throw new IllegalArgumentException();
|
throw new IllegalArgumentException();
|
||||||
}
|
|
||||||
return participantList.get(i + delta);
|
return participantList.get(i + delta);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void takeConstraintIntoAccount(StringBounder stringBounder) {
|
public void takeConstraintIntoAccount(StringBounder stringBounder) {
|
||||||
for (int dist = 1; dist < participantList.size(); dist++) {
|
for (int dist = 1; dist < participantList.size(); dist++)
|
||||||
pushEverybody(stringBounder, dist);
|
pushEverybody(stringBounder, dist);
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void pushEverybody(StringBounder stringBounder, int dist) {
|
private void pushEverybody(StringBounder stringBounder, int dist) {
|
||||||
@ -130,22 +130,22 @@ public class ConstraintSet {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void pushToLeftParticipantBox(double deltaX, Pushable firstToChange, boolean including) {
|
public void pushToLeftParticipantBox(double deltaX, Pushable firstToChange, boolean including) {
|
||||||
if (deltaX <= 0) {
|
if (deltaX <= 0)
|
||||||
throw new IllegalArgumentException();
|
throw new IllegalArgumentException();
|
||||||
}
|
|
||||||
Objects.requireNonNull(firstToChange);
|
Objects.requireNonNull(firstToChange);
|
||||||
// freeX += deltaX;
|
// freeX += deltaX;
|
||||||
boolean founded = false;
|
boolean founded = false;
|
||||||
for (Pushable box : participantList) {
|
for (Pushable box : participantList) {
|
||||||
if (box.equals(firstToChange)) {
|
if (box.equals(firstToChange)) {
|
||||||
founded = true;
|
founded = true;
|
||||||
if (including == false) {
|
if (including == false)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
if (founded)
|
||||||
if (founded) {
|
|
||||||
box.pushToLeft(deltaX);
|
box.pushToLeft(deltaX);
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -154,18 +154,17 @@ public class ConstraintSet {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void ensureSpaceAfter(StringBounder stringBounder, Pushable p1, Pushable p2, double space) {
|
private void ensureSpaceAfter(StringBounder stringBounder, Pushable p1, Pushable p2, double space) {
|
||||||
if (p1.equals(p2)) {
|
if (p1.equals(p2))
|
||||||
throw new IllegalArgumentException();
|
throw new IllegalArgumentException();
|
||||||
}
|
|
||||||
if (p1.getCenterX(stringBounder) > p2.getCenterX(stringBounder)) {
|
if (p1.getCenterX(stringBounder) > p2.getCenterX(stringBounder)) {
|
||||||
ensureSpaceAfter(stringBounder, p2, p1, space);
|
ensureSpaceAfter(stringBounder, p2, p1, space);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
assert p1.getCenterX(stringBounder) < p2.getCenterX(stringBounder);
|
assert p1.getCenterX(stringBounder) < p2.getCenterX(stringBounder);
|
||||||
final double existingSpace = p2.getCenterX(stringBounder) - p1.getCenterX(stringBounder);
|
final double existingSpace = p2.getCenterX(stringBounder) - p1.getCenterX(stringBounder);
|
||||||
if (existingSpace < space) {
|
if (existingSpace < space)
|
||||||
pushToLeftParticipantBox(space - existingSpace, p2, true);
|
pushToLeftParticipantBox(space - existingSpace, p2, true);
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -56,11 +56,11 @@ final class NotesBoxes extends GraphicalElement implements InGroupable {
|
|||||||
public void add(NoteBox noteBox, ParticipantBox participantBox1, ParticipantBox participantBox2) {
|
public void add(NoteBox noteBox, ParticipantBox participantBox1, ParticipantBox participantBox2) {
|
||||||
notes.add(noteBox);
|
notes.add(noteBox);
|
||||||
participants1.add(participantBox1);
|
participants1.add(participantBox1);
|
||||||
if (participantBox2 == null) {
|
if (participantBox2 == null)
|
||||||
participants2.add(participantBox1);
|
participants2.add(participantBox1);
|
||||||
} else {
|
else
|
||||||
participants2.add(participantBox2);
|
participants2.add(participantBox2);
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void ensureConstraints(StringBounder stringBounder, ConstraintSet constraintSet) {
|
public void ensureConstraints(StringBounder stringBounder, ConstraintSet constraintSet) {
|
||||||
@ -79,7 +79,9 @@ final class NotesBoxes extends GraphicalElement implements InGroupable {
|
|||||||
final NoteBox noteBox2 = notes.get(j);
|
final NoteBox noteBox2 = notes.get(j);
|
||||||
final ParticipantBox otherParticipantBox1 = participants1.get(j);
|
final ParticipantBox otherParticipantBox1 = participants1.get(j);
|
||||||
final double width2 = noteBox2.getPreferredWidth(stringBounder);
|
final double width2 = noteBox2.getPreferredWidth(stringBounder);
|
||||||
constraintSet.getConstraint(participantBox2, otherParticipantBox1).ensureValue((width + width2) / 2);
|
if (participantBox2 != otherParticipantBox1)
|
||||||
|
constraintSet.getConstraint(participantBox2, otherParticipantBox1)
|
||||||
|
.ensureValue((width + width2) / 2);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -88,9 +90,9 @@ final class NotesBoxes extends GraphicalElement implements InGroupable {
|
|||||||
double result = Double.MAX_VALUE;
|
double result = Double.MAX_VALUE;
|
||||||
for (NoteBox n : notes) {
|
for (NoteBox n : notes) {
|
||||||
final double m = n.getMinX(stringBounder);
|
final double m = n.getMinX(stringBounder);
|
||||||
if (m < result) {
|
if (m < result)
|
||||||
result = m;
|
result = m;
|
||||||
}
|
|
||||||
}
|
}
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
@ -99,9 +101,9 @@ final class NotesBoxes extends GraphicalElement implements InGroupable {
|
|||||||
double result = -Double.MAX_VALUE;
|
double result = -Double.MAX_VALUE;
|
||||||
for (NoteBox n : notes) {
|
for (NoteBox n : notes) {
|
||||||
final double m = n.getMaxX(stringBounder);
|
final double m = n.getMaxX(stringBounder);
|
||||||
if (m > result) {
|
if (m > result)
|
||||||
result = m;
|
result = m;
|
||||||
}
|
|
||||||
}
|
}
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
@ -112,9 +114,9 @@ final class NotesBoxes extends GraphicalElement implements InGroupable {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void drawInternalU(UGraphic ug, double maxX, Context2D context) {
|
protected void drawInternalU(UGraphic ug, double maxX, Context2D context) {
|
||||||
for (NoteBox n : notes) {
|
for (NoteBox n : notes)
|
||||||
n.drawInternalU(ug, maxX, context);
|
n.drawInternalU(ug, maxX, context);
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -122,9 +124,9 @@ final class NotesBoxes extends GraphicalElement implements InGroupable {
|
|||||||
double result = Double.MAX_VALUE;
|
double result = Double.MAX_VALUE;
|
||||||
for (NoteBox n : notes) {
|
for (NoteBox n : notes) {
|
||||||
final double m = n.getStartingX(stringBounder);
|
final double m = n.getStartingX(stringBounder);
|
||||||
if (m < result) {
|
if (m < result)
|
||||||
result = m;
|
result = m;
|
||||||
}
|
|
||||||
}
|
}
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
@ -140,9 +142,9 @@ final class NotesBoxes extends GraphicalElement implements InGroupable {
|
|||||||
double result = 0;
|
double result = 0;
|
||||||
for (NoteBox n : notes) {
|
for (NoteBox n : notes) {
|
||||||
final double m = n.getPreferredHeight(stringBounder);
|
final double m = n.getPreferredHeight(stringBounder);
|
||||||
if (m > result) {
|
if (m > result)
|
||||||
result = m;
|
result = m;
|
||||||
}
|
|
||||||
}
|
}
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user