diff options
author | Andreas Beeker <kiwiwings@apache.org> | 2017-01-15 02:04:57 +0000 |
---|---|---|
committer | Andreas Beeker <kiwiwings@apache.org> | 2017-01-15 02:04:57 +0000 |
commit | 9c2820add6a681f5775601fccb8270b85cd72920 (patch) | |
tree | d3131c2107184047d278d6eba14c2fc4fe445ac3 /src/java/org/apache/poi/hssf | |
parent | 4ce3e5def53c893012d6ba709e9beff95a149d48 (diff) | |
download | poi-9c2820add6a681f5775601fccb8270b85cd72920.tar.gz poi-9c2820add6a681f5775601fccb8270b85cd72920.zip |
#60586 - Support embedding OLE1.0 package in XSSF / SS Common
git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@1778869 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'src/java/org/apache/poi/hssf')
-rw-r--r-- | src/java/org/apache/poi/hssf/usermodel/HSSFPatriarch.java | 46 | ||||
-rw-r--r-- | src/java/org/apache/poi/hssf/usermodel/HSSFWorkbook.java | 11 |
2 files changed, 37 insertions, 20 deletions
diff --git a/src/java/org/apache/poi/hssf/usermodel/HSSFPatriarch.java b/src/java/org/apache/poi/hssf/usermodel/HSSFPatriarch.java index cc6805c5b8..d7baeb58e0 100644 --- a/src/java/org/apache/poi/hssf/usermodel/HSSFPatriarch.java +++ b/src/java/org/apache/poi/hssf/usermodel/HSSFPatriarch.java @@ -48,6 +48,7 @@ import org.apache.poi.poifs.filesystem.DirectoryNode; import org.apache.poi.ss.usermodel.Chart; import org.apache.poi.ss.usermodel.ClientAnchor; import org.apache.poi.ss.usermodel.Drawing; +import org.apache.poi.ss.usermodel.Workbook; import org.apache.poi.util.HexDump; import org.apache.poi.util.Internal; import org.apache.poi.util.NotImplemented; @@ -137,6 +138,7 @@ public final class HSSFPatriarch implements HSSFShapeContainer, Drawing<HSSFShap * @param shape to be removed * @return true of shape is removed */ + @Override public boolean removeShape(HSSFShape shape) { boolean isRemoved = _mainSpgrContainer.removeChildRecord(shape.getEscherContainer()); if (isRemoved){ @@ -214,22 +216,13 @@ public final class HSSFPatriarch implements HSSFShapeContainer, Drawing<HSSFShap * * @return newly created shape */ + @Override public HSSFPicture createPicture(ClientAnchor anchor, int pictureIndex) { return createPicture((HSSFClientAnchor) anchor, pictureIndex); } - /** - * Adds a new OLE Package Shape - * - * @param anchor the client anchor describes how this picture is - * attached to the sheet. - * @param storageId the storageId returned by {@link HSSFWorkbook#addOlePackage(POIFSFileSystem,String,String,String)} - * @param pictureIndex the index of the picture (used as preview image) in the - * workbook collection of pictures. - * - * @return newly created shape - */ - public HSSFObjectData createObjectData(HSSFClientAnchor anchor, int storageId, int pictureIndex) { + @Override + public HSSFObjectData createObjectData(ClientAnchor anchor, int storageId, int pictureIndex) { ObjRecord obj = new ObjRecord(); CommonObjectDataSubRecord ftCmo = new CommonObjectDataSubRecord(); @@ -248,15 +241,15 @@ public final class HSSFPatriarch implements HSSFShapeContainer, Drawing<HSSFShap FtCfSubRecord ftCf = new FtCfSubRecord(); HSSFPictureData pictData = getSheet().getWorkbook().getAllPictures().get(pictureIndex-1); switch (pictData.getFormat()) { - case HSSFWorkbook.PICTURE_TYPE_WMF: - case HSSFWorkbook.PICTURE_TYPE_EMF: + case Workbook.PICTURE_TYPE_WMF: + case Workbook.PICTURE_TYPE_EMF: // this needs patch #49658 to be applied to actually work ftCf.setFlags(FtCfSubRecord.METAFILE_BIT); break; - case HSSFWorkbook.PICTURE_TYPE_DIB: - case HSSFWorkbook.PICTURE_TYPE_PNG: - case HSSFWorkbook.PICTURE_TYPE_JPEG: - case HSSFWorkbook.PICTURE_TYPE_PICT: + case Workbook.PICTURE_TYPE_DIB: + case Workbook.PICTURE_TYPE_PNG: + case Workbook.PICTURE_TYPE_JPEG: + case Workbook.PICTURE_TYPE_PICT: ftCf.setFlags(FtCfSubRecord.BITMAP_BIT); break; default: @@ -280,14 +273,16 @@ public final class HSSFPatriarch implements HSSFShapeContainer, Drawing<HSSFShap DirectoryEntry oleRoot; try { DirectoryNode dn = _sheet.getWorkbook().getDirectory(); - if (dn == null) throw new FileNotFoundException(); + if (dn == null) { + throw new FileNotFoundException(); + } oleRoot = (DirectoryEntry)dn.getEntry(entryName); } catch (FileNotFoundException e) { throw new IllegalStateException("trying to add ole shape without actually adding data first - use HSSFWorkbook.addOlePackage first", e); } // create picture shape, which need to be minimal modified for oleshapes - HSSFPicture shape = new HSSFPicture(null, anchor); + HSSFPicture shape = new HSSFPicture(null, (HSSFClientAnchor)anchor); shape.setPictureIndex(pictureIndex); EscherContainerRecord spContainer = shape.getEscherContainer(); EscherSpRecord spRecord = spContainer.getChildById(EscherSpRecord.RECORD_ID); @@ -355,6 +350,7 @@ public final class HSSFPatriarch implements HSSFShapeContainer, Drawing<HSSFShap return shape; } + @Override public HSSFComment createCellComment(ClientAnchor anchor) { return createComment((HSSFAnchor) anchor); } @@ -362,6 +358,7 @@ public final class HSSFPatriarch implements HSSFShapeContainer, Drawing<HSSFShap /** * Returns a unmodifiable list of all shapes contained by the patriarch. */ + @Override public List<HSSFShape> getChildren() { return Collections.unmodifiableList(_shapes); } @@ -369,6 +366,7 @@ public final class HSSFPatriarch implements HSSFShapeContainer, Drawing<HSSFShap /** * add a shape to this drawing */ + @Override @Internal public void addShape(HSSFShape shape) { shape.setPatriarch(this); @@ -405,6 +403,7 @@ public final class HSSFPatriarch implements HSSFShapeContainer, Drawing<HSSFShap * Sets the coordinate space of this group. All children are constrained * to these coordinates. */ + @Override public void setCoordinates(int x1, int y1, int x2, int y2) { _spgrRecord.setRectY1(y1); _spgrRecord.setRectY2(y2); @@ -415,6 +414,7 @@ public final class HSSFPatriarch implements HSSFShapeContainer, Drawing<HSSFShap /** * remove all shapes inside patriarch */ + @Override public void clear() { ArrayList <HSSFShape> copy = new ArrayList<HSSFShape>(_shapes); for (HSSFShape shape: copy){ @@ -469,6 +469,7 @@ public final class HSSFPatriarch implements HSSFShapeContainer, Drawing<HSSFShap /** * @return x coordinate of the left up corner */ + @Override public int getX1() { return _spgrRecord.getRectX1(); } @@ -476,6 +477,7 @@ public final class HSSFPatriarch implements HSSFShapeContainer, Drawing<HSSFShap /** * @return y coordinate of the left up corner */ + @Override public int getY1() { return _spgrRecord.getRectY1(); } @@ -483,6 +485,7 @@ public final class HSSFPatriarch implements HSSFShapeContainer, Drawing<HSSFShap /** * @return x coordinate of the right down corner */ + @Override public int getX2() { return _spgrRecord.getRectX2(); } @@ -490,6 +493,7 @@ public final class HSSFPatriarch implements HSSFShapeContainer, Drawing<HSSFShap /** * @return y coordinate of the right down corner */ + @Override public int getY2() { return _spgrRecord.getRectY2(); } @@ -517,10 +521,12 @@ public final class HSSFPatriarch implements HSSFShapeContainer, Drawing<HSSFShap * @param row2 the row (0 based) of the second cell. * @return the newly created client anchor */ + @Override public HSSFClientAnchor createAnchor(int dx1, int dy1, int dx2, int dy2, int col1, int row1, int col2, int row2) { return new HSSFClientAnchor(dx1, dy1, dx2, dy2, (short) col1, row1, (short) col2, row2); } + @Override @NotImplemented public Chart createChart(ClientAnchor anchor) { throw new RuntimeException("NotImplemented"); diff --git a/src/java/org/apache/poi/hssf/usermodel/HSSFWorkbook.java b/src/java/org/apache/poi/hssf/usermodel/HSSFWorkbook.java index 2f3be03de9..55382236e0 100644 --- a/src/java/org/apache/poi/hssf/usermodel/HSSFWorkbook.java +++ b/src/java/org/apache/poi/hssf/usermodel/HSSFWorkbook.java @@ -2048,6 +2048,16 @@ public final class HSSFWorkbook extends POIDocument implements org.apache.poi.ss return olemap; } + /** + * Adds an OLE package manager object with the given POIFS to the sheet + * + * @param poiData an POIFS containing the embedded document, to be added + * @param label the label of the payload + * @param fileName the original filename + * @param command the command to open the payload + * @return the index of the added ole object + * @throws IOException if the object can't be embedded + */ public int addOlePackage(POIFSFileSystem poiData, String label, String fileName, String command) throws IOException { DirectoryNode root = poiData.getRoot(); @@ -2064,6 +2074,7 @@ public final class HSSFWorkbook extends POIDocument implements org.apache.poi.ss return addOlePackage(bos.toByteArray(), label, fileName, command); } + @Override public int addOlePackage(byte[] oleData, String label, String fileName, String command) throws IOException { // check if we were created by POIFS otherwise create a new dummy POIFS for storing the package data |