aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJeremias Maerki <jeremias@apache.org>2010-04-23 14:39:20 +0000
committerJeremias Maerki <jeremias@apache.org>2010-04-23 14:39:20 +0000
commit1e649a305c5e55904afffcde5e55519d9e486f68 (patch)
treef1fbb832cbed9a1c850a9e71468abdddcbcc324f
parentf90e643f6ae1ef50036a18a83f81ac74ffbe116c (diff)
downloadxmlgraphics-fop-1e649a305c5e55904afffcde5e55519d9e486f68.tar.gz
xmlgraphics-fop-1e649a305c5e55904afffcde5e55519d9e486f68.zip
Improved painting of double rules a bit, fixing a bug causing the message: "Invalid axis rule: unable to draw line"
git-svn-id: https://svn.apache.org/repos/asf/xmlgraphics/fop/trunk@937315 13f79535-47bb-0310-9956-ffa450edef68
-rw-r--r--src/java/org/apache/fop/afp/AFPBorderPainter.java18
-rw-r--r--src/java/org/apache/fop/afp/AFPLineDataInfo.java14
2 files changed, 28 insertions, 4 deletions
diff --git a/src/java/org/apache/fop/afp/AFPBorderPainter.java b/src/java/org/apache/fop/afp/AFPBorderPainter.java
index 4c56c0def..85046dbed 100644
--- a/src/java/org/apache/fop/afp/AFPBorderPainter.java
+++ b/src/java/org/apache/fop/afp/AFPBorderPainter.java
@@ -91,26 +91,36 @@ public class AFPBorderPainter extends AbstractAFPPainter {
lineDataInfo.setRotation(paintingState.getRotation());
lineDataInfo.x1 = Math.round(x1);
lineDataInfo.y1 = Math.round(y1);
+ float thickness;
if (borderPaintInfo.isHorizontal()) {
- lineDataInfo.setThickness(Math.round(y2 - y1));
+ thickness = y2 - y1;
} else {
- lineDataInfo.setThickness(Math.round(x2 - x1));
+ thickness = x2 - x1;
}
+ lineDataInfo.setThickness(Math.round(thickness));
// handle border-*-style
switch (borderPaintInfo.getStyle()) {
case Constants.EN_DOUBLE:
+ int thickness3 = (int)Math.floor(thickness / 3f);
+ lineDataInfo.setThickness(thickness3);
if (borderPaintInfo.isHorizontal()) {
lineDataInfo.x2 = Math.round(x2);
lineDataInfo.y2 = lineDataInfo.y1;
dataStream.createLine(lineDataInfo);
- lineDataInfo.y1 += Math.round((lineDataInfo.thickness / 3) * 2);
+ int distance = thickness3 * 2;
+ lineDataInfo = new AFPLineDataInfo(lineDataInfo);
+ lineDataInfo.y1 += distance;
+ lineDataInfo.y2 += distance;
dataStream.createLine(lineDataInfo);
} else {
lineDataInfo.x2 = lineDataInfo.x1;
lineDataInfo.y2 = Math.round(y2);
dataStream.createLine(lineDataInfo);
- lineDataInfo.x1 += Math.round((lineDataInfo.thickness / 3) * 2);
+ int distance = thickness3 * 2;
+ lineDataInfo = new AFPLineDataInfo(lineDataInfo);
+ lineDataInfo.x1 += distance;
+ lineDataInfo.x2 += distance;
dataStream.createLine(lineDataInfo);
}
break;
diff --git a/src/java/org/apache/fop/afp/AFPLineDataInfo.java b/src/java/org/apache/fop/afp/AFPLineDataInfo.java
index f3acf4f71..a056ebf1f 100644
--- a/src/java/org/apache/fop/afp/AFPLineDataInfo.java
+++ b/src/java/org/apache/fop/afp/AFPLineDataInfo.java
@@ -52,6 +52,20 @@ public class AFPLineDataInfo {
}
/**
+ * Copy constructor.
+ * @param template the object to copy
+ */
+ public AFPLineDataInfo(AFPLineDataInfo template) {
+ this.x1 = template.x1;
+ this.y1 = template.y1;
+ this.x2 = template.x2;
+ this.y2 = template.y2;
+ this.thickness = template.thickness;
+ this.color = template.color;
+ this.rotation = template.rotation;
+ }
+
+ /**
* Returns the X1 coordinate
*
* @return the X1 coordinate