diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/org/apache/fop/fo/flow/TableCell.java | 4 | ||||
-rw-r--r-- | src/org/apache/fop/fo/flow/TableColumn.java | 22 | ||||
-rw-r--r-- | src/org/apache/fop/fo/flow/TableRow.java | 27 |
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); |