You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

TestXSSFDrawing.java 29KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721
  1. /* ====================================================================
  2. Licensed to the Apache Software Foundation (ASF) under one or more
  3. contributor license agreements. See the NOTICE file distributed with
  4. this work for additional information regarding copyright ownership.
  5. The ASF licenses this file to You under the Apache License, Version 2.0
  6. (the "License"); you may not use this file except in compliance with
  7. the License. You may obtain a copy of the License at
  8. http://www.apache.org/licenses/LICENSE-2.0
  9. Unless required by applicable law or agreed to in writing, software
  10. distributed under the License is distributed on an "AS IS" BASIS,
  11. WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. See the License for the specific language governing permissions and
  13. limitations under the License.
  14. ==================================================================== */
  15. package org.apache.poi.xssf.usermodel;
  16. import java.awt.Color;
  17. import java.io.IOException;
  18. import java.util.Arrays;
  19. import java.util.List;
  20. import junit.framework.TestCase;
  21. import org.apache.poi.POIXMLDocumentPart;
  22. import org.apache.poi.openxml4j.opc.OPCPackage;
  23. import org.apache.poi.ss.usermodel.FontUnderline;
  24. import org.apache.poi.xssf.XSSFTestDataSamples;
  25. import org.openxmlformats.schemas.drawingml.x2006.main.CTTextCharacterProperties;
  26. import org.openxmlformats.schemas.drawingml.x2006.main.CTTextParagraph;
  27. import org.openxmlformats.schemas.drawingml.x2006.main.STTextUnderlineType;
  28. import org.openxmlformats.schemas.drawingml.x2006.spreadsheetDrawing.CTDrawing;
  29. /**
  30. * @author Yegor Kozlov
  31. */
  32. public class TestXSSFDrawing extends TestCase {
  33. public void testRead(){
  34. XSSFWorkbook wb = XSSFTestDataSamples.openSampleWorkbook("WithDrawing.xlsx");
  35. XSSFSheet sheet = wb.getSheetAt(0);
  36. //the sheet has one relationship and it is XSSFDrawing
  37. List<POIXMLDocumentPart> rels = sheet.getRelations();
  38. assertEquals(1, rels.size());
  39. assertTrue(rels.get(0) instanceof XSSFDrawing);
  40. XSSFDrawing drawing = (XSSFDrawing)rels.get(0);
  41. //sheet.createDrawingPatriarch() should return the same instance of XSSFDrawing
  42. assertSame(drawing, sheet.createDrawingPatriarch());
  43. String drawingId = drawing.getPackageRelationship().getId();
  44. //there should be a relation to this drawing in the worksheet
  45. assertTrue(sheet.getCTWorksheet().isSetDrawing());
  46. assertEquals(drawingId, sheet.getCTWorksheet().getDrawing().getId());
  47. List<XSSFShape> shapes = drawing.getShapes();
  48. assertEquals(6, shapes.size());
  49. assertTrue(shapes.get(0) instanceof XSSFPicture);
  50. assertTrue(shapes.get(1) instanceof XSSFPicture);
  51. assertTrue(shapes.get(2) instanceof XSSFPicture);
  52. assertTrue(shapes.get(3) instanceof XSSFPicture);
  53. assertTrue(shapes.get(4) instanceof XSSFSimpleShape);
  54. assertTrue(shapes.get(5) instanceof XSSFPicture);
  55. for(XSSFShape sh : shapes) assertNotNull(sh.getAnchor());
  56. assertNotNull(XSSFTestDataSamples.writeOutAndReadBack(wb));
  57. }
  58. public void testNew() throws Exception {
  59. XSSFWorkbook wb = new XSSFWorkbook();
  60. XSSFSheet sheet = wb.createSheet();
  61. //multiple calls of createDrawingPatriarch should return the same instance of XSSFDrawing
  62. XSSFDrawing dr1 = sheet.createDrawingPatriarch();
  63. XSSFDrawing dr2 = sheet.createDrawingPatriarch();
  64. assertSame(dr1, dr2);
  65. List<POIXMLDocumentPart> rels = sheet.getRelations();
  66. assertEquals(1, rels.size());
  67. assertTrue(rels.get(0) instanceof XSSFDrawing);
  68. XSSFDrawing drawing = (XSSFDrawing)rels.get(0);
  69. String drawingId = drawing.getPackageRelationship().getId();
  70. //there should be a relation to this drawing in the worksheet
  71. assertTrue(sheet.getCTWorksheet().isSetDrawing());
  72. assertEquals(drawingId, sheet.getCTWorksheet().getDrawing().getId());
  73. XSSFConnector c1= drawing.createConnector(new XSSFClientAnchor(0,0,0,0,0,0,2,2));
  74. c1.setLineWidth(2.5);
  75. c1.setLineStyle(1);
  76. XSSFShapeGroup c2 = drawing.createGroup(new XSSFClientAnchor(0,0,0,0,0,0,5,5));
  77. assertNotNull(c2);
  78. XSSFSimpleShape c3 = drawing.createSimpleShape(new XSSFClientAnchor(0,0,0,0,2,2,3,4));
  79. c3.setText(new XSSFRichTextString("Test String"));
  80. c3.setFillColor(128, 128, 128);
  81. XSSFTextBox c4 = drawing.createTextbox(new XSSFClientAnchor(0,0,0,0,4,4,5,6));
  82. XSSFRichTextString rt = new XSSFRichTextString("Test String");
  83. rt.applyFont(0, 5, wb.createFont());
  84. rt.applyFont(5, 6, wb.createFont());
  85. c4.setText(rt);
  86. c4.setNoFill(true);
  87. assertEquals(4, drawing.getCTDrawing().sizeOfTwoCellAnchorArray());
  88. List<XSSFShape> shapes = drawing.getShapes();
  89. assertEquals(4, shapes.size());
  90. assertTrue(shapes.get(0) instanceof XSSFConnector);
  91. assertTrue(shapes.get(1) instanceof XSSFShapeGroup);
  92. assertTrue(shapes.get(2) instanceof XSSFSimpleShape);
  93. assertTrue(shapes.get(3) instanceof XSSFSimpleShape); //
  94. // Save and re-load it
  95. wb = XSSFTestDataSamples.writeOutAndReadBack(wb);
  96. sheet = wb.getSheetAt(0);
  97. // Check
  98. dr1 = sheet.createDrawingPatriarch();
  99. CTDrawing ctDrawing = dr1.getCTDrawing();
  100. // Connector, shapes and text boxes are all two cell anchors
  101. assertEquals(0, ctDrawing.sizeOfAbsoluteAnchorArray());
  102. assertEquals(0, ctDrawing.sizeOfOneCellAnchorArray());
  103. assertEquals(4, ctDrawing.sizeOfTwoCellAnchorArray());
  104. shapes = dr1.getShapes();
  105. assertEquals(4, shapes.size());
  106. assertTrue(shapes.get(0) instanceof XSSFConnector);
  107. assertTrue(shapes.get(1) instanceof XSSFShapeGroup);
  108. assertTrue(shapes.get(2) instanceof XSSFSimpleShape);
  109. assertTrue(shapes.get(3) instanceof XSSFSimpleShape); //
  110. // Ensure it got the right namespaces
  111. String xml = ctDrawing.toString();
  112. assertTrue(xml.contains("xmlns:xdr=\"http://schemas.openxmlformats.org/drawingml/2006/spreadsheetDrawing\""));
  113. assertTrue(xml.contains("xmlns:a=\"http://schemas.openxmlformats.org/drawingml/2006/main\""));
  114. assertNotNull(XSSFTestDataSamples.writeOutAndReadBack(wb));
  115. }
  116. public void testMultipleDrawings() throws IOException{
  117. XSSFWorkbook wb = new XSSFWorkbook();
  118. for (int i = 0; i < 3; i++) {
  119. XSSFSheet sheet = wb.createSheet();
  120. XSSFDrawing drawing = sheet.createDrawingPatriarch();
  121. assertNotNull(drawing);
  122. }
  123. OPCPackage pkg = wb.getPackage();
  124. try {
  125. assertEquals(3, pkg.getPartsByContentType(XSSFRelation.DRAWINGS.getContentType()).size());
  126. assertNotNull(XSSFTestDataSamples.writeOutAndReadBack(wb));
  127. } finally {
  128. pkg.close();
  129. }
  130. }
  131. public void testClone() throws Exception{
  132. XSSFWorkbook wb = XSSFTestDataSamples.openSampleWorkbook("WithDrawing.xlsx");
  133. XSSFSheet sheet1 = wb.getSheetAt(0);
  134. XSSFSheet sheet2 = wb.cloneSheet(0);
  135. //the source sheet has one relationship and it is XSSFDrawing
  136. List<POIXMLDocumentPart> rels1 = sheet1.getRelations();
  137. assertEquals(1, rels1.size());
  138. assertTrue(rels1.get(0) instanceof XSSFDrawing);
  139. List<POIXMLDocumentPart> rels2 = sheet2.getRelations();
  140. assertEquals(1, rels2.size());
  141. assertTrue(rels2.get(0) instanceof XSSFDrawing);
  142. XSSFDrawing drawing1 = (XSSFDrawing)rels1.get(0);
  143. XSSFDrawing drawing2 = (XSSFDrawing)rels2.get(0);
  144. assertNotSame(drawing1, drawing2); // drawing2 is a clone of drawing1
  145. List<XSSFShape> shapes1 = drawing1.getShapes();
  146. List<XSSFShape> shapes2 = drawing2.getShapes();
  147. assertEquals(shapes1.size(), shapes2.size());
  148. for(int i = 0; i < shapes1.size(); i++){
  149. XSSFShape sh1 = shapes1.get(i);
  150. XSSFShape sh2 = shapes2.get(i);
  151. assertTrue(sh1.getClass() == sh2.getClass());
  152. assertEquals(sh1.getShapeProperties().toString(), sh2.getShapeProperties().toString());
  153. }
  154. assertNotNull(XSSFTestDataSamples.writeOutAndReadBack(wb));
  155. }
  156. /**
  157. * ensure that rich text attributes defined in a XSSFRichTextString
  158. * are passed to XSSFSimpleShape.
  159. *
  160. * See Bugzilla 52219.
  161. */
  162. public void testRichText(){
  163. XSSFWorkbook wb = new XSSFWorkbook();
  164. XSSFSheet sheet = wb.createSheet();
  165. XSSFDrawing drawing = sheet.createDrawingPatriarch();
  166. XSSFTextBox shape = drawing.createTextbox(new XSSFClientAnchor(0, 0, 0, 0, 2, 2, 3, 4));
  167. XSSFRichTextString rt = new XSSFRichTextString("Test String");
  168. XSSFFont font = wb.createFont();
  169. font.setColor(new XSSFColor(new Color(0, 128, 128)));
  170. font.setItalic(true);
  171. font.setBold(true);
  172. font.setUnderline(FontUnderline.SINGLE);
  173. rt.applyFont(font);
  174. shape.setText(rt);
  175. CTTextParagraph pr = shape.getCTShape().getTxBody().getPArray(0);
  176. assertEquals(1, pr.sizeOfRArray());
  177. CTTextCharacterProperties rPr = pr.getRArray(0).getRPr();
  178. assertEquals(true, rPr.getB());
  179. assertEquals(true, rPr.getI());
  180. assertEquals(STTextUnderlineType.SNG, rPr.getU());
  181. assertTrue(Arrays.equals(
  182. new byte[]{0, (byte)128, (byte)128} ,
  183. rPr.getSolidFill().getSrgbClr().getVal()));
  184. assertNotNull(XSSFTestDataSamples.writeOutAndReadBack(wb));
  185. }
  186. /**
  187. * test that anchor is not null when reading shapes from existing drawings
  188. */
  189. public void testReadAnchors(){
  190. XSSFWorkbook wb = new XSSFWorkbook();
  191. XSSFSheet sheet = wb.createSheet();
  192. XSSFDrawing drawing = sheet.createDrawingPatriarch();
  193. XSSFClientAnchor anchor1 = new XSSFClientAnchor(0, 0, 0, 0, 2, 2, 3, 4);
  194. XSSFShape shape1 = drawing.createTextbox(anchor1);
  195. assertNotNull(shape1);
  196. XSSFClientAnchor anchor2 = new XSSFClientAnchor(0, 0, 0, 0, 2, 2, 3, 5);
  197. XSSFShape shape2 = drawing.createTextbox(anchor2);
  198. assertNotNull(shape2);
  199. int pictureIndex= wb.addPicture(new byte[]{}, XSSFWorkbook.PICTURE_TYPE_PNG);
  200. XSSFClientAnchor anchor3 = new XSSFClientAnchor(0, 0, 0, 0, 2, 2, 3, 6);
  201. XSSFShape shape3 = drawing.createPicture(anchor3, pictureIndex);
  202. assertNotNull(shape3);
  203. wb = XSSFTestDataSamples.writeOutAndReadBack(wb);
  204. sheet = wb.getSheetAt(0);
  205. drawing = sheet.createDrawingPatriarch();
  206. List<XSSFShape> shapes = drawing.getShapes();
  207. assertEquals(shapes.get(0).getAnchor(), anchor1);
  208. assertEquals(shapes.get(1).getAnchor(), anchor2);
  209. assertEquals(shapes.get(2).getAnchor(), anchor3);
  210. assertNotNull(XSSFTestDataSamples.writeOutAndReadBack(wb));
  211. }
  212. /**
  213. * ensure that font and color rich text attributes defined in a XSSFRichTextString
  214. * are passed to XSSFSimpleShape.
  215. *
  216. * See Bugzilla 54969.
  217. */
  218. public void testRichTextFontAndColor() {
  219. XSSFWorkbook wb = new XSSFWorkbook();
  220. XSSFSheet sheet = wb.createSheet();
  221. XSSFDrawing drawing = sheet.createDrawingPatriarch();
  222. XSSFTextBox shape = drawing.createTextbox(new XSSFClientAnchor(0, 0, 0, 0, 2, 2, 3, 4));
  223. XSSFRichTextString rt = new XSSFRichTextString("Test String");
  224. XSSFFont font = wb.createFont();
  225. font.setColor(new XSSFColor(new Color(0, 128, 128)));
  226. font.setFontName("Arial");
  227. rt.applyFont(font);
  228. shape.setText(rt);
  229. CTTextParagraph pr = shape.getCTShape().getTxBody().getPArray(0);
  230. assertEquals(1, pr.sizeOfRArray());
  231. CTTextCharacterProperties rPr = pr.getRArray(0).getRPr();
  232. assertEquals("Arial", rPr.getLatin().getTypeface());
  233. assertTrue(Arrays.equals(
  234. new byte[]{0, (byte)128, (byte)128} ,
  235. rPr.getSolidFill().getSrgbClr().getVal()));
  236. assertNotNull(XSSFTestDataSamples.writeOutAndReadBack(wb));
  237. }
  238. /**
  239. * Test setText single paragraph to ensure backwards compatibility
  240. */
  241. public void testSetTextSingleParagraph() {
  242. XSSFWorkbook wb = new XSSFWorkbook();
  243. XSSFSheet sheet = wb.createSheet();
  244. XSSFDrawing drawing = sheet.createDrawingPatriarch();
  245. XSSFTextBox shape = drawing.createTextbox(new XSSFClientAnchor(0, 0, 0, 0, 2, 2, 3, 4));
  246. XSSFRichTextString rt = new XSSFRichTextString("Test String");
  247. XSSFFont font = wb.createFont();
  248. font.setColor(new XSSFColor(new Color(0, 255, 255)));
  249. font.setFontName("Arial");
  250. rt.applyFont(font);
  251. shape.setText(rt);
  252. List<XSSFTextParagraph> paras = shape.getTextParagraphs();
  253. assertEquals(1, paras.size());
  254. assertEquals("Test String", paras.get(0).getText());
  255. List<XSSFTextRun> runs = paras.get(0).getTextRuns();
  256. assertEquals(1, runs.size());
  257. assertEquals("Arial", runs.get(0).getFontFamily());
  258. Color clr = runs.get(0).getFontColor();
  259. assertTrue(Arrays.equals(
  260. new int[] { 0, 255, 255 } ,
  261. new int[] { clr.getRed(), clr.getGreen(), clr.getBlue() }));
  262. assertNotNull(XSSFTestDataSamples.writeOutAndReadBack(wb));
  263. }
  264. /**
  265. * Test addNewTextParagraph
  266. */
  267. public void testAddNewTextParagraph() {
  268. XSSFWorkbook wb = new XSSFWorkbook();
  269. XSSFSheet sheet = wb.createSheet();
  270. XSSFDrawing drawing = sheet.createDrawingPatriarch();
  271. XSSFTextBox shape = drawing.createTextbox(new XSSFClientAnchor(0, 0, 0, 0, 2, 2, 3, 4));
  272. XSSFTextParagraph para = shape.addNewTextParagraph();
  273. para.addNewTextRun().setText("Line 1");
  274. List<XSSFTextParagraph> paras = shape.getTextParagraphs();
  275. assertEquals(2, paras.size()); // this should be 2 as XSSFSimpleShape creates a default paragraph (no text), and then we add a string to that.
  276. List<XSSFTextRun> runs = para.getTextRuns();
  277. assertEquals(1, runs.size());
  278. assertEquals("Line 1", runs.get(0).getText());
  279. assertNotNull(XSSFTestDataSamples.writeOutAndReadBack(wb));
  280. }
  281. /**
  282. * Test addNewTextParagraph using RichTextString
  283. */
  284. public void testAddNewTextParagraphWithRTS() {
  285. XSSFWorkbook wb = new XSSFWorkbook();
  286. XSSFSheet sheet = wb.createSheet();
  287. XSSFDrawing drawing = sheet.createDrawingPatriarch();
  288. XSSFTextBox shape = drawing.createTextbox(new XSSFClientAnchor(0, 0, 0, 0, 2, 2, 3, 4));
  289. XSSFRichTextString rt = new XSSFRichTextString("Test Rich Text String");
  290. XSSFFont font = wb.createFont();
  291. font.setColor(new XSSFColor(new Color(0, 255, 255)));
  292. font.setFontName("Arial");
  293. rt.applyFont(font);
  294. XSSFFont midfont = wb.createFont();
  295. midfont.setColor(new XSSFColor(new Color(0, 255, 0)));
  296. rt.applyFont(5, 14, midfont); // set the text "Rich Text" to be green and the default font
  297. XSSFTextParagraph para = shape.addNewTextParagraph(rt);
  298. // Save and re-load it
  299. wb = XSSFTestDataSamples.writeOutAndReadBack(wb);
  300. sheet = wb.getSheetAt(0);
  301. // Check
  302. drawing = sheet.createDrawingPatriarch();
  303. List<XSSFShape> shapes = drawing.getShapes();
  304. assertEquals(1, shapes.size());
  305. assertTrue(shapes.get(0) instanceof XSSFSimpleShape);
  306. XSSFSimpleShape sshape = (XSSFSimpleShape) shapes.get(0);
  307. List<XSSFTextParagraph> paras = sshape.getTextParagraphs();
  308. assertEquals(2, paras.size()); // this should be 2 as XSSFSimpleShape creates a default paragraph (no text), and then we add a string to that.
  309. List<XSSFTextRun> runs = para.getTextRuns();
  310. assertEquals(3, runs.size());
  311. // first run properties
  312. assertEquals("Test ", runs.get(0).getText());
  313. assertEquals("Arial", runs.get(0).getFontFamily());
  314. Color clr = runs.get(0).getFontColor();
  315. assertTrue(Arrays.equals(
  316. new int[] { 0, 255, 255 } ,
  317. new int[] { clr.getRed(), clr.getGreen(), clr.getBlue() }));
  318. // second run properties
  319. assertEquals("Rich Text", runs.get(1).getText());
  320. assertEquals(XSSFFont.DEFAULT_FONT_NAME, runs.get(1).getFontFamily());
  321. clr = runs.get(1).getFontColor();
  322. assertTrue(Arrays.equals(
  323. new int[] { 0, 255, 0 } ,
  324. new int[] { clr.getRed(), clr.getGreen(), clr.getBlue() }));
  325. // third run properties
  326. assertEquals(" String", runs.get(2).getText());
  327. assertEquals("Arial", runs.get(2).getFontFamily());
  328. clr = runs.get(2).getFontColor();
  329. assertTrue(Arrays.equals(
  330. new int[] { 0, 255, 255 } ,
  331. new int[] { clr.getRed(), clr.getGreen(), clr.getBlue() }));
  332. assertNotNull(XSSFTestDataSamples.writeOutAndReadBack(wb));
  333. }
  334. /**
  335. * Test add multiple paragraphs and retrieve text
  336. */
  337. public void testAddMultipleParagraphs() {
  338. XSSFWorkbook wb = new XSSFWorkbook();
  339. XSSFSheet sheet = wb.createSheet();
  340. XSSFDrawing drawing = sheet.createDrawingPatriarch();
  341. XSSFTextBox shape = drawing.createTextbox(new XSSFClientAnchor(0, 0, 0, 0, 2, 2, 3, 4));
  342. XSSFTextParagraph para = shape.addNewTextParagraph();
  343. para.addNewTextRun().setText("Line 1");
  344. para = shape.addNewTextParagraph();
  345. para.addNewTextRun().setText("Line 2");
  346. para = shape.addNewTextParagraph();
  347. para.addNewTextRun().setText("Line 3");
  348. List<XSSFTextParagraph> paras = shape.getTextParagraphs();
  349. assertEquals(4, paras.size()); // this should be 4 as XSSFSimpleShape creates a default paragraph (no text), and then we added 3 paragraphs
  350. assertEquals("Line 1\nLine 2\nLine 3", shape.getText());
  351. assertNotNull(XSSFTestDataSamples.writeOutAndReadBack(wb));
  352. }
  353. /**
  354. * Test setting the text, then adding multiple paragraphs and retrieve text
  355. */
  356. public void testSetAddMultipleParagraphs() {
  357. XSSFWorkbook wb = new XSSFWorkbook();
  358. XSSFSheet sheet = wb.createSheet();
  359. XSSFDrawing drawing = sheet.createDrawingPatriarch();
  360. XSSFTextBox shape = drawing.createTextbox(new XSSFClientAnchor(0, 0, 0, 0, 2, 2, 3, 4));
  361. shape.setText("Line 1");
  362. XSSFTextParagraph para = shape.addNewTextParagraph();
  363. para.addNewTextRun().setText("Line 2");
  364. para = shape.addNewTextParagraph();
  365. para.addNewTextRun().setText("Line 3");
  366. List<XSSFTextParagraph> paras = shape.getTextParagraphs();
  367. assertEquals(3, paras.size()); // this should be 3 as we overwrote the default paragraph with setText, then added 2 new paragraphs
  368. assertEquals("Line 1\nLine 2\nLine 3", shape.getText());
  369. assertNotNull(XSSFTestDataSamples.writeOutAndReadBack(wb));
  370. }
  371. /**
  372. * Test reading text from a textbox in an existing file
  373. */
  374. public void testReadTextBox(){
  375. XSSFWorkbook wb = XSSFTestDataSamples.openSampleWorkbook("WithDrawing.xlsx");
  376. XSSFSheet sheet = wb.getSheetAt(0);
  377. //the sheet has one relationship and it is XSSFDrawing
  378. List<POIXMLDocumentPart> rels = sheet.getRelations();
  379. assertEquals(1, rels.size());
  380. assertTrue(rels.get(0) instanceof XSSFDrawing);
  381. XSSFDrawing drawing = (XSSFDrawing)rels.get(0);
  382. //sheet.createDrawingPatriarch() should return the same instance of XSSFDrawing
  383. assertSame(drawing, sheet.createDrawingPatriarch());
  384. String drawingId = drawing.getPackageRelationship().getId();
  385. //there should be a relation to this drawing in the worksheet
  386. assertTrue(sheet.getCTWorksheet().isSetDrawing());
  387. assertEquals(drawingId, sheet.getCTWorksheet().getDrawing().getId());
  388. List<XSSFShape> shapes = drawing.getShapes();
  389. assertEquals(6, shapes.size());
  390. assertTrue(shapes.get(4) instanceof XSSFSimpleShape);
  391. XSSFSimpleShape textbox = (XSSFSimpleShape) shapes.get(4);
  392. assertEquals("Sheet with various pictures\n(jpeg, png, wmf, emf and pict)", textbox.getText());
  393. assertNotNull(XSSFTestDataSamples.writeOutAndReadBack(wb));
  394. }
  395. /**
  396. * Test reading multiple paragraphs from a textbox in an existing file
  397. */
  398. public void testReadTextBoxParagraphs(){
  399. XSSFWorkbook wb = XSSFTestDataSamples.openSampleWorkbook("WithTextBox.xlsx");
  400. XSSFSheet sheet = wb.getSheetAt(0);
  401. //the sheet has one relationship and it is XSSFDrawing
  402. List<POIXMLDocumentPart> rels = sheet.getRelations();
  403. assertEquals(1, rels.size());
  404. assertTrue(rels.get(0) instanceof XSSFDrawing);
  405. XSSFDrawing drawing = (XSSFDrawing)rels.get(0);
  406. //sheet.createDrawingPatriarch() should return the same instance of XSSFDrawing
  407. assertSame(drawing, sheet.createDrawingPatriarch());
  408. String drawingId = drawing.getPackageRelationship().getId();
  409. //there should be a relation to this drawing in the worksheet
  410. assertTrue(sheet.getCTWorksheet().isSetDrawing());
  411. assertEquals(drawingId, sheet.getCTWorksheet().getDrawing().getId());
  412. List<XSSFShape> shapes = drawing.getShapes();
  413. assertEquals(1, shapes.size());
  414. assertTrue(shapes.get(0) instanceof XSSFSimpleShape);
  415. XSSFSimpleShape textbox = (XSSFSimpleShape) shapes.get(0);
  416. List<XSSFTextParagraph> paras = textbox.getTextParagraphs();
  417. assertEquals(3, paras.size());
  418. assertEquals("Line 2", paras.get(1).getText()); // check content of second paragraph
  419. assertEquals("Line 1\nLine 2\nLine 3", textbox.getText()); // check content of entire textbox
  420. // check attributes of paragraphs
  421. assertEquals(TextAlign.LEFT, paras.get(0).getTextAlign());
  422. assertEquals(TextAlign.CENTER, paras.get(1).getTextAlign());
  423. assertEquals(TextAlign.RIGHT, paras.get(2).getTextAlign());
  424. Color clr = paras.get(0).getTextRuns().get(0).getFontColor();
  425. assertTrue(Arrays.equals(
  426. new int[] { 255, 0, 0 } ,
  427. new int[] { clr.getRed(), clr.getGreen(), clr.getBlue() }));
  428. clr = paras.get(1).getTextRuns().get(0).getFontColor();
  429. assertTrue(Arrays.equals(
  430. new int[] { 0, 255, 0 } ,
  431. new int[] { clr.getRed(), clr.getGreen(), clr.getBlue() }));
  432. clr = paras.get(2).getTextRuns().get(0).getFontColor();
  433. assertTrue(Arrays.equals(
  434. new int[] { 0, 0, 255 } ,
  435. new int[] { clr.getRed(), clr.getGreen(), clr.getBlue() }));
  436. assertNotNull(XSSFTestDataSamples.writeOutAndReadBack(wb));
  437. }
  438. /**
  439. * Test adding and reading back paragraphs as bullet points
  440. */
  441. public void testAddBulletParagraphs() {
  442. XSSFWorkbook wb = new XSSFWorkbook();
  443. XSSFSheet sheet = wb.createSheet();
  444. XSSFDrawing drawing = sheet.createDrawingPatriarch();
  445. XSSFTextBox shape = drawing.createTextbox(new XSSFClientAnchor(0, 0, 0, 0, 2, 2, 10, 20));
  446. String paraString1 = "A normal paragraph";
  447. String paraString2 = "First bullet";
  448. String paraString3 = "Second bullet (level 1)";
  449. String paraString4 = "Third bullet";
  450. String paraString5 = "Another normal paragraph";
  451. String paraString6 = "First numbered bullet";
  452. String paraString7 = "Second bullet (level 1)";
  453. String paraString8 = "Third bullet (level 1)";
  454. String paraString9 = "Fourth bullet (level 1)";
  455. String paraString10 = "Fifth Bullet";
  456. XSSFTextParagraph para = shape.addNewTextParagraph(paraString1);
  457. para = shape.addNewTextParagraph(paraString2);
  458. para.setBullet(true);
  459. para = shape.addNewTextParagraph(paraString3);
  460. para.setBullet(true);
  461. para.setLevel(1);
  462. para = shape.addNewTextParagraph(paraString4);
  463. para.setBullet(true);
  464. para = shape.addNewTextParagraph(paraString5);
  465. para = shape.addNewTextParagraph(paraString6);
  466. para.setBullet(ListAutoNumber.ARABIC_PERIOD);
  467. para = shape.addNewTextParagraph(paraString7);
  468. para.setBullet(ListAutoNumber.ARABIC_PERIOD, 3);
  469. para.setLevel(1);
  470. para = shape.addNewTextParagraph(paraString8);
  471. para.setBullet(ListAutoNumber.ARABIC_PERIOD, 3);
  472. para.setLevel(1);
  473. para = shape.addNewTextParagraph("");
  474. para.setBullet(ListAutoNumber.ARABIC_PERIOD, 3);
  475. para.setLevel(1);
  476. para = shape.addNewTextParagraph(paraString9);
  477. para.setBullet(ListAutoNumber.ARABIC_PERIOD, 3);
  478. para.setLevel(1);
  479. para = shape.addNewTextParagraph(paraString10);
  480. para.setBullet(ListAutoNumber.ARABIC_PERIOD);
  481. // Save and re-load it
  482. wb = XSSFTestDataSamples.writeOutAndReadBack(wb);
  483. sheet = wb.getSheetAt(0);
  484. // Check
  485. drawing = sheet.createDrawingPatriarch();
  486. List<XSSFShape> shapes = drawing.getShapes();
  487. assertEquals(1, shapes.size());
  488. assertTrue(shapes.get(0) instanceof XSSFSimpleShape);
  489. XSSFSimpleShape sshape = (XSSFSimpleShape) shapes.get(0);
  490. List<XSSFTextParagraph> paras = sshape.getTextParagraphs();
  491. assertEquals(12, paras.size()); // this should be 12 as XSSFSimpleShape creates a default paragraph (no text), and then we added to that
  492. StringBuilder builder = new StringBuilder();
  493. builder.append(paraString1);
  494. builder.append("\n");
  495. builder.append("\u2022 ");
  496. builder.append(paraString2);
  497. builder.append("\n");
  498. builder.append("\t\u2022 ");
  499. builder.append(paraString3);
  500. builder.append("\n");
  501. builder.append("\u2022 ");
  502. builder.append(paraString4);
  503. builder.append("\n");
  504. builder.append(paraString5);
  505. builder.append("\n");
  506. builder.append("1. ");
  507. builder.append(paraString6);
  508. builder.append("\n");
  509. builder.append("\t3. ");
  510. builder.append(paraString7);
  511. builder.append("\n");
  512. builder.append("\t4. ");
  513. builder.append(paraString8);
  514. builder.append("\n");
  515. builder.append("\t"); // should be empty
  516. builder.append("\n");
  517. builder.append("\t5. ");
  518. builder.append(paraString9);
  519. builder.append("\n");
  520. builder.append("2. ");
  521. builder.append(paraString10);
  522. assertEquals(builder.toString(), sshape.getText());
  523. assertNotNull(XSSFTestDataSamples.writeOutAndReadBack(wb));
  524. }
  525. /**
  526. * Test reading bullet numbering from a textbox in an existing file
  527. */
  528. public void testReadTextBox2(){
  529. XSSFWorkbook wb = XSSFTestDataSamples.openSampleWorkbook("WithTextBox2.xlsx");
  530. XSSFSheet sheet = wb.getSheetAt(0);
  531. XSSFDrawing drawing = sheet.createDrawingPatriarch();
  532. List<XSSFShape> shapes = drawing.getShapes();
  533. XSSFSimpleShape textbox = (XSSFSimpleShape) shapes.get(0);
  534. String extracted = textbox.getText();
  535. StringBuilder sb = new StringBuilder();
  536. sb.append("1. content1A\n");
  537. sb.append("\t1. content1B\n");
  538. sb.append("\t2. content2B\n");
  539. sb.append("\t3. content3B\n");
  540. sb.append("2. content2A\n");
  541. sb.append("\t3. content2BStartAt3\n");
  542. sb.append("\t\n\t\n\t");
  543. sb.append("4. content2BStartAt3Incremented\n");
  544. sb.append("\t\n\t\n\t\n\t");
  545. assertEquals(sb.toString(), extracted);
  546. assertNotNull(XSSFTestDataSamples.writeOutAndReadBack(wb));
  547. }
  548. public void testXSSFSimpleShapeCausesNPE56514() throws Exception {
  549. XSSFWorkbook wb = XSSFTestDataSamples.openSampleWorkbook("56514.xlsx");
  550. XSSFSheet sheet = wb.getSheetAt(0);
  551. XSSFDrawing drawing = sheet.createDrawingPatriarch();
  552. List<XSSFShape> shapes = drawing.getShapes();
  553. assertEquals(4, shapes.size());
  554. wb = XSSFTestDataSamples.writeOutAndReadBack(wb);
  555. shapes = drawing.getShapes();
  556. assertEquals(4, shapes.size());
  557. /* OutputStream stream = new FileOutputStream(new File("C:\\temp\\56514.xlsx"));
  558. try {
  559. wb.write(stream);
  560. } finally {
  561. stream.close();
  562. }*/
  563. }
  564. }