aboutsummaryrefslogtreecommitdiffstats
path: root/src/org
diff options
context:
space:
mode:
Diffstat (limited to 'src/org')
-rw-r--r--src/org/apache/fop/fo/flow/TableCell.java4
-rw-r--r--src/org/apache/fop/fo/flow/TableColumn.java22
-rw-r--r--src/org/apache/fop/fo/flow/TableRow.java27
3 files changed, 52 insertions, 1 deletions
diff --git a/src/org/apache/fop/fo/flow/TableCell.java b/src/org/apache/fop/fo/flow/TableCell.java
index 16aba1704..ccb397b3d 100644
--- a/src/org/apache/fop/fo/flow/TableCell.java
+++ b/src/org/apache/fop/fo/flow/TableCell.java
@@ -260,6 +260,10 @@ public class TableCell extends FObj {
areaContainer.end();
area.addChild(areaContainer);
+ area.setHeight(getHeight());
+ // reset absoluteHeight to beginning of row
+ area.setAbsoluteHeight(areaContainer.getAbsoluteHeight());
+
return new Status(Status.OK);
}
diff --git a/src/org/apache/fop/fo/flow/TableColumn.java b/src/org/apache/fop/fo/flow/TableColumn.java
index 64398c22a..9d668b8a3 100644
--- a/src/org/apache/fop/fo/flow/TableColumn.java
+++ b/src/org/apache/fop/fo/flow/TableColumn.java
@@ -74,6 +74,11 @@ public class TableColumn extends FObj {
ColorType borderRightColor;
int borderRightWidth;
int borderRightStyle;
+ int paddingTop;
+ int paddingBottom;
+ int paddingLeft;
+ int paddingRight;
+
int columnWidth;
int columnOffset;
@@ -167,6 +172,21 @@ public class TableColumn extends FObj {
this.borderRightStyle =
this.properties.get("border-right-style").getEnum();
}
+ this.paddingTop =
+ this.properties.get("padding").getLength().mvalue();
+ this.paddingLeft = this.paddingTop;
+ this.paddingRight = this.paddingTop;
+ this.paddingBottom = this.paddingTop;
+ if (this.paddingTop == 0) {
+ this.paddingTop =
+ this.properties.get("padding-top").getLength().mvalue();
+ this.paddingLeft =
+ this.properties.get("padding-left").getLength().mvalue();
+ this.paddingBottom =
+ this.properties.get("padding-bottom").getLength().mvalue();
+ this.paddingRight =
+ this.properties.get("padding-right").getLength().mvalue();
+ }
this.columnWidth =
this.properties.get("column-width").getLength().mvalue();
@@ -179,6 +199,8 @@ public class TableColumn extends FObj {
new AreaContainer(fs, columnOffset - area.borderWidthLeft, -area.borderWidthTop, columnWidth,
area.getHeight(), Position.RELATIVE);
areaContainer.setPage(area.getPage());
+ areaContainer.setPadding(paddingTop, paddingLeft, paddingBottom,
+ paddingRight);
areaContainer.setBackgroundColor(backgroundColor);
areaContainer.setBorderStyle(borderTopStyle, borderLeftStyle,
borderBottomStyle, borderRightStyle);
diff --git a/src/org/apache/fop/fo/flow/TableRow.java b/src/org/apache/fop/fo/flow/TableRow.java
index 7ee6edb6f..af4d03176 100644
--- a/src/org/apache/fop/fo/flow/TableRow.java
+++ b/src/org/apache/fop/fo/flow/TableRow.java
@@ -93,6 +93,10 @@ public class TableRow extends FObj {
ColorType borderRightColor;
int borderRightWidth;
int borderRightStyle;
+ int paddingTop;
+ int paddingBottom;
+ int paddingLeft;
+ int paddingRight;
int widthOfCellsSoFar = 0;
int largestCellHeight = 0;
@@ -178,6 +182,21 @@ public class TableRow extends FObj {
this.borderRightStyle =
this.properties.get("border-right-style").getEnum();
}
+ this.paddingTop =
+ this.properties.get("padding").getLength().mvalue();
+ this.paddingLeft = this.paddingTop;
+ this.paddingRight = this.paddingTop;
+ this.paddingBottom = this.paddingTop;
+ if (this.paddingTop == 0) {
+ this.paddingTop =
+ this.properties.get("padding-top").getLength().mvalue();
+ this.paddingLeft =
+ this.properties.get("padding-left").getLength().mvalue();
+ this.paddingBottom =
+ this.properties.get("padding-bottom").getLength().mvalue();
+ this.paddingRight =
+ this.properties.get("padding-right").getLength().mvalue();
+ }
this.id=
this.properties.get("id").getString();
@@ -205,6 +224,8 @@ public class TableRow extends FObj {
area.getAllocationWidth(),
area.spaceLeft(), Position.RELATIVE);
areaContainer.setPage(area.getPage());
+ areaContainer.setPadding(paddingTop, paddingLeft, paddingBottom,
+ paddingRight);
areaContainer.setBackgroundColor(backgroundColor);
areaContainer.setBorderStyle(borderTopStyle, borderLeftStyle, borderBottomStyle, borderRightStyle);
areaContainer.setBorderWidth(borderTopWidth, borderLeftWidth, borderBottomWidth, borderRightWidth);
@@ -265,7 +286,11 @@ public class TableRow extends FObj {
area.addChild(areaContainer);
areaContainer.end();
- area.addDisplaySpace(largestCellHeight);
+ area.addDisplaySpace(largestCellHeight
+ + areaContainer.getPaddingTop()
+ + areaContainer.borderWidthTop
+ + areaContainer.getPaddingBottom()
+ + areaContainer.borderWidthBottom);
// bug fix from Eric Schaeffer
//area.increaseHeight(largestCellHeight);