Package org.apache.poi.ddf
Class EscherArrayProperty
- java.lang.Object
- 
- org.apache.poi.ddf.EscherProperty
- 
- org.apache.poi.ddf.EscherComplexProperty
- 
- org.apache.poi.ddf.EscherArrayProperty
 
 
 
- 
- All Implemented Interfaces:
- Iterable<byte[]>,- GenericRecord
 
 public final class EscherArrayProperty extends EscherComplexProperty implements Iterable<byte[]> Escher array properties are the most weird construction ever invented with all sorts of special cases. I'm hopeful I've got them all.
- 
- 
Constructor SummaryConstructors Constructor Description EscherArrayProperty(short propertyNumber, boolean isBlipId, byte[] complexData)EscherArrayProperty(short id, int complexSize)Create an instance of an escher array property.EscherArrayProperty(EscherPropertyTypes type, boolean isBlipId, int complexSize)Create an instance of an escher array property.
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description byte[]getElement(int index)Map<String,Supplier<?>>getGenericProperties()static intgetMaxRecordLength()intgetNumberOfElementsInArray()intgetNumberOfElementsInMemory()shortgetSizeOfElements()Iterator<byte[]>iterator()intserializeSimplePart(byte[] data, int pos)Serializes the simple part of this property.intsetArrayData(byte[] data, int offset)We have this method because the way in which arrays in escher works is screwed for seemly arbitrary reasons.voidsetElement(int index, byte[] element)static voidsetMaxRecordLength(int length)voidsetNumberOfElementsInArray(int numberOfElements)voidsetNumberOfElementsInMemory(int numberOfElements)voidsetSizeOfElements(int sizeOfElements)Spliterator<byte[]>spliterator()- 
Methods inherited from class org.apache.poi.ddf.EscherComplexPropertyequals, getComplexData, getPropertySize, hashCode, resizeComplexData, resizeComplexData, serializeComplexPart, setComplexData, setComplexData
 - 
Methods inherited from class org.apache.poi.ddf.EscherPropertygetGenericChildren, getGenericRecordType, getId, getName, getPropertyNumber, isBlipId, isComplex, toString, toXml
 
- 
 
- 
- 
- 
Constructor Detail- 
EscherArrayProperty@Internal public EscherArrayProperty(short id, int complexSize) Create an instance of an escher array property. This constructor can be used to create emptyComplexParts with a complexSize = 0. Preferably useEscherArrayProperty(EscherPropertyTypes, boolean, int)withEscherComplexProperty.setComplexData(byte[]).- Parameters:
- id- The id consists of the property number, a flag indicating whether this is a blip id and a flag indicating that this is a complex property.
- complexSize- the data size
 
 - 
EscherArrayProperty@Deprecated @Removal(version="5.0.0") public EscherArrayProperty(short propertyNumber, boolean isBlipId, byte[] complexData) Deprecated.Create an instance of an escher array property. This constructor defaults to a 6 bytes header if the complexData is null or byte[0].- Parameters:
- propertyNumber- the property number part of the property id
- isBlipId-- true, if it references a blip
- complexData- the data
 
 - 
EscherArrayPropertypublic EscherArrayProperty(EscherPropertyTypes type, boolean isBlipId, int complexSize) Create an instance of an escher array property. This constructor defaults to a 6 bytes header if the complexSize is 0.- Parameters:
- type- the property type of the property id
- isBlipId-- true, if it references a blip
- complexSize- the data size
 
 
- 
 - 
Method Detail- 
setMaxRecordLengthpublic static void setMaxRecordLength(int length) - Parameters:
- length- the max record length allowed for EscherArrayProperty
 
 - 
getMaxRecordLengthpublic static int getMaxRecordLength() - Returns:
- the max record length allowed for EscherArrayProperty
 
 - 
getNumberOfElementsInArraypublic int getNumberOfElementsInArray() 
 - 
setNumberOfElementsInArraypublic void setNumberOfElementsInArray(int numberOfElements) 
 - 
getNumberOfElementsInMemorypublic int getNumberOfElementsInMemory() 
 - 
setNumberOfElementsInMemorypublic void setNumberOfElementsInMemory(int numberOfElements) 
 - 
getSizeOfElementspublic short getSizeOfElements() 
 - 
setSizeOfElementspublic void setSizeOfElements(int sizeOfElements) 
 - 
getElementpublic byte[] getElement(int index) 
 - 
setElementpublic void setElement(int index, byte[] element)
 - 
setArrayDatapublic int setArrayData(byte[] data, int offset)We have this method because the way in which arrays in escher works is screwed for seemly arbitrary reasons. While most properties are fairly consistent and have a predictable array size, escher arrays have special cases.- Parameters:
- data- The data array containing the escher array information
- offset- The offset into the array to start reading from.
- Returns:
- the number of bytes used by this complex property.
 
 - 
serializeSimplePartpublic int serializeSimplePart(byte[] data, int pos)Serializes the simple part of this property. ie the first 6 bytes. Needs special code to handle the case when the size doesn't include the size of the header block- Overrides:
- serializeSimplePartin class- EscherComplexProperty
- Parameters:
- data- the buffer to write to
- pos- the starting position
- Returns:
- the length of the part
 
 - 
spliteratorpublic Spliterator<byte[]> spliterator() - Specified by:
- spliteratorin interface- Iterable<byte[]>
- Since:
- POI 5.2.0
 
 - 
getGenericPropertiespublic Map<String,Supplier<?>> getGenericProperties() - Specified by:
- getGenericPropertiesin interface- GenericRecord
- Overrides:
- getGenericPropertiesin class- EscherComplexProperty
 
 
- 
 
-