aboutsummaryrefslogtreecommitdiffstats
path: root/src/java
diff options
context:
space:
mode:
Diffstat (limited to 'src/java')
-rw-r--r--src/java/org/apache/poi/sl/draw/DrawPictureShape.java35
-rw-r--r--src/java/org/apache/poi/sl/draw/Drawable.java9
-rw-r--r--src/java/org/apache/poi/sl/usermodel/PictureShape.java10
3 files changed, 39 insertions, 15 deletions
diff --git a/src/java/org/apache/poi/sl/draw/DrawPictureShape.java b/src/java/org/apache/poi/sl/draw/DrawPictureShape.java
index 70194bdcd7..84e7c91b33 100644
--- a/src/java/org/apache/poi/sl/draw/DrawPictureShape.java
+++ b/src/java/org/apache/poi/sl/draw/DrawPictureShape.java
@@ -44,20 +44,29 @@ public class DrawPictureShape extends DrawSimpleShape {
@Override
public void drawContent(Graphics2D graphics) {
- PictureData data = getShape().getPictureData();
- if(data == null) return;
-
- Rectangle2D anchor = getAnchor(graphics, getShape());
- Insets insets = getShape().getClipping();
-
- try {
- ImageRenderer renderer = getImageRenderer(graphics, data.getContentType());
- renderer.loadImage(data.getData(), data.getContentType());
- renderer.drawImage(graphics, anchor, insets);
- } catch (IOException e) {
- LOG.log(POILogger.ERROR, "image can't be loaded/rendered.", e);
+ PictureShape<?,?> ps = getShape();
+
+ Rectangle2D anchor = getAnchor(graphics, ps);
+ Insets insets = ps.getClipping();
+
+ PictureData[] pics = { ps.getAlternativePictureData(), ps.getPictureData() };
+ for (PictureData data : pics) {
+ if (data == null) {
+ continue;
+ }
+
+ try {
+ ImageRenderer renderer = getImageRenderer(graphics, data.getContentType());
+ if (renderer.canRender(data.getContentType())) {
+ renderer.loadImage(data.getData(), data.getContentType());
+ renderer.drawImage(graphics, anchor, insets);
+ return;
+ }
+ } catch (IOException e) {
+ LOG.log(POILogger.ERROR, "image can't be loaded/rendered.", e);
+ }
}
- }
+ }
/**
* Returns an ImageRenderer for the PictureData
diff --git a/src/java/org/apache/poi/sl/draw/Drawable.java b/src/java/org/apache/poi/sl/draw/Drawable.java
index 4ec653ae50..d75b46dc40 100644
--- a/src/java/org/apache/poi/sl/draw/Drawable.java
+++ b/src/java/org/apache/poi/sl/draw/Drawable.java
@@ -136,8 +136,13 @@ public interface Drawable {
* are printed. In this situation we need to have a way to access the current slide
*/
DrawableHint CURRENT_SLIDE = new DrawableHint(12);
-
-
+
+ /**
+ * Stores a reference (WEAK_REFERENCE) to the buffered image, if the rendering is
+ * based on a buffered image
+ */
+ DrawableHint BUFFERED_IMAGE = new DrawableHint(13);
+
/**
* Apply 2-D transforms before drawing this shape. This includes rotation and flipping.
*
diff --git a/src/java/org/apache/poi/sl/usermodel/PictureShape.java b/src/java/org/apache/poi/sl/usermodel/PictureShape.java
index c7fb629410..03b2f642a4 100644
--- a/src/java/org/apache/poi/sl/usermodel/PictureShape.java
+++ b/src/java/org/apache/poi/sl/usermodel/PictureShape.java
@@ -31,6 +31,16 @@ public interface PictureShape<
PictureData getPictureData();
/**
+ * Returns an alternative picture data, e.g. an embedded SVG image
+ *
+ * @return an alternative picture data
+ *
+ * @since POI 4.1.0
+ */
+ default PictureData getAlternativePictureData() { return null; }
+
+
+ /**
* Returns the clipping values as percent ratio relatively to the image size.
* The clipping are returned as insets converted/scaled to 100000 (=100%).
*