Bugzilla 52599 - avoid duplicate text when rendering slides in HSLF

git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@1292273 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Yegor Kozlov 2012-02-22 13:23:31 +00:00
parent 93c7050f8c
commit df61625757
5 changed files with 24 additions and 2 deletions

View File

@ -34,6 +34,7 @@
<changes> <changes>
<release version="3.8-beta6" date="2012-??-??"> <release version="3.8-beta6" date="2012-??-??">
<action dev="poi-developers" type="fix">52599 - avoid duplicate text when rendering slides in HSLF</action>
<action dev="poi-developers" type="fix">52598 - respect slide background when rendering slides in HSLF</action> <action dev="poi-developers" type="fix">52598 - respect slide background when rendering slides in HSLF</action>
<action dev="poi-developers" type="fix">51731 - fixed painting shape outlines in HSLF</action> <action dev="poi-developers" type="fix">51731 - fixed painting shape outlines in HSLF</action>
<action dev="poi-developers" type="fix">52701 - fixed seting vertical alignment for XSLFTableCell</action> <action dev="poi-developers" type="fix">52701 - fixed seting vertical alignment for XSLFTableCell</action>

View File

@ -91,6 +91,7 @@ public final class Slide extends Sheet
for(int k=0; k<_otherRuns.length; i++, k++) { for(int k=0; k<_otherRuns.length; i++, k++) {
_runs[i] = _otherRuns[k]; _runs[i] = _otherRuns[k];
_runs[i].setSheet(this); _runs[i].setSheet(this);
_runs[i].setIndex(-1); // runs found in PPDrawing are not linked with SlideListWithTexts
} }
} }

View File

@ -48,7 +48,7 @@ public final class TextRun
private SlideShow slideShow; private SlideShow slideShow;
private Sheet _sheet; private Sheet _sheet;
private int shapeId; private int shapeId;
private int slwtIndex; //position in the owning SlideListWithText private int slwtIndex = -1; //position in the owning SlideListWithText
/** /**
* all text run records that follow TextHeaderAtom. * all text run records that follow TextHeaderAtom.
* (there can be misc InteractiveInfo, TxInteractiveInfo and other records) * (there can be misc InteractiveInfo, TxInteractiveInfo and other records)

View File

@ -47,7 +47,7 @@ public final class TestTextShape extends TestCase {
assertNotNull(shape.getEscherTextboxWrapper()); assertNotNull(shape.getEscherTextboxWrapper());
assertEquals("", shape.getText()); assertEquals("", shape.getText());
assertSame(run, shape.createTextRun()); assertSame(run, shape.createTextRun());
assertEquals(-1, run.getIndex());
} }
public void testCreateTextBox(){ public void testCreateTextBox(){
@ -195,4 +195,24 @@ public final class TestTextShape extends TestCase {
assertEquals(0.05, tx.getMarginTop()*Shape.EMU_PER_POINT/Shape.EMU_PER_INCH, 0.01); assertEquals(0.05, tx.getMarginTop()*Shape.EMU_PER_POINT/Shape.EMU_PER_INCH, 0.01);
assertEquals(0.05, tx.getMarginBottom()*Shape.EMU_PER_POINT/Shape.EMU_PER_INCH, 0.01); assertEquals(0.05, tx.getMarginBottom()*Shape.EMU_PER_POINT/Shape.EMU_PER_INCH, 0.01);
} }
public void test52599() throws IOException {
SlideShow ppt = new SlideShow(_slTests.openResourceAsStream("52599.ppt"));
Slide slide = ppt.getSlides()[0];
Shape[] sh = slide.getShapes();
assertEquals(3, sh.length);
TextShape sh0 = (TextShape)sh[0];
assertEquals(null, sh0.getText());
assertEquals(null, sh0.getTextRun());
TextShape sh1 = (TextShape)sh[1];
assertEquals(null, sh1.getText());
assertEquals(null, sh1.getTextRun());
TextShape sh2 = (TextShape)sh[2];
assertEquals("this box should be shown just once", sh2.getText());
assertEquals(-1, sh2.getTextRun().getIndex());
}
} }

Binary file not shown.