Class HSLFShape

java.lang.Object
org.apache.poi.hslf.usermodel.HSLFShape
All Implemented Interfaces:
Shape<HSLFShape,HSLFTextParagraph>
Direct Known Subclasses:
HSLFBackground, HSLFGroupShape, HSLFSimpleShape

public abstract class HSLFShape extends Object implements Shape<HSLFShape,HSLFTextParagraph>
Represents a Shape which is the elemental object that composes a drawing. This class is a wrapper around EscherSpContainer which holds all information about a shape in PowerPoint document.

When you add a shape, you usually specify the dimensions of the shape and the position of the upper'left corner of the bounding box for the shape relative to the upper'left corner of the page, worksheet, or slide. Distances in the drawing layer are measured in points (72 points = 1 inch).

  • Method Details

    • getParent

      Specified by:
      getParent in interface Shape<HSLFShape,HSLFTextParagraph>
      Returns:
      the parent of this shape
    • getShapeName

      public String getShapeName()
      Specified by:
      getShapeName in interface Shape<HSLFShape,HSLFTextParagraph>
      Returns:
      name of the shape.
    • getShapeType

      public ShapeType getShapeType()
    • setShapeType

      public void setShapeType(ShapeType type)
    • getAnchor

      public Rectangle2D getAnchor()
      Returns the anchor (the bounding box rectangle) of this shape. All coordinates are expressed in points (72 dpi).
      Specified by:
      getAnchor in interface Shape<HSLFShape,HSLFTextParagraph>
      Returns:
      the anchor of this shape
    • setAnchor

      public void setAnchor(Rectangle2D anchor)
      Sets the anchor (the bounding box rectangle) of this shape. All coordinates should be expressed in points (72 dpi).
      Parameters:
      anchor - new anchor
    • moveTo

      public final void moveTo(double x, double y)
      Moves the top left corner of the shape to the specified point.
      Parameters:
      x - the x coordinate of the top left corner of the shape
      y - the y coordinate of the top left corner of the shape
    • getEscherChild

      public static <T extends EscherRecord> T getEscherChild(EscherContainerRecord owner, int recordId)
      Helper method to return escher child by record ID
      Returns:
      escher record or null if not found.
    • getEscherChild

      public static <T extends EscherRecord> T getEscherChild(EscherContainerRecord owner, EscherRecordTypes recordId)
      Since:
      POI 3.14-Beta2
    • getEscherChild

      public <T extends EscherRecord> T getEscherChild(int recordId)
    • getEscherChild

      public <T extends EscherRecord> T getEscherChild(EscherRecordTypes recordId)
      Since:
      POI 3.14-Beta2
    • getEscherProperty

      @Deprecated @Removal(version="5.0.0") public static <T extends EscherProperty> T getEscherProperty(AbstractEscherOptRecord opt, int propId)
      Returns escher property by id.
      Returns:
      escher property or null if not found.
    • getEscherProperty

      public static <T extends EscherProperty> T getEscherProperty(AbstractEscherOptRecord opt, EscherPropertyTypes type)
      Returns escher property by type.
      Returns:
      escher property or null if not found.
    • setEscherProperty

      @Deprecated @Removal(version="5.0.0") public static void setEscherProperty(AbstractEscherOptRecord opt, short propId, int value)
      Set an escher property for this shape.
      Parameters:
      opt - The opt record to set the properties to.
      propId - The id of the property. One of the constants defined in EscherOptRecord.
      value - value of the property. If value = -1 then the property is removed.
    • setEscherProperty

      public static void setEscherProperty(AbstractEscherOptRecord opt, EscherPropertyTypes propType, int value)
      Set an escher property for this shape.
      Parameters:
      opt - The opt record to set the properties to.
      propType - The type of the property.
      value - value of the property. If value = -1 then the property is removed.
    • setEscherProperty

      public static void setEscherProperty(AbstractEscherOptRecord opt, EscherPropertyTypes propType, boolean isBlipId, int value)
    • setEscherProperty

      @Deprecated @Removal(version="5.0.0") public void setEscherProperty(short propId, int value)
      Set an simple escher property for this shape.
      Parameters:
      propId - The id of the property. One of the constants defined in EscherOptRecord.
      value - value of the property. If value = -1 then the property is removed.
    • setEscherProperty

      public void setEscherProperty(EscherPropertyTypes propType, int value)
      Set an simple escher property for this shape.
      Parameters:
      propType - The type of the property.
      value - value of the property. If value = -1 then the property is removed.
    • getEscherProperty

      public int getEscherProperty(short propId)
      Get the value of a simple escher property for this shape.
      Parameters:
      propId - The id of the property. One of the constants defined in EscherOptRecord.
    • getEscherProperty

      public int getEscherProperty(EscherPropertyTypes propType)
      Get the value of a simple escher property for this shape.
      Parameters:
      propType - The type of the property. One of the constants defined in EscherOptRecord.
    • getEscherProperty

      @Deprecated @Removal(version="5.0.0") public int getEscherProperty(short propId, int defaultValue)
      Get the value of a simple escher property for this shape.
      Parameters:
      propId - The id of the property. One of the constants defined in EscherOptRecord.
    • getEscherProperty

      public int getEscherProperty(EscherPropertyTypes type, int defaultValue)
      Get the value of a simple escher property for this shape.
      Parameters:
      type - The type of the property.
    • getSpContainer

      public EscherContainerRecord getSpContainer()
      Returns:
      The shape container and its children that can represent this shape.
    • getSheet

      public HSLFSheet getSheet()
      Specified by:
      getSheet in interface Shape<HSLFShape,HSLFTextParagraph>
      Returns:
      the SlideShow this shape belongs to
    • setSheet

      public void setSheet(HSLFSheet sheet)
      Assign the SlideShow this shape belongs to
      Parameters:
      sheet - owner of this shape
    • getShapeId

      public int getShapeId()
      Description copied from interface: Shape
      Returns a unique identifier for this shape within the current slide. This ID may be used to assist in uniquely identifying this object so that it can be referred to by other parts of the document.

      If multiple objects within the same slide share the same id attribute value, then the document shall be considered non-conformant.

      Specified by:
      getShapeId in interface Shape<HSLFShape,HSLFTextParagraph>
      Returns:
      unique id of this shape
    • setShapeId

      public void setShapeId(int id)
      Sets shape ID
      Parameters:
      id - of the shape
    • getFill

      public HSLFFill getFill()
      Fill properties of this shape
      Returns:
      fill properties of this shape
    • getFillStyle

      public FillStyle getFillStyle()
    • draw

      public void draw(Graphics2D graphics, Rectangle2D bounds)
      Description copied from interface: Shape
      Convenience method to draw a single shape
      Specified by:
      draw in interface Shape<HSLFShape,HSLFTextParagraph>
      Parameters:
      graphics - the graphics context
      bounds - the rectangle to fit the shape to. if null, the bounds of the shape are used.
    • getEscherOptRecord

      public AbstractEscherOptRecord getEscherOptRecord()
    • getFlipHorizontal

      public boolean getFlipHorizontal()
    • setFlipHorizontal

      public void setFlipHorizontal(boolean flip)
    • getFlipVertical

      public boolean getFlipVertical()
    • setFlipVertical

      public void setFlipVertical(boolean flip)
    • getRotation

      public double getRotation()
    • setRotation

      public void setRotation(double theta)
    • isPlaceholder

      public boolean isPlaceholder()
    • getClientDataRecord

      public <T extends Record> T getClientDataRecord(int recordType)
      Find a record in the underlying EscherClientDataRecord
      Parameters:
      recordType - type of the record to search