#63745 - Add traversing and debugging interface

Replace EscherProperty.getAttributeMap by GenericRecord interface

git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@1868352 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Andreas Beeker 2019-10-12 16:32:53 +00:00
parent e81a348864
commit 9982ec4e79
85 changed files with 2031 additions and 2974 deletions

View File

@ -24,6 +24,7 @@ import java.util.function.Supplier;
import org.apache.poi.util.GenericRecordUtil; import org.apache.poi.util.GenericRecordUtil;
import org.apache.poi.util.LittleEndian; import org.apache.poi.util.LittleEndian;
import org.apache.poi.util.Removal;
/** /**
* Common abstract class for {@link EscherOptRecord} and * Common abstract class for {@link EscherOptRecord} and
@ -96,18 +97,13 @@ public abstract class AbstractEscherOptRecord extends EscherRecord
return 8 + getPropertiesSize(); return 8 + getPropertiesSize();
} }
public <T extends EscherProperty> T lookup( int propId ) public <T extends EscherProperty> T lookup( EscherPropertyTypes propType ) {
{ return lookup(propType.propNumber);
for ( EscherProperty prop : properties ) }
{
if ( prop.getPropertyNumber() == propId )
{
@SuppressWarnings( "unchecked" ) @SuppressWarnings( "unchecked" )
final T result = (T) prop; public <T extends EscherProperty> T lookup( int propId ) {
return result; return (T)properties.stream().filter(p -> p.getPropertyNumber() == propId).findFirst().orElse(null);
}
}
return null;
} }
@Override @Override
@ -140,8 +136,7 @@ public abstract class AbstractEscherOptRecord extends EscherRecord
} }
/** /**
* Set an escher property. If a property with given propId already * Set an escher property. If a property with given propId already exists it is replaced.
exists it is replaced.
* *
* @param value the property to set. * @param value the property to set.
*/ */
@ -151,32 +146,22 @@ public abstract class AbstractEscherOptRecord extends EscherRecord
sortProperties(); sortProperties();
} }
@Deprecated
@Removal(version = "5.0.0")
public void removeEscherProperty(int num){ public void removeEscherProperty(int num){
properties.removeIf(prop -> prop.getPropertyNumber() == num); properties.removeIf(prop -> prop.getPropertyNumber() == num);
} }
@Override public void removeEscherProperty(EscherPropertyTypes type){
protected Object[][] getAttributeMap() { properties.removeIf(prop -> prop.getPropertyNumber() == type.propNumber);
List<Object> attrList = new ArrayList<>(properties.size() * 2 + 2);
attrList.add("properties");
attrList.add(properties.size());
for ( EscherProperty property : properties ) {
attrList.add(property.getName());
attrList.add(property);
}
return new Object[][]{
{ "isContainer", isContainerRecord() },
{ "numchildren", getChildRecords().size() },
attrList.toArray()
};
} }
@Override @Override
public Map<String, Supplier<?>> getGenericProperties() { public Map<String, Supplier<?>> getGenericProperties() {
return GenericRecordUtil.getGenericProperties( return GenericRecordUtil.getGenericProperties(
"base", super::getGenericProperties, "base", super::getGenericProperties,
"isContainer", this::isContainerRecord "isContainer", this::isContainerRecord,
"properties", this::getEscherProperties
); );
} }
} }

View File

@ -18,11 +18,17 @@
package org.apache.poi.ddf; package org.apache.poi.ddf;
import java.util.Iterator; import java.util.Iterator;
import java.util.Map;
import java.util.NoSuchElementException; import java.util.NoSuchElementException;
import java.util.function.Supplier;
import java.util.stream.Collectors;
import java.util.stream.StreamSupport;
import org.apache.poi.util.HexDump; import org.apache.poi.util.GenericRecordUtil;
import org.apache.poi.util.IOUtils; import org.apache.poi.util.IOUtils;
import org.apache.poi.util.Internal;
import org.apache.poi.util.LittleEndian; import org.apache.poi.util.LittleEndian;
import org.apache.poi.util.Removal;
/** /**
* Escher array properties are the most weird construction ever invented * Escher array properties are the most weird construction ever invented
@ -34,13 +40,11 @@ public final class EscherArrayProperty extends EscherComplexProperty implements
private static final int MAX_RECORD_LENGTH = 100_000; private static final int MAX_RECORD_LENGTH = 100_000;
/** /**
* The size of the header that goes at the * The size of the header that goes at the start of the array, before the data
* start of the array, before the data
*/ */
private static final int FIXED_SIZE = 3 * 2; private static final int FIXED_SIZE = 3 * 2;
/** /**
* Normally, the size recorded in the simple data (for the complex * Normally, the size recorded in the simple data (for the complex data) includes the size of the header.
* data) includes the size of the header.
* There are a few cases when it doesn't though... * There are a few cases when it doesn't though...
*/ */
private boolean sizeIncludesHeaderSize = true; private boolean sizeIncludesHeaderSize = true;
@ -48,23 +52,77 @@ public final class EscherArrayProperty extends EscherComplexProperty implements
/** /**
* When reading a property from data stream remember if the complex part is empty and set this flag. * When reading a property from data stream remember if the complex part is empty and set this flag.
*/ */
private boolean emptyComplexPart; private final boolean emptyComplexPart;
/**
* Create an instance of an escher array property.
* This constructor defaults to a 6 bytes header if the complexData is null or byte[0].
*
* @param 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.
* @param complexData The value of this property.
*
* @deprecated use {@link #EscherArrayProperty(EscherPropertyTypes, boolean, int)} and {@link #setComplexData(byte[])}
*/
@Deprecated
@Removal(version = "5.0.0")
@Internal
public EscherArrayProperty(short id, byte[] complexData) { public EscherArrayProperty(short id, byte[] complexData) {
super(id, checkComplexData(complexData)); this(id, safeSize(complexData == null ? 0 : complexData.length));
emptyComplexPart = (complexData == null || complexData.length == 0); setComplexData(complexData);
} }
/**
* Create an instance of an escher array property.
* This constructor can be used to create emptyComplexParts with a complexSize = 0.
* Preferably use {@link #EscherArrayProperty(EscherPropertyTypes, boolean, int)} with {@link #setComplexData(byte[])}.
*
* @param 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.
* @param complexSize the data size
*/
@Internal
public EscherArrayProperty(short id, int complexSize) {
// this is called by EscherPropertyFactory which happens to call it with empty parts
// if a part is initial empty, don't allow it to contain something again
super(id, complexSize);
emptyComplexPart = (complexSize == 0);
}
/**
* Create an instance of an escher array property.
* This constructor defaults to a 6 bytes header if the complexData is null or byte[0].
*
* @param propertyNumber the property number part of the property id
* @param isBlipId {@code true}, if it references a blip
* @param complexData the data
*
* @deprecated use {@link #EscherArrayProperty(EscherPropertyTypes, boolean, int)} and {@link #setComplexData(byte[])}
*/
@Deprecated
@Removal(version = "5.0.0")
public EscherArrayProperty(short propertyNumber, boolean isBlipId, byte[] complexData) { public EscherArrayProperty(short propertyNumber, boolean isBlipId, byte[] complexData) {
super(propertyNumber, isBlipId, checkComplexData(complexData)); // this is called by user code, if the complexData is empty/null, allocate a space for a valid header
// be aware, that there are complex data areas with less than 6 bytes
this((short)(propertyNumber | (isBlipId ? IS_BLIP : 0)), safeSize(complexData == null ? 0 : complexData.length));
setComplexData(complexData);
} }
private static byte[] checkComplexData(byte[] complexData) { /**
if (complexData == null || complexData.length == 0) { * Create an instance of an escher array property.
return new byte[6]; * This constructor defaults to a 6 bytes header if the complexSize is 0.
*
* @param type the property type of the property id
* @param isBlipId {@code true}, if it references a blip
* @param complexSize the data size
*/
public EscherArrayProperty(EscherPropertyTypes type, boolean isBlipId, int complexSize) {
this((short)(type.propNumber | (isBlipId ? IS_BLIP : 0)), safeSize(complexSize));
} }
return complexData; private static int safeSize(int complexSize) {
// when called by user code, fix the size to be valid for the header
return complexSize == 0 ? 6 : complexSize;
} }
public int getNumberOfElementsInArray() { public int getNumberOfElementsInArray() {
@ -72,26 +130,27 @@ public final class EscherArrayProperty extends EscherComplexProperty implements
} }
public void setNumberOfElementsInArray(int numberOfElements) { public void setNumberOfElementsInArray(int numberOfElements) {
int expectedArraySize = numberOfElements * getActualSizeOfElements(getSizeOfElements()) + FIXED_SIZE; if (emptyComplexPart) {
if (expectedArraySize != getComplexData().length) { return;
byte[] newArray = IOUtils.safelyAllocate(expectedArraySize, MAX_RECORD_LENGTH);
System.arraycopy(getComplexData(), 0, newArray, 0, getComplexData().length);
setComplexData(newArray);
} }
rewriteArray(numberOfElements, false);
LittleEndian.putShort(getComplexData(), 0, (short) numberOfElements); LittleEndian.putShort(getComplexData(), 0, (short) numberOfElements);
} }
private void rewriteArray(int numberOfElements, boolean copyToNewLen) {
int expectedArraySize = numberOfElements * getActualSizeOfElements(getSizeOfElements()) + FIXED_SIZE;
resizeComplexData(expectedArraySize, copyToNewLen ? expectedArraySize : getComplexData().length);
}
public int getNumberOfElementsInMemory() { public int getNumberOfElementsInMemory() {
return (emptyComplexPart) ? 0 : LittleEndian.getUShort(getComplexData(), 2); return (emptyComplexPart) ? 0 : LittleEndian.getUShort(getComplexData(), 2);
} }
public void setNumberOfElementsInMemory(int numberOfElements) { public void setNumberOfElementsInMemory(int numberOfElements) {
int expectedArraySize = numberOfElements * getActualSizeOfElements(getSizeOfElements()) + FIXED_SIZE; if (emptyComplexPart) {
if (expectedArraySize != getComplexData().length) { return;
byte[] newArray = IOUtils.safelyAllocate(expectedArraySize, MAX_RECORD_LENGTH);
System.arraycopy(getComplexData(), 0, newArray, 0, expectedArraySize);
setComplexData(newArray);
} }
rewriteArray(numberOfElements, true);
LittleEndian.putShort(getComplexData(), 2, (short) numberOfElements); LittleEndian.putShort(getComplexData(), 2, (short) numberOfElements);
} }
@ -100,15 +159,14 @@ public final class EscherArrayProperty extends EscherComplexProperty implements
} }
public void setSizeOfElements(int sizeOfElements) { public void setSizeOfElements(int sizeOfElements) {
if (emptyComplexPart) {
return;
}
LittleEndian.putShort( getComplexData(), 4, (short) sizeOfElements ); LittleEndian.putShort( getComplexData(), 4, (short) sizeOfElements );
int expectedArraySize = getNumberOfElementsInArray() * getActualSizeOfElements(getSizeOfElements()) + FIXED_SIZE; int expectedArraySize = getNumberOfElementsInArray() * getActualSizeOfElements(getSizeOfElements()) + FIXED_SIZE;
if (expectedArraySize != getComplexData().length) {
// Keep just the first 6 bytes. The rest is no good to us anyway. // Keep just the first 6 bytes. The rest is no good to us anyway.
byte[] newArray = IOUtils.safelyAllocate(expectedArraySize, MAX_RECORD_LENGTH); resizeComplexData(expectedArraySize, 6);
System.arraycopy( getComplexData(), 0, newArray, 0, 6 );
setComplexData(newArray);
}
} }
public byte[] getElement(int index) { public byte[] getElement(int index) {
@ -119,43 +177,13 @@ public final class EscherArrayProperty extends EscherComplexProperty implements
} }
public void setElement(int index, byte[] element) { public void setElement(int index, byte[] element) {
if (emptyComplexPart) {
return;
}
int actualSize = getActualSizeOfElements(getSizeOfElements()); int actualSize = getActualSizeOfElements(getSizeOfElements());
System.arraycopy( element, 0, getComplexData(), FIXED_SIZE + index * actualSize, actualSize); System.arraycopy( element, 0, getComplexData(), FIXED_SIZE + index * actualSize, actualSize);
} }
@Override
public String toString() {
StringBuilder results = new StringBuilder();
results.append("propNum: ").append(getPropertyNumber());
results.append(", propName: ").append(EscherProperties.getPropertyName( getPropertyNumber() ));
results.append(", complex: ").append(isComplex());
results.append(", blipId: ").append(isBlipId());
results.append(", data: \n");
results.append(" {EscherArrayProperty:" + '\n');
results.append(" Num Elements: ").append(getNumberOfElementsInArray()).append('\n');
results.append(" Num Elements In Memory: ").append(getNumberOfElementsInMemory()).append('\n');
results.append(" Size of elements: ").append(getSizeOfElements()).append('\n');
for (int i = 0; i < getNumberOfElementsInArray(); i++) {
results.append(" Element ").append(i).append(": ").append(HexDump.toHex(getElement(i))).append('\n');
}
results.append("}" + '\n');
return results.toString();
}
@Override
public String toXml(String tab){
StringBuilder builder = new StringBuilder();
builder.append(tab).append("<").append(getClass().getSimpleName()).append(" id=\"0x").append(HexDump.toHex(getId()))
.append("\" name=\"").append(getName()).append("\" blipId=\"")
.append(isBlipId()).append("\">\n");
for (int i = 0; i < getNumberOfElementsInArray(); i++) {
builder.append("\t").append(tab).append("<Element>").append(HexDump.toHex(getElement(i))).append("</Element>\n");
}
builder.append(tab).append("</").append(getClass().getSimpleName()).append(">");
return builder.toString();
}
/** /**
* We have this method because the way in which arrays in escher works * We have this method because the way in which arrays in escher works
* is screwed for seemly arbitrary reasons. While most properties are * is screwed for seemly arbitrary reasons. While most properties are
@ -168,7 +196,7 @@ public final class EscherArrayProperty extends EscherComplexProperty implements
*/ */
public int setArrayData(byte[] data, int offset) { public int setArrayData(byte[] data, int offset) {
if (emptyComplexPart) { if (emptyComplexPart) {
setComplexData(new byte[0]); resizeComplexData(0);
} else { } else {
short numElements = LittleEndian.getShort(data, offset); short numElements = LittleEndian.getShort(data, offset);
// LittleEndian.getShort(data, offset + 2); // numReserved // LittleEndian.getShort(data, offset + 2); // numReserved
@ -176,13 +204,14 @@ public final class EscherArrayProperty extends EscherComplexProperty implements
// the code here seems to depend on complexData already being // the code here seems to depend on complexData already being
// sized correctly via the constructor // sized correctly via the constructor
int cdLen = getComplexData().length;
int arraySize = getActualSizeOfElements(sizeOfElements) * numElements; int arraySize = getActualSizeOfElements(sizeOfElements) * numElements;
if (arraySize == getComplexData().length) { if (arraySize == cdLen) {
// The stored data size in the simple block excludes the header size // The stored data size in the simple block excludes the header size
setComplexData(new byte[arraySize + 6]); resizeComplexData(arraySize + 6, 0);
sizeIncludesHeaderSize = false; sizeIncludesHeaderSize = false;
} }
System.arraycopy(data, offset, getComplexData(), 0, getComplexData().length ); setComplexData(data, offset);
} }
return getComplexData().length; return getComplexData().length;
} }
@ -239,5 +268,14 @@ public final class EscherArrayProperty extends EscherComplexProperty implements
}; };
} }
@Override
public Map<String, Supplier<?>> getGenericProperties() {
return GenericRecordUtil.getGenericProperties(
"base", super::getGenericProperties,
"numElements", this::getNumberOfElementsInArray,
"numElementsInMemory", this::getNumberOfElementsInMemory,
"sizeOfElements", this::getSizeOfElements,
"elements", () -> StreamSupport.stream(spliterator(), false).collect(Collectors.toList())
);
}
} }

View File

@ -22,6 +22,7 @@ import java.util.LinkedHashMap;
import java.util.Map; import java.util.Map;
import java.util.function.Supplier; import java.util.function.Supplier;
import org.apache.poi.sl.usermodel.PictureData.PictureType;
import org.apache.poi.util.IOUtils; import org.apache.poi.util.IOUtils;
import org.apache.poi.util.LittleEndian; import org.apache.poi.util.LittleEndian;
@ -39,15 +40,6 @@ public final class EscherBSERecord extends EscherRecord {
public static final short RECORD_ID = EscherRecordTypes.BSE.typeID; public static final short RECORD_ID = EscherRecordTypes.BSE.typeID;
public static final byte BT_ERROR = 0;
public static final byte BT_UNKNOWN = 1;
public static final byte BT_EMF = 2;
public static final byte BT_WMF = 3;
public static final byte BT_PICT = 4;
public static final byte BT_JPEG = 5;
public static final byte BT_PNG = 6;
public static final byte BT_DIB = 7;
private byte field_1_blipTypeWin32; private byte field_1_blipTypeWin32;
private byte field_2_blipTypeMacOS; private byte field_2_blipTypeMacOS;
private final byte[] field_3_uid = new byte[16]; private final byte[] field_3_uid = new byte[16];
@ -164,6 +156,10 @@ public final class EscherBSERecord extends EscherRecord {
return field_1_blipTypeWin32; return field_1_blipTypeWin32;
} }
public PictureType getPictureTypeWin32() {
return PictureType.forNativeID(field_1_blipTypeWin32);
}
/** /**
* Set the expected win32 blip type * Set the expected win32 blip type
* *
@ -183,6 +179,10 @@ public final class EscherBSERecord extends EscherRecord {
return field_2_blipTypeMacOS; return field_2_blipTypeMacOS;
} }
public PictureType getPictureTypeMacOS() {
return PictureType.forNativeID(field_2_blipTypeMacOS);
}
/** /**
* Set the expected MacOS blip type * Set the expected MacOS blip type
* *
@ -363,54 +363,13 @@ public final class EscherBSERecord extends EscherRecord {
_remainingData = (remainingData == null) ? new byte[0] : remainingData.clone(); _remainingData = (remainingData == null) ? new byte[0] : remainingData.clone();
} }
/**
* Retrieve the string representation given a blip id.
*
* @param b the blip type byte-encoded
*
* @return the blip type as string
*/
public static String getBlipType(byte b) {
switch (b) {
case BT_ERROR: return " ERROR";
case BT_UNKNOWN: return " UNKNOWN";
case BT_EMF: return " EMF";
case BT_WMF: return " WMF";
case BT_PICT: return " PICT";
case BT_JPEG: return " JPEG";
case BT_PNG: return " PNG";
case BT_DIB: return " DIB";
}
if ( b < 32 ) {
return " NotKnown";
}
return " Client";
}
@Override
protected Object[][] getAttributeMap() {
return new Object[][] {
{ "BlipTypeWin32", field_1_blipTypeWin32 },
{ "BlipTypeMacOS", field_2_blipTypeMacOS },
{ "SUID", field_3_uid },
{ "Tag", field_4_tag },
{ "Size", field_5_size },
{ "Ref", field_6_ref },
{ "Offset", field_7_offset },
{ "Usage", field_8_usage },
{ "Name", field_9_name },
{ "Unused2", field_10_unused2 },
{ "Unused3", field_11_unused3 },
{ "Blip Record", field_12_blipRecord },
{ "Extra Data", _remainingData }
};
}
@Override @Override
public Map<String, Supplier<?>> getGenericProperties() { public Map<String, Supplier<?>> getGenericProperties() {
final Map<String, Supplier<?>> m = new LinkedHashMap<>(super.getGenericProperties()); final Map<String, Supplier<?>> m = new LinkedHashMap<>(super.getGenericProperties());
m.put("blipTypeWin32", this::getBlipTypeWin32); m.put("blipTypeWin32", this::getBlipTypeWin32);
m.put("pictureTypeWin32", this::getPictureTypeWin32);
m.put("blipTypeMacOS", this::getBlipTypeMacOS); m.put("blipTypeMacOS", this::getBlipTypeMacOS);
m.put("pictureTypeMacOS", this::getPictureTypeMacOS);
m.put("suid", this::getUid); m.put("suid", this::getUid);
m.put("tag", this::getTag); m.put("tag", this::getTag);
m.put("size", this::getSize); m.put("size", this::getSize);

View File

@ -17,11 +17,10 @@
package org.apache.poi.ddf; package org.apache.poi.ddf;
import java.util.Collections;
import java.util.LinkedHashMap;
import java.util.Map; import java.util.Map;
import java.util.function.Supplier; import java.util.function.Supplier;
import org.apache.poi.util.GenericRecordUtil;
import org.apache.poi.util.LittleEndian; import org.apache.poi.util.LittleEndian;
public class EscherBitmapBlip extends EscherBlipRecord { public class EscherBitmapBlip extends EscherBlipRecord {
@ -113,21 +112,13 @@ public class EscherBitmapBlip extends EscherBlipRecord {
this.field_2_marker = field_2_marker; this.field_2_marker = field_2_marker;
} }
@Override
protected Object[][] getAttributeMap() {
return new Object[][] {
{ "Marker", field_2_marker },
{ "Extra Data", getPicturedata() }
};
}
@Override @Override
public Map<String, Supplier<?>> getGenericProperties() { public Map<String, Supplier<?>> getGenericProperties() {
final Map<String, Supplier<?>> m = new LinkedHashMap<>(super.getGenericProperties()); return GenericRecordUtil.getGenericProperties(
m.put("uid", this::getUID); "base", super::getGenericProperties,
m.put("marker", this::getMarker); "uid", this::getUID,
return Collections.unmodifiableMap(m); "marker", this::getMarker
);
} }
} }

View File

@ -107,13 +107,6 @@ public class EscherBlipRecord extends EscherRecord {
System.arraycopy(pictureData, offset, field_pictureData, 0, length); System.arraycopy(pictureData, offset, field_pictureData, 0, length);
} }
@Override
protected Object[][] getAttributeMap() {
return new Object[][] {
{ "Extra Data", getPicturedata() }
};
}
@Override @Override
public Map<String, Supplier<?>> getGenericProperties() { public Map<String, Supplier<?>> getGenericProperties() {
return GenericRecordUtil.getGenericProperties( return GenericRecordUtil.getGenericProperties(

View File

@ -18,8 +18,6 @@
package org.apache.poi.ddf; package org.apache.poi.ddf;
import org.apache.poi.util.HexDump;
/** /**
* Represents a boolean property. The actual utility of this property is in doubt because many * Represents a boolean property. The actual utility of this property is in doubt because many
* of the properties marked as boolean seem to actually contain special values. In other words * of the properties marked as boolean seem to actually contain special values. In other words
@ -42,6 +40,18 @@ public class EscherBoolProperty
super(propertyNumber, value); super(propertyNumber, value);
} }
/**
* Create an instance of an escher boolean property.
*
* @param propertyType The property type
* @param value The 32 bit value of this bool property
*/
public EscherBoolProperty( EscherPropertyTypes propertyType, int value )
{
super(propertyType.propNumber, value);
}
/** /**
* Whether this boolean property is true * Whether this boolean property is true
* *
@ -51,21 +61,4 @@ public class EscherBoolProperty
{ {
return getPropertyValue() != 0; return getPropertyValue() != 0;
} }
// public String toString()
// {
// return "propNum: " + getPropertyNumber()
// + ", complex: " + isComplex()
// + ", blipId: " + isBlipId()
// + ", value: " + (getValue() != 0);
// }
@Override
public String toXml(String tab){
StringBuilder builder = new StringBuilder();
builder.append(tab).append("<").append(getClass().getSimpleName()).append(" id=\"0x").append(HexDump.toHex(getId()))
.append("\" name=\"").append(getName()).append("\" simpleValue=\"").append(getPropertyValue()).append("\" blipId=\"")
.append(isBlipId()).append("\" value=\"").append(isTrue()).append("\"").append("/>");
return builder.toString();
}
} }

View File

@ -176,16 +176,6 @@ public class EscherChildAnchorRecord extends EscherRecord {
this.field_4_dy2 = field_4_dy2; this.field_4_dy2 = field_4_dy2;
} }
@Override
protected Object[][] getAttributeMap() {
return new Object[][] {
{ "X1", field_1_dx1 },
{ "Y1", field_2_dy1 },
{ "X2", field_3_dx2 },
{ "Y2", field_4_dy2 }
};
}
@Override @Override
public Map<String, Supplier<?>> getGenericProperties() { public Map<String, Supplier<?>> getGenericProperties() {
return GenericRecordUtil.getGenericProperties( return GenericRecordUtil.getGenericProperties(

View File

@ -348,22 +348,6 @@ public class EscherClientAnchorRecord extends EscherRecord {
} }
} }
@Override
protected Object[][] getAttributeMap() {
return new Object[][] {
{ "Flag", field_1_flag },
{ "Col1", field_2_col1 },
{ "DX1", field_3_dx1 },
{ "Row1", field_4_row1 },
{ "DY1", field_5_dy1 },
{ "Col2", field_6_col2 },
{ "DX2", field_7_dx2 },
{ "Row2", field_8_row2 },
{ "DY2", field_9_dy2 },
{ "Extra Data", remainingData }
};
}
@Override @Override
public Map<String, Supplier<?>> getGenericProperties() { public Map<String, Supplier<?>> getGenericProperties() {
final Map<String,Supplier<?>> m = new LinkedHashMap<>(super.getGenericProperties()); final Map<String,Supplier<?>> m = new LinkedHashMap<>(super.getGenericProperties());

View File

@ -102,13 +102,6 @@ public class EscherClientDataRecord
: remainingData.clone(); : remainingData.clone();
} }
@Override
protected Object[][] getAttributeMap() {
return new Object[][] {
{ "Extra Data", getRemainingData() }
};
}
@Override @Override
public Map<String, Supplier<?>> getGenericProperties() { public Map<String, Supplier<?>> getGenericProperties() {
return GenericRecordUtil.getGenericProperties( return GenericRecordUtil.getGenericProperties(

View File

@ -18,9 +18,13 @@
package org.apache.poi.ddf; package org.apache.poi.ddf;
import java.util.Arrays; import java.util.Arrays;
import java.util.Map;
import java.util.function.Supplier;
import org.apache.poi.util.HexDump; import org.apache.poi.util.GenericRecordUtil;
import org.apache.poi.util.IOUtils;
import org.apache.poi.util.LittleEndian; import org.apache.poi.util.LittleEndian;
import org.apache.poi.util.Removal;
/** /**
* A complex property differs from a simple property in that the data can not fit inside a 32 bit * A complex property differs from a simple property in that the data can not fit inside a 32 bit
@ -28,7 +32,10 @@ import org.apache.poi.util.LittleEndian;
* stored here. * stored here.
*/ */
public class EscherComplexProperty extends EscherProperty { public class EscherComplexProperty extends EscherProperty {
private byte[] _complexData; //arbitrarily selected; may need to increase
private static final int MAX_RECORD_LENGTH = 100_000_000;
private byte[] complexData;
/** /**
* Create a complex property using the property id and a byte array containing the complex * Create a complex property using the property id and a byte array containing the complex
@ -38,12 +45,11 @@ public class EscherComplexProperty extends EscherProperty {
* indicating that this is a complex property. * indicating that this is a complex property.
* @param complexData The value of this property. * @param complexData The value of this property.
*/ */
@Deprecated
@Removal(version = "5.0.0")
public EscherComplexProperty(short id, byte[] complexData) { public EscherComplexProperty(short id, byte[] complexData) {
super(id); this(id, complexData == null ? 0 : complexData.length);
if (complexData == null) { setComplexData(complexData);
throw new IllegalArgumentException("complexData can't be null");
}
_complexData = complexData.clone();
} }
/** /**
@ -54,12 +60,48 @@ public class EscherComplexProperty extends EscherProperty {
* @param isBlipId Whether this is a blip id. Should be false. * @param isBlipId Whether this is a blip id. Should be false.
* @param complexData The value of this complex property. * @param complexData The value of this complex property.
*/ */
@Deprecated
@Removal(version = "5.0.0")
public EscherComplexProperty(short propertyNumber, boolean isBlipId, byte[] complexData) { public EscherComplexProperty(short propertyNumber, boolean isBlipId, byte[] complexData) {
super(propertyNumber, true, isBlipId); this(propertyNumber, isBlipId, complexData == null ? 0 : complexData.length);
if (complexData == null) { setComplexData(complexData);
throw new IllegalArgumentException("complexData can't be null");
} }
_complexData = complexData.clone();
/**
* Create a complex property using the property id and a byte array containing the complex
* data value size.
*
* @param 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.
* @param complexSize The byte size of this property.
*/
public EscherComplexProperty(short id, int complexSize) {
super((short)(id | IS_COMPLEX));
complexData = IOUtils.safelyAllocate(complexSize, MAX_RECORD_LENGTH);
}
/**
* Create a complex property using the property number, a flag to indicate whether this is a
* blip reference and the complex property data size.
*
* @param propertyNumber The property number
* @param isBlipId Whether this is a blip id. Should be false.
* @param complexSize The byte size of this property.
*/
public EscherComplexProperty(short propertyNumber, boolean isBlipId, int complexSize) {
this((short)(propertyNumber | (isBlipId ? IS_BLIP : 0)), complexSize);
}
/**
* Create a complex property using the property type, a flag to indicate whether this is a
* blip reference and the complex property data size.
*
* @param type The property type
* @param isBlipId Whether this is a blip id. Should be false.
* @param complexSize The byte size of this property.
*/
public EscherComplexProperty(EscherPropertyTypes type, boolean isBlipId, int complexSize) {
this((short)(type.propNumber | (isBlipId ? IS_BLIP : 0)), complexSize);
} }
/** /**
@ -68,7 +110,7 @@ public class EscherComplexProperty extends EscherProperty {
@Override @Override
public int serializeSimplePart(byte[] data, int pos) { public int serializeSimplePart(byte[] data, int pos) {
LittleEndian.putShort(data, pos, getId()); LittleEndian.putShort(data, pos, getId());
LittleEndian.putInt(data, pos + 2, _complexData.length); LittleEndian.putInt(data, pos + 2, complexData.length);
return 6; return 6;
} }
@ -81,8 +123,8 @@ public class EscherComplexProperty extends EscherProperty {
*/ */
@Override @Override
public int serializeComplexPart(byte[] data, int pos) { public int serializeComplexPart(byte[] data, int pos) {
System.arraycopy(_complexData, 0, data, pos, _complexData.length); System.arraycopy(complexData, 0, data, pos, complexData.length);
return _complexData.length; return complexData.length;
} }
/** /**
@ -91,11 +133,36 @@ public class EscherComplexProperty extends EscherProperty {
* @return the complex bytes * @return the complex bytes
*/ */
public byte[] getComplexData() { public byte[] getComplexData() {
return _complexData; return complexData;
} }
protected void setComplexData(byte[] _complexData) { public int setComplexData(byte[] complexData) {
this._complexData = _complexData; return setComplexData(complexData, 0);
}
public int setComplexData(byte[] complexData, int offset) {
if (complexData == null) {
return 0;
} else {
int copySize = Math.max(0, Math.min(this.complexData.length, complexData.length - offset));
System.arraycopy(complexData, offset, this.complexData, 0, copySize);
return copySize;
}
}
protected void resizeComplexData(int newSize) {
resizeComplexData(newSize, Integer.MAX_VALUE);
}
protected void resizeComplexData(int newSize, int copyLen) {
if (newSize == complexData.length) {
return;
}
byte[] newArray = IOUtils.safelyAllocate(newSize, MAX_RECORD_LENGTH);
System.arraycopy(complexData, 0, newArray, 0, Math.min(Math.min(complexData.length, copyLen),newSize));
complexData = newArray;
} }
/** /**
@ -109,14 +176,13 @@ public class EscherComplexProperty extends EscherProperty {
if (this == o) { if (this == o) {
return true; return true;
} }
if (o == null || !(o instanceof EscherComplexProperty)) { if (!(o instanceof EscherComplexProperty)) {
return false; return false;
} }
EscherComplexProperty escherComplexProperty = (EscherComplexProperty) o; EscherComplexProperty escherComplexProperty = (EscherComplexProperty) o;
return Arrays.equals(_complexData, escherComplexProperty._complexData); return Arrays.equals(complexData, escherComplexProperty.complexData);
} }
/** /**
@ -126,7 +192,7 @@ public class EscherComplexProperty extends EscherProperty {
*/ */
@Override @Override
public int getPropertySize() { public int getPropertySize() {
return 6 + _complexData.length; return 6 + complexData.length;
} }
@Override @Override
@ -134,26 +200,11 @@ public class EscherComplexProperty extends EscherProperty {
return getId() * 11; return getId() * 11;
} }
/**
* Retrieves the string representation for this property.
*/
@Override @Override
public String toString() { public Map<String, Supplier<?>> getGenericProperties() {
String dataStr = HexDump.toHex( _complexData, 32); return GenericRecordUtil.getGenericProperties(
"base", super::getGenericProperties,
return "propNum: " + getPropertyNumber() "data", this::getComplexData
+ ", propName: " + EscherProperties.getPropertyName( getPropertyNumber() ) );
+ ", complex: " + isComplex()
+ ", blipId: " + isBlipId()
+ ", data: " + System.getProperty("line.separator") + dataStr;
}
@Override
public String toXml(String tab){
return tab + "<" + getClass().getSimpleName() + " id=\"0x" + HexDump.toHex(getId()) +
"\" name=\"" + getName() + "\" blipId=\"" +
isBlipId() + "\">\n" +
tab + "</" + getClass().getSimpleName() + ">";
//builder.append("\t").append(tab).append(dataStr);
} }
} }

View File

@ -272,23 +272,6 @@ public final class EscherContainerRecord extends EscherRecord implements Iterabl
} }
} }
@Override
protected Object[][] getAttributeMap() {
List<Object> chList = new ArrayList<>(_childRecords.size() * 2 + 2);
chList.add("children");
chList.add(_childRecords.size());
int count = 0;
for ( EscherRecord record : this ) {
chList.add("Child "+count);
chList.add(record);
count++;
}
return new Object[][] {
{ "isContainer", isContainerRecord() },
chList.toArray()
};
}
@Override @Override
public Map<String, Supplier<?>> getGenericProperties() { public Map<String, Supplier<?>> getGenericProperties() {
return GenericRecordUtil.getGenericProperties( return GenericRecordUtil.getGenericProperties(

View File

@ -144,14 +144,6 @@ public class EscherDgRecord extends EscherRecord {
this.field_1_numShapes++; this.field_1_numShapes++;
} }
@Override
protected Object[][] getAttributeMap() {
return new Object[][] {
{ "NumShapes", field_1_numShapes },
{ "LastMSOSPID", field_2_lastMSOSPID }
};
}
@Override @Override
public Map<String, Supplier<?>> getGenericProperties() { public Map<String, Supplier<?>> getGenericProperties() {
return GenericRecordUtil.getGenericProperties( return GenericRecordUtil.getGenericProperties(

View File

@ -336,26 +336,6 @@ public final class EscherDggRecord extends EscherRecord {
return shapeId; return shapeId;
} }
@Override
protected Object[][] getAttributeMap() {
List<Object> fldIds = new ArrayList<>();
fldIds.add("FileId Clusters");
fldIds.add(field_5_fileIdClusters.size());
for (FileIdCluster fic : field_5_fileIdClusters) {
fldIds.add("Group"+fic.field_1_drawingGroupId);
fldIds.add(fic.field_2_numShapeIdsUsed);
}
return new Object[][] {
{ "ShapeIdMax", field_1_shapeIdMax },
{ "NumIdClusters", getNumIdClusters() },
{ "NumShapesSaved", field_3_numShapesSaved },
{ "DrawingsSaved", field_4_drawingsSaved },
fldIds.toArray()
};
}
@Override @Override
public Enum getGenericRecordType() { public Enum getGenericRecordType() {
return EscherRecordTypes.DGG; return EscherRecordTypes.DGG;

View File

@ -17,25 +17,13 @@
package org.apache.poi.ddf; package org.apache.poi.ddf;
import java.io.ByteArrayInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.PrintStream; import java.io.PrintStream;
import java.util.zip.InflaterInputStream;
import org.apache.poi.util.HexDump;
import org.apache.poi.util.HexRead;
import org.apache.poi.util.LittleEndian;
/** /**
* Used to dump the contents of escher records to a PrintStream. * Used to dump the contents of escher records to a PrintStream.
*/ */
public final class EscherDump { public final class EscherDump {
public EscherDump() {
//
}
/** /**
* Decodes the escher stream from a byte array and dumps the results to * Decodes the escher stream from a byte array and dumps the results to
* a print stream. * a print stream.
@ -58,869 +46,6 @@ public final class EscherDump {
} }
} }
/**
* This version of dump is a translation from the open office escher dump routine.
*
* @param maxLength The number of bytes to read
* @param in An input stream to read from.
* @param out An output stream to write to.
*
* @throws IOException if the data can't be read or written
* @throws LittleEndian.BufferUnderrunException if an buffer underrun occurs
*/
public void dumpOld(long maxLength, InputStream in, PrintStream out)
throws IOException, LittleEndian.BufferUnderrunException {
long remainingBytes = maxLength;
short options; // 4 bits for the version and 12 bits for the instance
short recordId;
int recordBytesRemaining; // including enclosing records
short nDumpSize;
String recordName;
boolean atEOF = false;
while (!atEOF && (remainingBytes > 0)) {
options = LittleEndian.readShort( in );
recordId = LittleEndian.readShort( in );
recordBytesRemaining = LittleEndian.readInt( in );
remainingBytes -= 2 + 2 + 4;
switch ( recordId )
{
case (short) 0xF000:
recordName = "MsofbtDggContainer";
break;
case (short) 0xF006:
recordName = "MsofbtDgg";
break;
case (short) 0xF016:
recordName = "MsofbtCLSID";
break;
case (short) 0xF00B:
recordName = "MsofbtOPT";
break;
case (short) 0xF11A:
recordName = "MsofbtColorMRU";
break;
case (short) 0xF11E:
recordName = "MsofbtSplitMenuColors";
break;
case (short) 0xF001:
recordName = "MsofbtBstoreContainer";
break;
case (short) 0xF007:
recordName = "MsofbtBSE";
break;
case (short) 0xF002:
recordName = "MsofbtDgContainer";
break;
case (short) 0xF008:
recordName = "MsofbtDg";
break;
case (short) 0xF118:
recordName = "MsofbtRegroupItem";
break;
case (short) 0xF120:
recordName = "MsofbtColorScheme";
break;
case (short) 0xF003:
recordName = "MsofbtSpgrContainer";
break;
case (short) 0xF004:
recordName = "MsofbtSpContainer";
break;
case (short) 0xF009:
recordName = "MsofbtSpgr";
break;
case (short) 0xF00A:
recordName = "MsofbtSp";
break;
case (short) 0xF00C:
recordName = "MsofbtTextbox";
break;
case (short) 0xF00D:
recordName = "MsofbtClientTextbox";
break;
case (short) 0xF00E:
recordName = "MsofbtAnchor";
break;
case (short) 0xF00F:
recordName = "MsofbtChildAnchor";
break;
case (short) 0xF010:
recordName = "MsofbtClientAnchor";
break;
case (short) 0xF011:
recordName = "MsofbtClientData";
break;
case (short) 0xF11F:
recordName = "MsofbtOleObject";
break;
case (short) 0xF11D:
recordName = "MsofbtDeletedPspl";
break;
case (short) 0xF005:
recordName = "MsofbtSolverContainer";
break;
case (short) 0xF012:
recordName = "MsofbtConnectorRule";
break;
case (short) 0xF013:
recordName = "MsofbtAlignRule";
break;
case (short) 0xF014:
recordName = "MsofbtArcRule";
break;
case (short) 0xF015:
recordName = "MsofbtClientRule";
break;
case (short) 0xF017:
recordName = "MsofbtCalloutRule";
break;
case (short) 0xF119:
recordName = "MsofbtSelection";
break;
case (short) 0xF122:
recordName = "MsofbtUDefProp";
break;
default:
if ( recordId >= (short) 0xF018 && recordId <= (short) 0xF117 ) {
recordName = "MsofbtBLIP";
} else if ( ( options & (short) 0x000F ) == (short) 0x000F ) {
recordName = "UNKNOWN container";
} else {
recordName = "UNKNOWN ID";
}
}
StringBuilder stringBuf = new StringBuilder();
stringBuf.append( " " );
stringBuf.append( HexDump.toHex( recordId ) );
stringBuf.append( " " ).append( recordName ).append( " [" );
stringBuf.append( HexDump.toHex( options ) );
stringBuf.append( ',' );
stringBuf.append( HexDump.toHex( recordBytesRemaining ) );
stringBuf.append( "] instance: " );
stringBuf.append( HexDump.toHex( ( (short) ( options >> 4 ) ) ) );
out.println(stringBuf);
stringBuf.setLength(0);
if ( recordId == (short) 0xF007 && 36 <= remainingBytes && 36 <= recordBytesRemaining )
{ // BSE, FBSE
// ULONG nP = pIn->GetRecPos();
byte n8;
// short n16;
// int n32;
stringBuf = stringBuf.append( " btWin32: " );
n8 = (byte) in.read();
stringBuf.append( HexDump.toHex( n8 ) );
stringBuf.append( getBlipType( n8 ) );
stringBuf.append( " btMacOS: " );
n8 = (byte) in.read();
stringBuf.append( HexDump.toHex( n8 ) );
stringBuf.append( getBlipType( n8 ) );
out.println(stringBuf);
out.println( " rgbUid:" );
HexDump.dump( in, out, 0, 16 );
out.print( " tag: " );
outHex( 2, in, out );
out.println();
out.print( " size: " );
outHex( 4, in, out );
out.println();
out.print( " cRef: " );
outHex( 4, in, out );
out.println();
out.print( " offs: " );
outHex( 4, in, out );
out.println();
out.print( " usage: " );
outHex( 1, in, out );
out.println();
out.print( " cbName: " );
outHex( 1, in, out );
out.println();
out.print( " unused2: " );
outHex( 1, in, out );
out.println();
out.print( " unused3: " );
outHex( 1, in, out );
out.println();
// subtract the number of bytes we've read
remainingBytes -= 36;
//n -= pIn->GetRecPos() - nP;
recordBytesRemaining = 0; // loop to MsofbtBLIP
}
else if ( recordId == (short) 0xF010 && 0x12 <= remainingBytes && 0x12 <= recordBytesRemaining )
{ // ClientAnchor
//ULONG nP = pIn->GetRecPos();
// short n16;
out.print( " Flag: " );
outHex( 2, in, out );
out.println();
out.print( " Col1: " );
outHex( 2, in, out );
out.print( " dX1: " );
outHex( 2, in, out );
out.print( " Row1: " );
outHex( 2, in, out );
out.print( " dY1: " );
outHex( 2, in, out );
out.println();
out.print( " Col2: " );
outHex( 2, in, out );
out.print( " dX2: " );
outHex( 2, in, out );
out.print( " Row2: " );
outHex( 2, in, out );
out.print( " dY2: " );
outHex( 2, in, out );
out.println();
remainingBytes -= 18;
recordBytesRemaining -= 18;
}
else if ( recordId == (short) 0xF00B || recordId == (short) 0xF122 )
{ // OPT
int nComplex = 0;
out.println( " PROPID VALUE" );
while ( recordBytesRemaining >= 6 + nComplex && remainingBytes >= 6 + nComplex )
{
short n16;
int n32;
n16 = LittleEndian.readShort( in );
n32 = LittleEndian.readInt( in );
recordBytesRemaining -= 6;
remainingBytes -= 6;
out.print( " " );
out.print( HexDump.toHex( n16 ) );
out.print( " (" );
int propertyId = n16 & (short) 0x3FFF;
out.print( " " + propertyId );
if ( ( n16 & (short) 0x8000 ) == 0 )
{
if ( ( n16 & (short) 0x4000 ) != 0 ) {
out.print( ", fBlipID" );
}
out.print( ") " );
out.print( HexDump.toHex( n32 ) );
if ( ( n16 & (short) 0x4000 ) == 0 )
{
out.print( " (" );
out.print( dec1616( n32 ) );
out.print( ')' );
out.print( " {" + propName( (short)propertyId ) + "}" );
}
out.println();
}
else
{
out.print( ", fComplex) " );
out.print( HexDump.toHex( n32 ) );
out.print( " - Complex prop len" );
out.println( " {" + propName( (short)propertyId ) + "}" );
nComplex += n32;
}
}
// complex property data
while ( ( nComplex & remainingBytes ) > 0 )
{
nDumpSize = ( nComplex > (int) remainingBytes ) ? (short) remainingBytes : (short) nComplex;
HexDump.dump( in, out, 0, nDumpSize );
nComplex -= nDumpSize;
recordBytesRemaining -= nDumpSize;
remainingBytes -= nDumpSize;
}
}
else if ( recordId == (short) 0xF012 )
{
out.print( " Connector rule: " );
out.print( LittleEndian.readInt( in ) );
out.print( " ShapeID A: " );
out.print( LittleEndian.readInt( in ) );
out.print( " ShapeID B: " );
out.print( LittleEndian.readInt( in ) );
out.print( " ShapeID connector: " );
out.print( LittleEndian.readInt( in ) );
out.print( " Connect pt A: " );
out.print( LittleEndian.readInt( in ) );
out.print( " Connect pt B: " );
out.println( LittleEndian.readInt( in ) );
recordBytesRemaining -= 24;
remainingBytes -= 24;
}
else if ( recordId >= (short) 0xF018 && recordId < (short) 0xF117 )
{
out.println( " Secondary UID: " );
HexDump.dump( in, out, 0, 16 );
out.println( " Cache of size: " + HexDump.toHex( LittleEndian.readInt( in ) ) );
out.println( " Boundary top: " + HexDump.toHex( LittleEndian.readInt( in ) ) );
out.println( " Boundary left: " + HexDump.toHex( LittleEndian.readInt( in ) ) );
out.println( " Boundary width: " + HexDump.toHex( LittleEndian.readInt( in ) ) );
out.println( " Boundary height: " + HexDump.toHex( LittleEndian.readInt( in ) ) );
out.println( " X: " + HexDump.toHex( LittleEndian.readInt( in ) ) );
out.println( " Y: " + HexDump.toHex( LittleEndian.readInt( in ) ) );
out.println( " Cache of saved size: " + HexDump.toHex( LittleEndian.readInt( in ) ) );
out.println( " Compression Flag: " + HexDump.toHex( (byte) in.read() ) );
out.println( " Filter: " + HexDump.toHex( (byte) in.read() ) );
out.println( " Data (after decompression): " );
recordBytesRemaining -= 34 + 16;
remainingBytes -= 34 + 16;
nDumpSize = ( recordBytesRemaining > (int) remainingBytes ) ? (short) remainingBytes : (short) recordBytesRemaining;
byte[] buf = new byte[nDumpSize];
int read = in.read( buf );
while ( read != -1 && read < nDumpSize ) {
read += in.read( buf, read, buf.length );
}
ByteArrayInputStream bin = new ByteArrayInputStream( buf );
InputStream in1 = new InflaterInputStream( bin );
int bytesToDump = -1;
HexDump.dump( in1, out, 0, bytesToDump );
recordBytesRemaining -= nDumpSize;
remainingBytes -= nDumpSize;
}
boolean isContainer = ( options & (short) 0x000F ) == (short) 0x000F;
if ( isContainer && remainingBytes >= 0 )
{ // Container
if ( recordBytesRemaining <= (int) remainingBytes ) {
out.println( " completed within" );
} else {
out.println( " continued elsewhere" );
}
}
else if ( remainingBytes >= 0 )
// -> 0x0000 ... 0x0FFF
{
nDumpSize = ( recordBytesRemaining > (int) remainingBytes ) ? (short) remainingBytes : (short) recordBytesRemaining;
if ( nDumpSize != 0 )
{
HexDump.dump( in, out, 0, nDumpSize );
remainingBytes -= nDumpSize;
}
} else {
out.println( " >> OVERRUN <<" );
}
}
}
/**
* Returns a property name given a property id. This is used only by the
* old escher dump routine.
*
* @param propertyId The property number for the name
* @return A descriptive name.
*/
private String propName(short propertyId) {
final class PropName {
final int _id;
final String _name;
public PropName(int id, String name) {
_id = id;
_name = name;
}
}
final PropName[] props = new PropName[] {
new PropName(4, "transform.rotation"),
new PropName(119, "protection.lockrotation"),
new PropName(120, "protection.lockaspectratio"),
new PropName(121, "protection.lockposition"),
new PropName(122, "protection.lockagainstselect"),
new PropName(123, "protection.lockcropping"),
new PropName(124, "protection.lockvertices"),
new PropName(125, "protection.locktext"),
new PropName(126, "protection.lockadjusthandles"),
new PropName(127, "protection.lockagainstgrouping"),
new PropName(128, "text.textid"),
new PropName(129, "text.textleft"),
new PropName(130, "text.texttop"),
new PropName(131, "text.textright"),
new PropName(132, "text.textbottom"),
new PropName(133, "text.wraptext"),
new PropName(134, "text.scaletext"),
new PropName(135, "text.anchortext"),
new PropName(136, "text.textflow"),
new PropName(137, "text.fontrotation"),
new PropName(138, "text.idofnextshape"),
new PropName(139, "text.bidir"),
new PropName(187, "text.singleclickselects"),
new PropName(188, "text.usehostmargins"),
new PropName(189, "text.rotatetextwithshape"),
new PropName(190, "text.sizeshapetofittext"),
new PropName(191, "text.sizetexttofitshape"),
new PropName(192, "geotext.unicode"),
new PropName(193, "geotext.rtftext"),
new PropName(194, "geotext.alignmentoncurve"),
new PropName(195, "geotext.defaultpointsize"),
new PropName(196, "geotext.textspacing"),
new PropName(197, "geotext.fontfamilyname"),
new PropName(240, "geotext.reverseroworder"),
new PropName(241, "geotext.hastexteffect"),
new PropName(242, "geotext.rotatecharacters"),
new PropName(243, "geotext.kerncharacters"),
new PropName(244, "geotext.tightortrack"),
new PropName(245, "geotext.stretchtofitshape"),
new PropName(246, "geotext.charboundingbox"),
new PropName(247, "geotext.scaletextonpath"),
new PropName(248, "geotext.stretchcharheight"),
new PropName(249, "geotext.nomeasurealongpath"),
new PropName(250, "geotext.boldfont"),
new PropName(251, "geotext.italicfont"),
new PropName(252, "geotext.underlinefont"),
new PropName(253, "geotext.shadowfont"),
new PropName(254, "geotext.smallcapsfont"),
new PropName(255, "geotext.strikethroughfont"),
new PropName(256, "blip.cropfromtop"),
new PropName(257, "blip.cropfrombottom"),
new PropName(258, "blip.cropfromleft"),
new PropName(259, "blip.cropfromright"),
new PropName(260, "blip.bliptodisplay"),
new PropName(261, "blip.blipfilename"),
new PropName(262, "blip.blipflags"),
new PropName(263, "blip.transparentcolor"),
new PropName(264, "blip.contrastsetting"),
new PropName(265, "blip.brightnesssetting"),
new PropName(266, "blip.gamma"),
new PropName(267, "blip.pictureid"),
new PropName(268, "blip.doublemod"),
new PropName(269, "blip.picturefillmod"),
new PropName(270, "blip.pictureline"),
new PropName(271, "blip.printblip"),
new PropName(272, "blip.printblipfilename"),
new PropName(273, "blip.printflags"),
new PropName(316, "blip.nohittestpicture"),
new PropName(317, "blip.picturegray"),
new PropName(318, "blip.picturebilevel"),
new PropName(319, "blip.pictureactive"),
new PropName(320, "geometry.left"),
new PropName(321, "geometry.top"),
new PropName(322, "geometry.right"),
new PropName(323, "geometry.bottom"),
new PropName(324, "geometry.shapepath"),
new PropName(325, "geometry.vertices"),
new PropName(326, "geometry.segmentinfo"),
new PropName(327, "geometry.adjustvalue"),
new PropName(328, "geometry.adjust2value"),
new PropName(329, "geometry.adjust3value"),
new PropName(330, "geometry.adjust4value"),
new PropName(331, "geometry.adjust5value"),
new PropName(332, "geometry.adjust6value"),
new PropName(333, "geometry.adjust7value"),
new PropName(334, "geometry.adjust8value"),
new PropName(335, "geometry.adjust9value"),
new PropName(336, "geometry.adjust10value"),
new PropName(378, "geometry.shadowOK"),
new PropName(379, "geometry.3dok"),
new PropName(380, "geometry.lineok"),
new PropName(381, "geometry.geotextok"),
new PropName(382, "geometry.fillshadeshapeok"),
new PropName(383, "geometry.fillok"),
new PropName(384, "fill.filltype"),
new PropName(385, "fill.fillcolor"),
new PropName(386, "fill.fillopacity"),
new PropName(387, "fill.fillbackcolor"),
new PropName(388, "fill.backopacity"),
new PropName(389, "fill.crmod"),
new PropName(390, "fill.patterntexture"),
new PropName(391, "fill.blipfilename"),
new PropName(392, "fill.blipflags"),
new PropName(393, "fill.width"),
new PropName(394, "fill.height"),
new PropName(395, "fill.angle"),
new PropName(396, "fill.focus"),
new PropName(397, "fill.toleft"),
new PropName(398, "fill.totop"),
new PropName(399, "fill.toright"),
new PropName(400, "fill.tobottom"),
new PropName(401, "fill.rectleft"),
new PropName(402, "fill.recttop"),
new PropName(403, "fill.rectright"),
new PropName(404, "fill.rectbottom"),
new PropName(405, "fill.dztype"),
new PropName(406, "fill.shadepreset"),
new PropName(407, "fill.shadecolors"),
new PropName(408, "fill.originx"),
new PropName(409, "fill.originy"),
new PropName(410, "fill.shapeoriginx"),
new PropName(411, "fill.shapeoriginy"),
new PropName(412, "fill.shadetype"),
new PropName(443, "fill.filled"),
new PropName(444, "fill.hittestfill"),
new PropName(445, "fill.shape"),
new PropName(446, "fill.userect"),
new PropName(447, "fill.nofillhittest"),
new PropName(448, "linestyle.color"),
new PropName(449, "linestyle.opacity"),
new PropName(450, "linestyle.backcolor"),
new PropName(451, "linestyle.crmod"),
new PropName(452, "linestyle.linetype"),
new PropName(453, "linestyle.fillblip"),
new PropName(454, "linestyle.fillblipname"),
new PropName(455, "linestyle.fillblipflags"),
new PropName(456, "linestyle.fillwidth"),
new PropName(457, "linestyle.fillheight"),
new PropName(458, "linestyle.filldztype"),
new PropName(459, "linestyle.linewidth"),
new PropName(460, "linestyle.linemiterlimit"),
new PropName(461, "linestyle.linestyle"),
new PropName(462, "linestyle.linedashing"),
new PropName(463, "linestyle.linedashstyle"),
new PropName(464, "linestyle.linestartarrowhead"),
new PropName(465, "linestyle.lineendarrowhead"),
new PropName(466, "linestyle.linestartarrowwidth"),
new PropName(467, "linestyle.lineestartarrowlength"),
new PropName(468, "linestyle.lineendarrowwidth"),
new PropName(469, "linestyle.lineendarrowlength"),
new PropName(470, "linestyle.linejoinstyle"),
new PropName(471, "linestyle.lineendcapstyle"),
new PropName(507, "linestyle.arrowheadsok"),
new PropName(508, "linestyle.anyline"),
new PropName(509, "linestyle.hitlinetest"),
new PropName(510, "linestyle.linefillshape"),
new PropName(511, "linestyle.nolinedrawdash"),
new PropName(512, "shadowstyle.type"),
new PropName(513, "shadowstyle.color"),
new PropName(514, "shadowstyle.highlight"),
new PropName(515, "shadowstyle.crmod"),
new PropName(516, "shadowstyle.opacity"),
new PropName(517, "shadowstyle.offsetx"),
new PropName(518, "shadowstyle.offsety"),
new PropName(519, "shadowstyle.secondoffsetx"),
new PropName(520, "shadowstyle.secondoffsety"),
new PropName(521, "shadowstyle.scalextox"),
new PropName(522, "shadowstyle.scaleytox"),
new PropName(523, "shadowstyle.scalextoy"),
new PropName(524, "shadowstyle.scaleytoy"),
new PropName(525, "shadowstyle.perspectivex"),
new PropName(526, "shadowstyle.perspectivey"),
new PropName(527, "shadowstyle.weight"),
new PropName(528, "shadowstyle.originx"),
new PropName(529, "shadowstyle.originy"),
new PropName(574, "shadowstyle.shadow"),
new PropName(575, "shadowstyle.shadowobsured"),
new PropName(576, "perspective.type"),
new PropName(577, "perspective.offsetx"),
new PropName(578, "perspective.offsety"),
new PropName(579, "perspective.scalextox"),
new PropName(580, "perspective.scaleytox"),
new PropName(581, "perspective.scalextoy"),
new PropName(582, "perspective.scaleytox"),
new PropName(583, "perspective.perspectivex"),
new PropName(584, "perspective.perspectivey"),
new PropName(585, "perspective.weight"),
new PropName(586, "perspective.originx"),
new PropName(587, "perspective.originy"),
new PropName(639, "perspective.perspectiveon"),
new PropName(640, "3d.specularamount"),
new PropName(661, "3d.diffuseamount"),
new PropName(662, "3d.shininess"),
new PropName(663, "3d.edgethickness"),
new PropName(664, "3d.extrudeforward"),
new PropName(665, "3d.extrudebackward"),
new PropName(666, "3d.extrudeplane"),
new PropName(667, "3d.extrusioncolor"),
new PropName(648, "3d.crmod"),
new PropName(700, "3d.3deffect"),
new PropName(701, "3d.metallic"),
new PropName(702, "3d.useextrusioncolor"),
new PropName(703, "3d.lightface"),
new PropName(704, "3dstyle.yrotationangle"),
new PropName(705, "3dstyle.xrotationangle"),
new PropName(706, "3dstyle.rotationaxisx"),
new PropName(707, "3dstyle.rotationaxisy"),
new PropName(708, "3dstyle.rotationaxisz"),
new PropName(709, "3dstyle.rotationangle"),
new PropName(710, "3dstyle.rotationcenterx"),
new PropName(711, "3dstyle.rotationcentery"),
new PropName(712, "3dstyle.rotationcenterz"),
new PropName(713, "3dstyle.rendermode"),
new PropName(714, "3dstyle.tolerance"),
new PropName(715, "3dstyle.xviewpoint"),
new PropName(716, "3dstyle.yviewpoint"),
new PropName(717, "3dstyle.zviewpoint"),
new PropName(718, "3dstyle.originx"),
new PropName(719, "3dstyle.originy"),
new PropName(720, "3dstyle.skewangle"),
new PropName(721, "3dstyle.skewamount"),
new PropName(722, "3dstyle.ambientintensity"),
new PropName(723, "3dstyle.keyx"),
new PropName(724, "3dstyle.keyy"),
new PropName(725, "3dstyle.keyz"),
new PropName(726, "3dstyle.keyintensity"),
new PropName(727, "3dstyle.fillx"),
new PropName(728, "3dstyle.filly"),
new PropName(729, "3dstyle.fillz"),
new PropName(730, "3dstyle.fillintensity"),
new PropName(763, "3dstyle.constrainrotation"),
new PropName(764, "3dstyle.rotationcenterauto"),
new PropName(765, "3dstyle.parallel"),
new PropName(766, "3dstyle.keyharsh"),
new PropName(767, "3dstyle.fillharsh"),
new PropName(769, "shape.master"),
new PropName(771, "shape.connectorstyle"),
new PropName(772, "shape.blackandwhitesettings"),
new PropName(773, "shape.wmodepurebw"),
new PropName(774, "shape.wmodebw"),
new PropName(826, "shape.oleicon"),
new PropName(827, "shape.preferrelativeresize"),
new PropName(828, "shape.lockshapetype"),
new PropName(830, "shape.deleteattachedobject"),
new PropName(831, "shape.backgroundshape"),
new PropName(832, "callout.callouttype"),
new PropName(833, "callout.xycalloutgap"),
new PropName(834, "callout.calloutangle"),
new PropName(835, "callout.calloutdroptype"),
new PropName(836, "callout.calloutdropspecified"),
new PropName(837, "callout.calloutlengthspecified"),
new PropName(889, "callout.iscallout"),
new PropName(890, "callout.calloutaccentbar"),
new PropName(891, "callout.callouttextborder"),
new PropName(892, "callout.calloutminusx"),
new PropName(893, "callout.calloutminusy"),
new PropName(894, "callout.dropauto"),
new PropName(895, "callout.lengthspecified"),
new PropName(896, "groupshape.shapename"),
new PropName(897, "groupshape.description"),
new PropName(898, "groupshape.hyperlink"),
new PropName(899, "groupshape.wrappolygonvertices"),
new PropName(900, "groupshape.wrapdistleft"),
new PropName(901, "groupshape.wrapdisttop"),
new PropName(902, "groupshape.wrapdistright"),
new PropName(903, "groupshape.wrapdistbottom"),
new PropName(904, "groupshape.regroupid"),
new PropName(953, "groupshape.editedwrap"),
new PropName(954, "groupshape.behinddocument"),
new PropName(955, "groupshape.ondblclicknotify"),
new PropName(956, "groupshape.isbutton"),
new PropName(957, "groupshape.1dadjustment"),
new PropName(958, "groupshape.hidden"),
new PropName(959, "groupshape.print"),
};
for (int i = 0; i < props.length; i++) {
if (props[i]._id == propertyId) {
return props[i]._name;
}
}
return "unknown property";
}
/**
* Returns the blip description given a blip id.
*
* @param b blip id
* @return A description.
*/
private static String getBlipType(byte b) {
return EscherBSERecord.getBlipType(b);
}
/**
* Straight conversion from OO. Converts a type of float.
*/
private String dec1616( int n32 )
{
String result = "";
result += (short) ( n32 >> 16 );
result += '.';
result += (short) ( n32 & 0xFFFF );
return result;
}
/**
* Dumps out a hex value by reading from a input stream.
*
* @param bytes How many bytes this hex value consists of.
* @param in The stream to read the hex value from.
* @param out The stream to write the nicely formatted hex value to.
*/
private void outHex( int bytes, InputStream in, PrintStream out ) throws IOException, LittleEndian.BufferUnderrunException
{
switch ( bytes )
{
case 1:
out.print( HexDump.toHex( (byte) in.read() ) );
break;
case 2:
out.print( HexDump.toHex( LittleEndian.readShort( in ) ) );
break;
case 4:
out.print( HexDump.toHex( LittleEndian.readInt( in ) ) );
break;
default:
throw new IOException( "Unable to output variable of that width" );
}
}
/**
* A simple test stub.
*
* @param args the args
*/
public static void main( String[] args ) {
main(args, System.out);
}
public static void main( String[] args, PrintStream out ) {
String dump =
"0F 00 00 F0 89 07 00 00 00 00 06 F0 18 00 00 00 " +
"05 04 00 00 02 00 00 00 05 00 00 00 01 00 00 00 " +
"01 00 00 00 05 00 00 00 4F 00 01 F0 2F 07 00 00 " +
"42 00 07 F0 B7 01 00 00 03 04 3F 14 AE 6B 0F 65 " +
"B0 48 BF 5E 94 63 80 E8 91 73 FF 00 93 01 00 00 " +
"01 00 00 00 00 00 00 00 00 00 FF FF 20 54 1C F0 " +
"8B 01 00 00 3F 14 AE 6B 0F 65 B0 48 BF 5E 94 63 " +
"80 E8 91 73 92 0E 00 00 00 00 00 00 00 00 00 00 " +
"D1 07 00 00 DD 05 00 00 4A AD 6F 00 8A C5 53 00 " +
"59 01 00 00 00 FE 78 9C E3 9B C4 00 04 AC 77 D9 " +
"2F 32 08 32 FD E7 61 F8 FF 0F C8 FD 05 C5 30 19 " +
"10 90 63 90 FA 0F 06 0C 8C 0C 5C 70 19 43 30 EB " +
"0E FB 05 86 85 0C DB 18 58 80 72 8C 70 16 0B 83 " +
"05 56 51 29 88 C9 60 D9 69 0C 6C 20 26 23 03 C8 " +
"74 B0 A8 0E 03 07 FB 45 56 C7 A2 CC C4 1C 06 66 " +
"A0 0D 2C 40 39 5E 86 4C 06 3D A0 4E 10 D0 60 D9 " +
"C8 58 CC E8 CF B0 80 61 3A 8A 7E 0D C6 23 AC 4F " +
"E0 E2 98 B6 12 2B 06 73 9D 12 E3 52 56 59 F6 08 " +
"8A CC 52 66 A3 50 FF 96 2B 94 E9 DF 4C A1 FE 2D " +
"3A 03 AB 9F 81 C2 F0 A3 54 BF 0F 85 EE A7 54 FF " +
"40 FB 7F A0 E3 9F D2 F4 4F 71 FE 19 58 FF 2B 31 " +
"7F 67 36 3B 25 4F 99 1B 4E 53 A6 5F 89 25 95 E9 " +
"C4 00 C7 83 12 F3 1F 26 35 4A D3 D2 47 0E 0A C3 " +
"41 8E C9 8A 52 37 DC 15 A1 D0 0D BC 4C 06 0C 2B " +
"28 2C 13 28 D4 EF 43 61 5A A0 58 3F 85 71 E0 4B " +
"69 9E 64 65 FE 39 C0 E5 22 30 1D 30 27 0E 74 3A " +
"18 60 FD 4A CC B1 2C 13 7D 07 36 2D 2A 31 85 B2 " +
"6A 0D 74 1D 1D 22 4D 99 FE 60 0A F5 9B EC 1C 58 " +
"FD 67 06 56 3F 38 0D 84 3C A5 30 0E 28 D3 AF C4 " +
"A4 CA FA 44 7A 0D 65 6E 60 7F 4D A1 1B 24 58 F7 " +
"49 AF A5 CC 0D CC DF 19 FE 03 00 F0 B1 25 4D 42 " +
"00 07 F0 E1 01 00 00 03 04 39 50 BE 98 B0 6F 57 " +
"24 31 70 5D 23 2F 9F 10 66 FF 00 BD 01 00 00 01 " +
"00 00 00 00 00 00 00 00 00 FF FF 20 54 1C F0 B5 " +
"01 00 00 39 50 BE 98 B0 6F 57 24 31 70 5D 23 2F " +
"9F 10 66 DA 03 00 00 00 00 00 00 00 00 00 00 D1 " +
"07 00 00 DD 05 00 00 4A AD 6F 00 8A C5 53 00 83 " +
"01 00 00 00 FE 78 9C A5 52 BF 4B 42 51 14 3E F7 " +
"DC 77 7A 16 45 48 8B 3C 48 A8 16 15 0D 6C 88 D0 " +
"04 C3 40 A3 32 1C 84 96 08 21 04 A1 C5 5C A2 35 " +
"82 C0 35 6A AB 1C 6A 6B A8 24 5A 83 68 08 84 84 " +
"96 A2 86 A0 7F C2 86 5E E7 5E F5 41 E4 10 BC 03 " +
"1F E7 FB F1 CE B9 F7 F1 9E 7C 05 2E 7A 37 9B E0 " +
"45 7B 10 EC 6F 96 5F 1D 74 13 55 7E B0 6C 5D 20 " +
"60 C0 49 A2 9A BD 99 4F 50 83 1B 30 38 13 0E 33 " +
"60 A6 A7 6B B5 37 EB F4 10 FA 14 15 A0 B6 6B 37 " +
"0C 1E B3 49 73 5B A5 C2 26 48 3E C1 E0 6C 08 4A " +
"30 C9 93 AA 02 B8 20 13 62 05 4E E1 E8 D7 7C C0 " +
"B8 14 95 5E BE B8 A7 CF 1E BE 55 2C 56 B9 78 DF " +
"08 7E 88 4C 27 FF 7B DB FF 7A DD B7 1A 17 67 34 " +
"6A AE BA DA 35 D1 E7 72 BE FE EC 6E FE DA E5 7C " +
"3D EC 7A DE 03 FD 50 06 0B 23 F2 0E F3 B2 A5 11 " +
"91 0D 4C B5 B5 F3 BF 94 C1 8F 24 F7 D9 6F 60 94 " +
"3B C9 9A F3 1C 6B E7 BB F0 2E 49 B2 25 2B C6 B1 " +
"EE 69 EE 15 63 4F 71 7D CE 85 CC C8 35 B9 C3 28 " +
"28 CE D0 5C 67 79 F2 4A A2 14 23 A4 38 43 73 9D " +
"2D 69 2F C1 08 31 9F C5 5C 9B EB 7B C5 69 19 B3 " +
"B4 81 F3 DC E3 B4 8E 8B CC B3 94 53 5A E7 41 2A " +
"63 9A AA 38 C5 3D 48 BB EC 57 59 6F 2B AD 73 1F " +
"1D 60 92 AE 70 8C BB 8F CE 31 C1 3C 49 27 4A EB " +
"DC A4 5B 8C D1 0B 0E 73 37 E9 11 A7 99 C7 E8 41 " +
"69 B0 7F 00 96 F2 A7 E8 42 00 07 F0 B4 01 00 00 " +
"03 04 1A BA F9 D6 A9 B9 3A 03 08 61 E9 90 FF 7B " +
"9E E6 FF 00 90 01 00 00 01 00 00 00 00 00 00 00 " +
"00 00 FF FF 20 54 1C F0 88 01 00 00 1A BA F9 D6 " +
"A9 B9 3A 03 08 61 E9 90 FF 7B 9E E6 12 0E 00 00 " +
"00 00 00 00 00 00 00 00 D1 07 00 00 DD 05 00 00 " +
"4A AD 6F 00 8A C5 53 00 56 01 00 00 00 FE 78 9C " +
"E3 13 62 00 02 D6 BB EC 17 19 04 99 FE F3 30 FC " +
"FF 07 E4 FE 82 62 98 0C 08 C8 31 48 FD 07 03 06 " +
"46 06 2E B8 8C 21 98 75 87 FD 02 C3 42 86 6D 0C " +
"2C 40 39 46 38 8B 85 C1 02 AB A8 14 C4 64 B0 EC " +
"34 06 36 10 93 91 01 64 3A 58 54 87 81 83 FD 22 " +
"AB 63 51 66 62 0E 03 33 D0 06 16 A0 1C 2F 43 26 " +
"83 1E 50 27 08 68 B0 6C 64 2C 66 F4 67 58 C0 30 " +
"1D 45 BF 06 E3 11 D6 27 70 71 4C 5B 89 15 83 B9 " +
"4E 89 71 29 AB 2C 7B 04 45 66 29 B3 51 A8 7F CB " +
"15 CA F4 6F A6 50 FF 16 9D 81 D5 CF 40 61 F8 51 " +
"AA DF 87 42 F7 53 AA 7F A0 FD 3F D0 F1 4F 69 FA " +
"A7 38 FF 0C AC FF 95 98 BF 33 9B 9D 92 A7 CC 0D " +
"A7 29 D3 AF C4 92 CA 74 62 80 E3 41 89 F9 0F 93 " +
"1A A5 69 E9 23 07 85 E1 20 C7 64 45 A9 1B EE 8A " +
"50 E8 06 5E 26 03 86 15 14 96 09 14 EA F7 A1 30 " +
"2D 50 AC 9F C2 38 F0 A5 34 4F B2 32 FF 1C E0 72 " +
"11 98 0E 98 13 07 38 1D 28 31 C7 B2 4C F4 1D D8 " +
"B4 A0 C4 14 CA AA 35 D0 75 64 88 34 65 FA 83 29 " +
"D4 6F B2 73 60 F5 9F A1 54 FF 0E CA D3 40 C8 53 " +
"0A E3 E0 09 85 6E 50 65 7D 22 BD 86 32 37 B0 BF " +
"A6 D0 0D 12 AC FB A4 D7 52 E6 06 E6 EF 0C FF 01 " +
"97 1D 12 C7 42 00 07 F0 C3 01 00 00 03 04 BA 4C " +
"B6 23 BA 8B 27 BE C8 55 59 86 24 9F 89 D4 FF 00 " +
"9F 01 00 00 01 00 00 00 00 00 00 00 00 00 FF FF " +
"20 54 1C F0 97 01 00 00 BA 4C B6 23 BA 8B 27 BE " +
"C8 55 59 86 24 9F 89 D4 AE 0E 00 00 00 00 00 00 " +
"00 00 00 00 D1 07 00 00 DD 05 00 00 4A AD 6F 00 " +
"8A C5 53 00 65 01 00 00 00 FE 78 9C E3 5B C7 00 " +
"04 AC 77 D9 2F 32 08 32 FD E7 61 F8 FF 0F C8 FD " +
"05 C5 30 19 10 90 63 90 FA 0F 06 0C 8C 0C 5C 70 " +
"19 43 30 EB 0E FB 05 86 85 0C DB 18 58 80 72 8C " +
"70 16 0B 83 05 56 51 29 88 C9 60 D9 69 0C 6C 20 " +
"26 23 03 C8 74 B0 A8 0E 03 07 FB 45 56 C7 A2 CC " +
"C4 1C 06 66 A0 0D 2C 40 39 5E 86 4C 06 3D A0 4E " +
"10 D0 60 99 C6 B8 98 D1 9F 61 01 C3 74 14 FD 1A " +
"8C 2B D8 84 B1 88 4B A5 A5 75 03 01 50 DF 59 46 " +
"77 46 0F A8 3C A6 AB 88 15 83 B9 5E 89 B1 8B D5 " +
"97 2D 82 22 B3 94 29 D5 BF E5 CA C0 EA DF AC 43 " +
"A1 FD 14 EA 67 A0 30 FC 28 D5 EF 43 A1 FB 7D 87 " +
"B8 FF 07 3A FE 07 3A FD 53 EA 7E 0A C3 4F 89 F9 " +
"0E 73 EA 69 79 CA DC 70 8A 32 FD 4A 2C 5E 4C DF " +
"87 7A 3C BC E0 A5 30 1E 3E 31 C5 33 AC A0 30 2F " +
"52 A8 DF 87 C2 30 A4 54 3F A5 65 19 85 65 A9 12 " +
"D3 2B 16 0D 8A CB 13 4A F3 E3 27 E6 09 03 9D 0E " +
"06 58 BF 12 B3 13 CB C1 01 4E 8B 4A 4C 56 AC 91 " +
"03 5D 37 86 48 53 A6 3F 98 42 FD 26 3B 07 56 FF " +
"99 1D 14 EA A7 CC 7E 70 1A 08 79 42 61 1C 3C A5 " +
"D0 0D 9C 6C C2 32 6B 29 73 03 DB 6B CA DC C0 F8 " +
"97 F5 AD CC 1A CA DC C0 F4 83 32 37 B0 A4 30 CE " +
"FC C7 48 99 1B FE 33 32 FC 07 00 6C CC 2E 23 33 " +
"00 0B F0 12 00 00 00 BF 00 08 00 08 00 81 01 09 " +
"00 00 08 C0 01 40 00 00 08 40 00 1E F1 10 00 00 " +
"00 0D 00 00 08 0C 00 00 08 17 00 00 08 F7 00 00 " +
"10 ";
// Decode the stream to bytes
byte[] bytes = HexRead.readFromString(dump);
// Create a new instance of the escher dumper
EscherDump dumper = new EscherDump();
// Dump the contents of scher to screen.
// dumper.dumpOld( bytes.length, new ByteArrayInputStream( bytes ), System.out );
dumper.dump(bytes, 0, bytes.length, out);
}
public void dump( int recordSize, byte[] data, PrintStream out ) { public void dump( int recordSize, byte[] data, PrintStream out ) {
dump( data, 0, recordSize, out ); dump( data, 0, recordSize, out );

View File

@ -386,22 +386,6 @@ public final class EscherMetafileBlip extends EscherBlipRecord {
setCompressed(true); setCompressed(true);
} }
@Override
protected Object[][] getAttributeMap() {
return new Object[][]{
// record, version, instance are directly fetched
{ "UID", field_1_UID, "UID2", field_2_UID },
{ "Uncompressed Size", field_2_cb },
{ "Bounds", getBounds().toString() },
{ "Size in EMU", getSizeEMU().toString() },
{ "Compressed Size", field_5_cbSave },
{ "Compression", field_6_fCompression },
{ "Filter", field_7_fFilter },
{ "Extra Data", "" },
{ "Remaining Data", remainingData }
};
}
@Override @Override
public Map<String, Supplier<?>> getGenericProperties() { public Map<String, Supplier<?>> getGenericProperties() {
final Map<String, Supplier<?>> m = new LinkedHashMap<>(super.getGenericProperties()); final Map<String, Supplier<?>> m = new LinkedHashMap<>(super.getGenericProperties());

View File

@ -284,20 +284,6 @@ public final class EscherPictBlip extends EscherBlipRecord {
field_7_fFilter = filter; field_7_fFilter = filter;
} }
@Override
protected Object[][] getAttributeMap() {
return new Object[][]{
{ "UID", field_1_UID },
{ "Uncompressed Size", field_2_cb },
{ "Bounds", getBounds().toString() },
{ "Size in EMU", getSizeEMU().toString() },
{ "Compressed Size", field_5_cbSave },
{ "Compression", field_6_fCompression },
{ "Filter", field_7_fFilter },
{ "Extra Data", getPicturedata() },
};
}
@Override @Override
public Map<String, Supplier<?>> getGenericProperties() { public Map<String, Supplier<?>> getGenericProperties() {
final Map<String, Supplier<?>> m = new LinkedHashMap<>(super.getGenericProperties()); final Map<String, Supplier<?>> m = new LinkedHashMap<>(super.getGenericProperties());

View File

@ -17,666 +17,334 @@
package org.apache.poi.ddf; package org.apache.poi.ddf;
import java.util.HashMap; import org.apache.poi.util.Removal;
import java.util.Map;
/** /**
* Provides a list of all known escher properties including the description and * Provides a list of all known escher properties including the description and type.
* type.
* *
* @author Glen Stampoultzis (glens at apache.org) * @deprecated use {@link EscherPropertyTypes} enum instead
*/ */
@SuppressWarnings("WeakerAccess") @SuppressWarnings({"unused"})
public final class EscherProperties { @Deprecated
@Removal(version = "5.0.0")
public interface EscherProperties {
short TRANSFORM__ROTATION = EscherPropertyTypes.TRANSFORM__ROTATION.propNumber;
short PROTECTION__LOCKROTATION = EscherPropertyTypes.PROTECTION__LOCKROTATION.propNumber;
short PROTECTION__LOCKASPECTRATIO = EscherPropertyTypes.PROTECTION__LOCKASPECTRATIO.propNumber;
short PROTECTION__LOCKPOSITION = EscherPropertyTypes.PROTECTION__LOCKPOSITION.propNumber;
short PROTECTION__LOCKAGAINSTSELECT = EscherPropertyTypes.PROTECTION__LOCKAGAINSTSELECT.propNumber;
short PROTECTION__LOCKCROPPING = EscherPropertyTypes.PROTECTION__LOCKCROPPING.propNumber;
short PROTECTION__LOCKVERTICES = EscherPropertyTypes.PROTECTION__LOCKVERTICES.propNumber;
short PROTECTION__LOCKTEXT = EscherPropertyTypes.PROTECTION__LOCKTEXT.propNumber;
short PROTECTION__LOCKADJUSTHANDLES = EscherPropertyTypes.PROTECTION__LOCKADJUSTHANDLES.propNumber;
short PROTECTION__LOCKAGAINSTGROUPING = EscherPropertyTypes.PROTECTION__LOCKAGAINSTGROUPING.propNumber;
short TEXT__TEXTID = EscherPropertyTypes.TEXT__TEXTID.propNumber;
short TEXT__TEXTLEFT = EscherPropertyTypes.TEXT__TEXTLEFT.propNumber;
short TEXT__TEXTTOP = EscherPropertyTypes.TEXT__TEXTTOP.propNumber;
short TEXT__TEXTRIGHT = EscherPropertyTypes.TEXT__TEXTRIGHT.propNumber;
short TEXT__TEXTBOTTOM = EscherPropertyTypes.TEXT__TEXTBOTTOM.propNumber;
short TEXT__WRAPTEXT = EscherPropertyTypes.TEXT__WRAPTEXT.propNumber;
short TEXT__SCALETEXT = EscherPropertyTypes.TEXT__SCALETEXT.propNumber;
short TEXT__ANCHORTEXT = EscherPropertyTypes.TEXT__ANCHORTEXT.propNumber;
short TEXT__TEXTFLOW = EscherPropertyTypes.TEXT__TEXTFLOW.propNumber;
short TEXT__FONTROTATION = EscherPropertyTypes.TEXT__FONTROTATION.propNumber;
short TEXT__IDOFNEXTSHAPE = EscherPropertyTypes.TEXT__IDOFNEXTSHAPE.propNumber;
short TEXT__BIDIR = EscherPropertyTypes.TEXT__BIDIR.propNumber;
short TEXT__SINGLECLICKSELECTS = EscherPropertyTypes.TEXT__SINGLECLICKSELECTS.propNumber;
short TEXT__USEHOSTMARGINS = EscherPropertyTypes.TEXT__USEHOSTMARGINS.propNumber;
short TEXT__ROTATETEXTWITHSHAPE = EscherPropertyTypes.TEXT__ROTATETEXTWITHSHAPE.propNumber;
short TEXT__SIZESHAPETOFITTEXT = EscherPropertyTypes.TEXT__SIZESHAPETOFITTEXT.propNumber;
short TEXT__SIZE_TEXT_TO_FIT_SHAPE = EscherPropertyTypes.TEXT__SIZE_TEXT_TO_FIT_SHAPE.propNumber;
short GEOTEXT__UNICODE = EscherPropertyTypes.GEOTEXT__UNICODE.propNumber;
short GEOTEXT__RTFTEXT = EscherPropertyTypes.GEOTEXT__RTFTEXT.propNumber;
short GEOTEXT__ALIGNMENTONCURVE = EscherPropertyTypes.GEOTEXT__ALIGNMENTONCURVE.propNumber;
short GEOTEXT__DEFAULTPOINTSIZE = EscherPropertyTypes.GEOTEXT__DEFAULTPOINTSIZE.propNumber;
short GEOTEXT__TEXTSPACING = EscherPropertyTypes.GEOTEXT__TEXTSPACING.propNumber;
short GEOTEXT__FONTFAMILYNAME = EscherPropertyTypes.GEOTEXT__FONTFAMILYNAME.propNumber;
short GEOTEXT__REVERSEROWORDER = EscherPropertyTypes.GEOTEXT__REVERSEROWORDER.propNumber;
short GEOTEXT__HASTEXTEFFECT = EscherPropertyTypes.GEOTEXT__HASTEXTEFFECT.propNumber;
short GEOTEXT__ROTATECHARACTERS = EscherPropertyTypes.GEOTEXT__ROTATECHARACTERS.propNumber;
short GEOTEXT__KERNCHARACTERS = EscherPropertyTypes.GEOTEXT__KERNCHARACTERS.propNumber;
short GEOTEXT__TIGHTORTRACK = EscherPropertyTypes.GEOTEXT__TIGHTORTRACK.propNumber;
short GEOTEXT__STRETCHTOFITSHAPE = EscherPropertyTypes.GEOTEXT__STRETCHTOFITSHAPE.propNumber;
short GEOTEXT__CHARBOUNDINGBOX = EscherPropertyTypes.GEOTEXT__CHARBOUNDINGBOX.propNumber;
short GEOTEXT__SCALETEXTONPATH = EscherPropertyTypes.GEOTEXT__SCALETEXTONPATH.propNumber;
short GEOTEXT__STRETCHCHARHEIGHT = EscherPropertyTypes.GEOTEXT__STRETCHCHARHEIGHT.propNumber;
short GEOTEXT__NOMEASUREALONGPATH = EscherPropertyTypes.GEOTEXT__NOMEASUREALONGPATH.propNumber;
short GEOTEXT__BOLDFONT = EscherPropertyTypes.GEOTEXT__BOLDFONT.propNumber;
short GEOTEXT__ITALICFONT = EscherPropertyTypes.GEOTEXT__ITALICFONT.propNumber;
short GEOTEXT__UNDERLINEFONT = EscherPropertyTypes.GEOTEXT__UNDERLINEFONT.propNumber;
short GEOTEXT__SHADOWFONT = EscherPropertyTypes.GEOTEXT__SHADOWFONT.propNumber;
short GEOTEXT__SMALLCAPSFONT = EscherPropertyTypes.GEOTEXT__SMALLCAPSFONT.propNumber;
short GEOTEXT__STRIKETHROUGHFONT = EscherPropertyTypes.GEOTEXT__STRIKETHROUGHFONT.propNumber;
short BLIP__CROPFROMTOP = EscherPropertyTypes.BLIP__CROPFROMTOP.propNumber;
short BLIP__CROPFROMBOTTOM = EscherPropertyTypes.BLIP__CROPFROMBOTTOM.propNumber;
short BLIP__CROPFROMLEFT = EscherPropertyTypes.BLIP__CROPFROMLEFT.propNumber;
short BLIP__CROPFROMRIGHT = EscherPropertyTypes.BLIP__CROPFROMRIGHT.propNumber;
short BLIP__BLIPTODISPLAY = EscherPropertyTypes.BLIP__BLIPTODISPLAY.propNumber;
short BLIP__BLIPFILENAME = EscherPropertyTypes.BLIP__BLIPFILENAME.propNumber;
short BLIP__BLIPFLAGS = EscherPropertyTypes.BLIP__BLIPFLAGS.propNumber;
short BLIP__TRANSPARENTCOLOR = EscherPropertyTypes.BLIP__TRANSPARENTCOLOR.propNumber;
short BLIP__CONTRASTSETTING = EscherPropertyTypes.BLIP__CONTRASTSETTING.propNumber;
short BLIP__BRIGHTNESSSETTING = EscherPropertyTypes.BLIP__BRIGHTNESSSETTING.propNumber;
short BLIP__GAMMA = EscherPropertyTypes.BLIP__GAMMA.propNumber;
short BLIP__PICTUREID = EscherPropertyTypes.BLIP__PICTUREID.propNumber;
short BLIP__DOUBLEMOD = EscherPropertyTypes.BLIP__DOUBLEMOD.propNumber;
short BLIP__PICTUREFILLMOD = EscherPropertyTypes.BLIP__PICTUREFILLMOD.propNumber;
short BLIP__PICTURELINE = EscherPropertyTypes.BLIP__PICTURELINE.propNumber;
short BLIP__PRINTBLIP = EscherPropertyTypes.BLIP__PRINTBLIP.propNumber;
short BLIP__PRINTBLIPFILENAME = EscherPropertyTypes.BLIP__PRINTBLIPFILENAME.propNumber;
short BLIP__PRINTFLAGS = EscherPropertyTypes.BLIP__PRINTFLAGS.propNumber;
short BLIP__NOHITTESTPICTURE = EscherPropertyTypes.BLIP__NOHITTESTPICTURE.propNumber;
short BLIP__PICTUREGRAY = EscherPropertyTypes.BLIP__PICTUREGRAY.propNumber;
short BLIP__PICTUREBILEVEL = EscherPropertyTypes.BLIP__PICTUREBILEVEL.propNumber;
short BLIP__PICTUREACTIVE = EscherPropertyTypes.BLIP__PICTUREACTIVE.propNumber;
short GEOMETRY__LEFT = EscherPropertyTypes.GEOMETRY__LEFT.propNumber;
short GEOMETRY__TOP = EscherPropertyTypes.GEOMETRY__TOP.propNumber;
short GEOMETRY__RIGHT = EscherPropertyTypes.GEOMETRY__RIGHT.propNumber;
short GEOMETRY__BOTTOM = EscherPropertyTypes.GEOMETRY__BOTTOM.propNumber;
short GEOMETRY__SHAPEPATH = EscherPropertyTypes.GEOMETRY__SHAPEPATH.propNumber;
short GEOMETRY__VERTICES = EscherPropertyTypes.GEOMETRY__VERTICES.propNumber;
short GEOMETRY__SEGMENTINFO = EscherPropertyTypes.GEOMETRY__SEGMENTINFO.propNumber;
short GEOMETRY__ADJUSTVALUE = EscherPropertyTypes.GEOMETRY__ADJUSTVALUE.propNumber;
short GEOMETRY__ADJUST2VALUE = EscherPropertyTypes.GEOMETRY__ADJUST2VALUE.propNumber;
short GEOMETRY__ADJUST3VALUE = EscherPropertyTypes.GEOMETRY__ADJUST3VALUE.propNumber;
short GEOMETRY__ADJUST4VALUE = EscherPropertyTypes.GEOMETRY__ADJUST4VALUE.propNumber;
short GEOMETRY__ADJUST5VALUE = EscherPropertyTypes.GEOMETRY__ADJUST5VALUE.propNumber;
short GEOMETRY__ADJUST6VALUE = EscherPropertyTypes.GEOMETRY__ADJUST6VALUE.propNumber;
short GEOMETRY__ADJUST7VALUE = EscherPropertyTypes.GEOMETRY__ADJUST7VALUE.propNumber;
short GEOMETRY__ADJUST8VALUE = EscherPropertyTypes.GEOMETRY__ADJUST8VALUE.propNumber;
short GEOMETRY__ADJUST9VALUE = EscherPropertyTypes.GEOMETRY__ADJUST9VALUE.propNumber;
short GEOMETRY__ADJUST10VALUE = EscherPropertyTypes.GEOMETRY__ADJUST10VALUE.propNumber;
short GEOMETRY__PCONNECTIONSITES = EscherPropertyTypes.GEOMETRY__PCONNECTIONSITES.propNumber;
short GEOMETRY__PCONNECTIONSITESDIR = EscherPropertyTypes.GEOMETRY__PCONNECTIONSITESDIR.propNumber;
short GEOMETRY__XLIMO = EscherPropertyTypes.GEOMETRY__XLIMO.propNumber;
short GEOMETRY__YLIMO = EscherPropertyTypes.GEOMETRY__YLIMO.propNumber;
short GEOMETRY__PADJUSTHANDLES = EscherPropertyTypes.GEOMETRY__PADJUSTHANDLES.propNumber;
short GEOMETRY__PGUIDES = EscherPropertyTypes.GEOMETRY__PGUIDES.propNumber;
short GEOMETRY__PINSCRIBE = EscherPropertyTypes.GEOMETRY__PINSCRIBE.propNumber;
short GEOMETRY__CXK = EscherPropertyTypes.GEOMETRY__CXK.propNumber;
short GEOMETRY__PFRAGMENTS = EscherPropertyTypes.GEOMETRY__PFRAGMENTS.propNumber;
short GEOMETRY__SHADOWok = EscherPropertyTypes.GEOMETRY__SHADOWOK.propNumber;
short GEOMETRY__3DOK = EscherPropertyTypes.GEOMETRY__3DOK.propNumber;
short GEOMETRY__LINEOK = EscherPropertyTypes.GEOMETRY__LINEOK.propNumber;
short GEOMETRY__GEOTEXTOK = EscherPropertyTypes.GEOMETRY__GEOTEXTOK.propNumber;
short GEOMETRY__FILLSHADESHAPEOK = EscherPropertyTypes.GEOMETRY__FILLSHADESHAPEOK.propNumber;
short GEOMETRY__FILLOK = EscherPropertyTypes.GEOMETRY__FILLOK.propNumber;
short FILL__FILLTYPE = EscherPropertyTypes.FILL__FILLTYPE.propNumber;
short FILL__FILLCOLOR = EscherPropertyTypes.FILL__FILLCOLOR.propNumber;
short FILL__FILLOPACITY = EscherPropertyTypes.FILL__FILLOPACITY.propNumber;
short FILL__FILLBACKCOLOR = EscherPropertyTypes.FILL__FILLBACKCOLOR.propNumber;
short FILL__BACKOPACITY = EscherPropertyTypes.FILL__BACKOPACITY.propNumber;
short FILL__CRMOD = EscherPropertyTypes.FILL__CRMOD.propNumber;
short FILL__PATTERNTEXTURE = EscherPropertyTypes.FILL__PATTERNTEXTURE.propNumber;
short FILL__BLIPFILENAME = EscherPropertyTypes.FILL__BLIPFILENAME.propNumber;
short FILL__BLIPFLAGS = EscherPropertyTypes.FILL__BLIPFLAGS.propNumber;
short FILL__WIDTH = EscherPropertyTypes.FILL__WIDTH.propNumber;
short FILL__HEIGHT = EscherPropertyTypes.FILL__HEIGHT.propNumber;
short FILL__ANGLE = EscherPropertyTypes.FILL__ANGLE.propNumber;
short FILL__FOCUS = EscherPropertyTypes.FILL__FOCUS.propNumber;
short FILL__TOLEFT = EscherPropertyTypes.FILL__TOLEFT.propNumber;
short FILL__TOTOP = EscherPropertyTypes.FILL__TOTOP.propNumber;
short FILL__TORIGHT = EscherPropertyTypes.FILL__TORIGHT.propNumber;
short FILL__TOBOTTOM = EscherPropertyTypes.FILL__TOBOTTOM.propNumber;
short FILL__RECTLEFT = EscherPropertyTypes.FILL__RECTLEFT.propNumber;
short FILL__RECTTOP = EscherPropertyTypes.FILL__RECTTOP.propNumber;
short FILL__RECTRIGHT = EscherPropertyTypes.FILL__RECTRIGHT.propNumber;
short FILL__RECTBOTTOM = EscherPropertyTypes.FILL__RECTBOTTOM.propNumber;
short FILL__DZTYPE = EscherPropertyTypes.FILL__DZTYPE.propNumber;
short FILL__SHADEPRESET = EscherPropertyTypes.FILL__SHADEPRESET.propNumber;
short FILL__SHADECOLORS = EscherPropertyTypes.FILL__SHADECOLORS.propNumber;
short FILL__ORIGINX = EscherPropertyTypes.FILL__ORIGINX.propNumber;
short FILL__ORIGINY = EscherPropertyTypes.FILL__ORIGINY.propNumber;
short FILL__SHAPEORIGINX = EscherPropertyTypes.FILL__SHAPEORIGINX.propNumber;
short FILL__SHAPEORIGINY = EscherPropertyTypes.FILL__SHAPEORIGINY.propNumber;
short FILL__SHADETYPE = EscherPropertyTypes.FILL__SHADETYPE.propNumber;
short FILL__FILLED = EscherPropertyTypes.FILL__FILLED.propNumber;
short FILL__HITTESTFILL = EscherPropertyTypes.FILL__HITTESTFILL.propNumber;
short FILL__SHAPE = EscherPropertyTypes.FILL__SHAPE.propNumber;
short FILL__USERECT = EscherPropertyTypes.FILL__USERECT.propNumber;
short FILL__NOFILLHITTEST = EscherPropertyTypes.FILL__NOFILLHITTEST.propNumber;
short LINESTYLE__COLOR = EscherPropertyTypes.LINESTYLE__COLOR.propNumber;
short LINESTYLE__OPACITY = EscherPropertyTypes.LINESTYLE__OPACITY.propNumber;
short LINESTYLE__BACKCOLOR = EscherPropertyTypes.LINESTYLE__BACKCOLOR.propNumber;
short LINESTYLE__CRMOD = EscherPropertyTypes.LINESTYLE__CRMOD.propNumber;
short LINESTYLE__LINETYPE = EscherPropertyTypes.LINESTYLE__LINETYPE.propNumber;
short LINESTYLE__FILLBLIP = EscherPropertyTypes.LINESTYLE__FILLBLIP.propNumber;
short LINESTYLE__FILLBLIPNAME = EscherPropertyTypes.LINESTYLE__FILLBLIPNAME.propNumber;
short LINESTYLE__FILLBLIPFLAGS = EscherPropertyTypes.LINESTYLE__FILLBLIPFLAGS.propNumber;
short LINESTYLE__FILLWIDTH = EscherPropertyTypes.LINESTYLE__FILLWIDTH.propNumber;
short LINESTYLE__FILLHEIGHT = EscherPropertyTypes.LINESTYLE__FILLHEIGHT.propNumber;
short LINESTYLE__FILLDZTYPE = EscherPropertyTypes.LINESTYLE__FILLDZTYPE.propNumber;
short LINESTYLE__LINEWIDTH = EscherPropertyTypes.LINESTYLE__LINEWIDTH.propNumber;
short LINESTYLE__LINEMITERLIMIT = EscherPropertyTypes.LINESTYLE__LINEMITERLIMIT.propNumber;
short LINESTYLE__LINESTYLE = EscherPropertyTypes.LINESTYLE__LINESTYLE.propNumber;
short LINESTYLE__LINEDASHING = EscherPropertyTypes.LINESTYLE__LINEDASHING.propNumber;
short LINESTYLE__LINEDASHSTYLE = EscherPropertyTypes.LINESTYLE__LINEDASHSTYLE.propNumber;
short LINESTYLE__LINESTARTARROWHEAD = EscherPropertyTypes.LINESTYLE__LINESTARTARROWHEAD.propNumber;
short LINESTYLE__LINEENDARROWHEAD = EscherPropertyTypes.LINESTYLE__LINEENDARROWHEAD.propNumber;
short LINESTYLE__LINESTARTARROWWIDTH = EscherPropertyTypes.LINESTYLE__LINESTARTARROWWIDTH.propNumber;
short LINESTYLE__LINESTARTARROWLENGTH = EscherPropertyTypes.LINESTYLE__LINESTARTARROWLENGTH.propNumber;
short LINESTYLE__LINEENDARROWWIDTH = EscherPropertyTypes.LINESTYLE__LINEENDARROWWIDTH.propNumber;
short LINESTYLE__LINEENDARROWLENGTH = EscherPropertyTypes.LINESTYLE__LINEENDARROWLENGTH.propNumber;
short LINESTYLE__LINEJOINSTYLE = EscherPropertyTypes.LINESTYLE__LINEJOINSTYLE.propNumber;
short LINESTYLE__LINEENDCAPSTYLE = EscherPropertyTypes.LINESTYLE__LINEENDCAPSTYLE.propNumber;
short LINESTYLE__ARROWHEADSOK = EscherPropertyTypes.LINESTYLE__ARROWHEADSOK.propNumber;
short LINESTYLE__ANYLINE = EscherPropertyTypes.LINESTYLE__ANYLINE.propNumber;
short LINESTYLE__HITLINETEST = EscherPropertyTypes.LINESTYLE__HITLINETEST.propNumber;
short LINESTYLE__LINEFILLSHAPE = EscherPropertyTypes.LINESTYLE__LINEFILLSHAPE.propNumber;
short LINESTYLE__NOLINEDRAWDASH = EscherPropertyTypes.LINESTYLE__NOLINEDRAWDASH.propNumber;
short LINESTYLE__NOLINEDRAWDASH_LEFT = EscherPropertyTypes.LINESTYLE__NOLINEDRAWDASH_LEFT.propNumber;
short LINESTYLE__NOLINEDRAWDASH_TOP = EscherPropertyTypes.LINESTYLE__NOLINEDRAWDASH_TOP.propNumber;
short LINESTYLE__NOLINEDRAWDASH_BOTTOM = EscherPropertyTypes.LINESTYLE__NOLINEDRAWDASH_BOTTOM.propNumber;
short LINESTYLE__NOLINEDRAWDASH_RIGHT = EscherPropertyTypes.LINESTYLE__NOLINEDRAWDASH_RIGHT.propNumber;
short SHADOWSTYLE__TYPE = EscherPropertyTypes.SHADOWSTYLE__TYPE.propNumber;
short SHADOWSTYLE__COLOR = EscherPropertyTypes.SHADOWSTYLE__COLOR.propNumber;
short SHADOWSTYLE__HIGHLIGHT = EscherPropertyTypes.SHADOWSTYLE__HIGHLIGHT.propNumber;
short SHADOWSTYLE__CRMOD = EscherPropertyTypes.SHADOWSTYLE__CRMOD.propNumber;
short SHADOWSTYLE__OPACITY = EscherPropertyTypes.SHADOWSTYLE__OPACITY.propNumber;
short SHADOWSTYLE__OFFSETX = EscherPropertyTypes.SHADOWSTYLE__OFFSETX.propNumber;
short SHADOWSTYLE__OFFSETY = EscherPropertyTypes.SHADOWSTYLE__OFFSETY.propNumber;
short SHADOWSTYLE__SECONDOFFSETX = EscherPropertyTypes.SHADOWSTYLE__SECONDOFFSETX.propNumber;
short SHADOWSTYLE__SECONDOFFSETY = EscherPropertyTypes.SHADOWSTYLE__SECONDOFFSETY.propNumber;
short SHADOWSTYLE__SCALEXTOX = EscherPropertyTypes.SHADOWSTYLE__SCALEXTOX.propNumber;
short SHADOWSTYLE__SCALEYTOX = EscherPropertyTypes.SHADOWSTYLE__SCALEYTOX.propNumber;
short SHADOWSTYLE__SCALEXTOY = EscherPropertyTypes.SHADOWSTYLE__SCALEXTOY.propNumber;
short SHADOWSTYLE__SCALEYTOY = EscherPropertyTypes.SHADOWSTYLE__SCALEYTOY.propNumber;
short SHADOWSTYLE__PERSPECTIVEX = EscherPropertyTypes.SHADOWSTYLE__PERSPECTIVEX.propNumber;
short SHADOWSTYLE__PERSPECTIVEY = EscherPropertyTypes.SHADOWSTYLE__PERSPECTIVEY.propNumber;
short SHADOWSTYLE__WEIGHT = EscherPropertyTypes.SHADOWSTYLE__WEIGHT.propNumber;
short SHADOWSTYLE__ORIGINX = EscherPropertyTypes.SHADOWSTYLE__ORIGINX.propNumber;
short SHADOWSTYLE__ORIGINY = EscherPropertyTypes.SHADOWSTYLE__ORIGINY.propNumber;
short SHADOWSTYLE__SHADOW = EscherPropertyTypes.SHADOWSTYLE__SHADOW.propNumber;
short SHADOWSTYLE__SHADOWOBSURED = EscherPropertyTypes.SHADOWSTYLE__SHADOWOBSURED.propNumber;
short PERSPECTIVE__TYPE = EscherPropertyTypes.PERSPECTIVE__TYPE.propNumber;
short PERSPECTIVE__OFFSETX = EscherPropertyTypes.PERSPECTIVE__OFFSETX.propNumber;
short PERSPECTIVE__OFFSETY = EscherPropertyTypes.PERSPECTIVE__OFFSETY.propNumber;
short PERSPECTIVE__SCALEXTOX = EscherPropertyTypes.PERSPECTIVE__SCALEXTOX.propNumber;
short PERSPECTIVE__SCALEYTOX = EscherPropertyTypes.PERSPECTIVE__SCALEYTOX.propNumber;
short PERSPECTIVE__SCALEXTOY = EscherPropertyTypes.PERSPECTIVE__SCALEXTOY.propNumber;
short PERSPECTIVE__SCALEYTOY = EscherPropertyTypes.PERSPECTIVE__SCALEYTOY.propNumber;
short PERSPECTIVE__PERSPECTIVEX = EscherPropertyTypes.PERSPECTIVE__PERSPECTIVEX.propNumber;
short PERSPECTIVE__PERSPECTIVEY = EscherPropertyTypes.PERSPECTIVE__PERSPECTIVEY.propNumber;
short PERSPECTIVE__WEIGHT = EscherPropertyTypes.PERSPECTIVE__WEIGHT.propNumber;
short PERSPECTIVE__ORIGINX = EscherPropertyTypes.PERSPECTIVE__ORIGINX.propNumber;
short PERSPECTIVE__ORIGINY = EscherPropertyTypes.PERSPECTIVE__ORIGINY.propNumber;
short PERSPECTIVE__PERSPECTIVEON = EscherPropertyTypes.PERSPECTIVE__PERSPECTIVEON.propNumber;
short THREED__SPECULARAMOUNT = EscherPropertyTypes.THREED__SPECULARAMOUNT.propNumber;
short THREED__DIFFUSEAMOUNT = EscherPropertyTypes.THREED__DIFFUSEAMOUNT.propNumber;
short THREED__SHININESS = EscherPropertyTypes.THREED__SHININESS.propNumber;
short THREED__EDGETHICKNESS = EscherPropertyTypes.THREED__EDGETHICKNESS.propNumber;
short THREED__EXTRUDEFORWARD = EscherPropertyTypes.THREED__EXTRUDEFORWARD.propNumber;
short THREED__EXTRUDEBACKWARD = EscherPropertyTypes.THREED__EXTRUDEBACKWARD.propNumber;
short THREED__EXTRUDEPLANE = EscherPropertyTypes.THREED__EXTRUDEPLANE.propNumber;
short THREED__EXTRUSIONCOLOR = EscherPropertyTypes.THREED__EXTRUSIONCOLOR.propNumber;
short THREED__CRMOD = EscherPropertyTypes.THREED__CRMOD.propNumber;
short THREED__3DEFFECT = EscherPropertyTypes.THREED__3DEFFECT.propNumber;
short THREED__METALLIC = EscherPropertyTypes.THREED__METALLIC.propNumber;
short THREED__USEEXTRUSIONCOLOR = EscherPropertyTypes.THREED__USEEXTRUSIONCOLOR.propNumber;
short THREED__LIGHTFACE = EscherPropertyTypes.THREED__LIGHTFACE.propNumber;
short THREEDSTYLE__YROTATIONANGLE = EscherPropertyTypes.THREEDSTYLE__YROTATIONANGLE.propNumber;
short THREEDSTYLE__XROTATIONANGLE = EscherPropertyTypes.THREEDSTYLE__XROTATIONANGLE.propNumber;
short THREEDSTYLE__ROTATIONAXISX = EscherPropertyTypes.THREEDSTYLE__ROTATIONAXISX.propNumber;
short THREEDSTYLE__ROTATIONAXISY = EscherPropertyTypes.THREEDSTYLE__ROTATIONAXISY.propNumber;
short THREEDSTYLE__ROTATIONAXISZ = EscherPropertyTypes.THREEDSTYLE__ROTATIONAXISZ.propNumber;
short THREEDSTYLE__ROTATIONANGLE = EscherPropertyTypes.THREEDSTYLE__ROTATIONANGLE.propNumber;
short THREEDSTYLE__ROTATIONCENTERX = EscherPropertyTypes.THREEDSTYLE__ROTATIONCENTERX.propNumber;
short THREEDSTYLE__ROTATIONCENTERY = EscherPropertyTypes.THREEDSTYLE__ROTATIONCENTERY.propNumber;
short THREEDSTYLE__ROTATIONCENTERZ = EscherPropertyTypes.THREEDSTYLE__ROTATIONCENTERZ.propNumber;
short THREEDSTYLE__RENDERMODE = EscherPropertyTypes.THREEDSTYLE__RENDERMODE.propNumber;
short THREEDSTYLE__TOLERANCE = EscherPropertyTypes.THREEDSTYLE__TOLERANCE.propNumber;
short THREEDSTYLE__XVIEWPOINT = EscherPropertyTypes.THREEDSTYLE__XVIEWPOINT.propNumber;
short THREEDSTYLE__YVIEWPOINT = EscherPropertyTypes.THREEDSTYLE__YVIEWPOINT.propNumber;
short THREEDSTYLE__ZVIEWPOINT = EscherPropertyTypes.THREEDSTYLE__ZVIEWPOINT.propNumber;
short THREEDSTYLE__ORIGINX = EscherPropertyTypes.THREEDSTYLE__ORIGINX.propNumber;
short THREEDSTYLE__ORIGINY = EscherPropertyTypes.THREEDSTYLE__ORIGINY.propNumber;
short THREEDSTYLE__SKEWANGLE = EscherPropertyTypes.THREEDSTYLE__SKEWANGLE.propNumber;
short THREEDSTYLE__SKEWAMOUNT = EscherPropertyTypes.THREEDSTYLE__SKEWAMOUNT.propNumber;
short THREEDSTYLE__AMBIENTINTENSITY = EscherPropertyTypes.THREEDSTYLE__AMBIENTINTENSITY.propNumber;
short THREEDSTYLE__KEYX = EscherPropertyTypes.THREEDSTYLE__KEYX.propNumber;
short THREEDSTYLE__KEYY = EscherPropertyTypes.THREEDSTYLE__KEYY.propNumber;
short THREEDSTYLE__KEYZ = EscherPropertyTypes.THREEDSTYLE__KEYZ.propNumber;
short THREEDSTYLE__KEYINTENSITY = EscherPropertyTypes.THREEDSTYLE__KEYINTENSITY.propNumber;
short THREEDSTYLE__FILLX = EscherPropertyTypes.THREEDSTYLE__FILLX.propNumber;
short THREEDSTYLE__FILLY = EscherPropertyTypes.THREEDSTYLE__FILLY.propNumber;
short THREEDSTYLE__FILLZ = EscherPropertyTypes.THREEDSTYLE__FILLZ.propNumber;
short THREEDSTYLE__FILLINTENSITY = EscherPropertyTypes.THREEDSTYLE__FILLINTENSITY.propNumber;
short THREEDSTYLE__CONSTRAINROTATION = EscherPropertyTypes.THREEDSTYLE__CONSTRAINROTATION.propNumber;
short THREEDSTYLE__ROTATIONCENTERAUTO = EscherPropertyTypes.THREEDSTYLE__ROTATIONCENTERAUTO.propNumber;
short THREEDSTYLE__PARALLEL = EscherPropertyTypes.THREEDSTYLE__PARALLEL.propNumber;
short THREEDSTYLE__KEYHARSH = EscherPropertyTypes.THREEDSTYLE__KEYHARSH.propNumber;
short THREEDSTYLE__FILLHARSH = EscherPropertyTypes.THREEDSTYLE__FILLHARSH.propNumber;
short SHAPE__MASTER = EscherPropertyTypes.SHAPE__MASTER.propNumber;
short SHAPE__CONNECTORSTYLE = EscherPropertyTypes.SHAPE__CONNECTORSTYLE.propNumber;
short SHAPE__BLACKANDWHITESETTINGS = EscherPropertyTypes.SHAPE__BLACKANDWHITESETTINGS.propNumber;
short SHAPE__WMODEPUREBW = EscherPropertyTypes.SHAPE__WMODEPUREBW.propNumber;
short SHAPE__WMODEBW = EscherPropertyTypes.SHAPE__WMODEBW.propNumber;
short SHAPE__OLEICON = EscherPropertyTypes.SHAPE__OLEICON.propNumber;
short SHAPE__PREFERRELATIVERESIZE = EscherPropertyTypes.SHAPE__PREFERRELATIVERESIZE.propNumber;
short SHAPE__LOCKSHAPETYPE = EscherPropertyTypes.SHAPE__LOCKSHAPETYPE.propNumber;
short SHAPE__DELETEATTACHEDOBJECT = EscherPropertyTypes.SHAPE__DELETEATTACHEDOBJECT.propNumber;
short SHAPE__BACKGROUNDSHAPE = EscherPropertyTypes.SHAPE__BACKGROUNDSHAPE.propNumber;
short CALLOUT__CALLOUTTYPE = EscherPropertyTypes.CALLOUT__CALLOUTTYPE.propNumber;
short CALLOUT__XYCALLOUTGAP = EscherPropertyTypes.CALLOUT__XYCALLOUTGAP.propNumber;
short CALLOUT__CALLOUTANGLE = EscherPropertyTypes.CALLOUT__CALLOUTANGLE.propNumber;
short CALLOUT__CALLOUTDROPTYPE = EscherPropertyTypes.CALLOUT__CALLOUTDROPTYPE.propNumber;
short CALLOUT__CALLOUTDROPSPECIFIED = EscherPropertyTypes.CALLOUT__CALLOUTDROPSPECIFIED.propNumber;
short CALLOUT__CALLOUTLENGTHSPECIFIED = EscherPropertyTypes.CALLOUT__CALLOUTLENGTHSPECIFIED.propNumber;
short CALLOUT__ISCALLOUT = EscherPropertyTypes.CALLOUT__ISCALLOUT.propNumber;
short CALLOUT__CALLOUTACCENTBAR = EscherPropertyTypes.CALLOUT__CALLOUTACCENTBAR.propNumber;
short CALLOUT__CALLOUTTEXTBORDER = EscherPropertyTypes.CALLOUT__CALLOUTTEXTBORDER.propNumber;
short CALLOUT__CALLOUTMINUSX = EscherPropertyTypes.CALLOUT__CALLOUTMINUSX.propNumber;
short CALLOUT__CALLOUTMINUSY = EscherPropertyTypes.CALLOUT__CALLOUTMINUSY.propNumber;
short CALLOUT__DROPAUTO = EscherPropertyTypes.CALLOUT__DROPAUTO.propNumber;
short CALLOUT__LENGTHSPECIFIED = EscherPropertyTypes.CALLOUT__LENGTHSPECIFIED.propNumber;
short GROUPSHAPE__SHAPENAME = EscherPropertyTypes.GROUPSHAPE__SHAPENAME.propNumber;
short GROUPSHAPE__DESCRIPTION = EscherPropertyTypes.GROUPSHAPE__DESCRIPTION.propNumber;
short GROUPSHAPE__HYPERLINK = EscherPropertyTypes.GROUPSHAPE__HYPERLINK.propNumber;
short GROUPSHAPE__WRAPPOLYGONVERTICES = EscherPropertyTypes.GROUPSHAPE__WRAPPOLYGONVERTICES.propNumber;
short GROUPSHAPE__WRAPDISTLEFT = EscherPropertyTypes.GROUPSHAPE__WRAPDISTLEFT.propNumber;
short GROUPSHAPE__WRAPDISTTOP = EscherPropertyTypes.GROUPSHAPE__WRAPDISTTOP.propNumber;
short GROUPSHAPE__WRAPDISTRIGHT = EscherPropertyTypes.GROUPSHAPE__WRAPDISTRIGHT.propNumber;
short GROUPSHAPE__WRAPDISTBOTTOM = EscherPropertyTypes.GROUPSHAPE__WRAPDISTBOTTOM.propNumber;
short GROUPSHAPE__REGROUPID = EscherPropertyTypes.GROUPSHAPE__REGROUPID.propNumber;
short GROUPSHAPE__UNUSED906 = EscherPropertyTypes.GROUPSHAPE__UNUSED906.propNumber;
short GROUPSHAPE__TOOLTIP = EscherPropertyTypes.GROUPSHAPE__TOOLTIP.propNumber;
short GROUPSHAPE__SCRIPT = EscherPropertyTypes.GROUPSHAPE__SCRIPT.propNumber;
short GROUPSHAPE__POSH = EscherPropertyTypes.GROUPSHAPE__POSH.propNumber;
short GROUPSHAPE__POSRELH = EscherPropertyTypes.GROUPSHAPE__POSRELH.propNumber;
short GROUPSHAPE__POSV = EscherPropertyTypes.GROUPSHAPE__POSV.propNumber;
short GROUPSHAPE__POSRELV = EscherPropertyTypes.GROUPSHAPE__POSRELV.propNumber;
short GROUPSHAPE__HR_PCT = EscherPropertyTypes.GROUPSHAPE__HR_PCT.propNumber;
short GROUPSHAPE__HR_ALIGN = EscherPropertyTypes.GROUPSHAPE__HR_ALIGN.propNumber;
short GROUPSHAPE__HR_HEIGHT = EscherPropertyTypes.GROUPSHAPE__HR_HEIGHT.propNumber;
short GROUPSHAPE__HR_WIDTH = EscherPropertyTypes.GROUPSHAPE__HR_WIDTH.propNumber;
short GROUPSHAPE__SCRIPTEXT = EscherPropertyTypes.GROUPSHAPE__SCRIPTEXT.propNumber;
short GROUPSHAPE__SCRIPTLANG = EscherPropertyTypes.GROUPSHAPE__SCRIPTLANG.propNumber;
short GROUPSHAPE__BORDERTOPCOLOR = EscherPropertyTypes.GROUPSHAPE__BORDERTOPCOLOR.propNumber;
short GROUPSHAPE__BORDERLEFTCOLOR = EscherPropertyTypes.GROUPSHAPE__BORDERLEFTCOLOR.propNumber;
short GROUPSHAPE__BORDERBOTTOMCOLOR = EscherPropertyTypes.GROUPSHAPE__BORDERBOTTOMCOLOR.propNumber;
short GROUPSHAPE__BORDERRIGHTCOLOR = EscherPropertyTypes.GROUPSHAPE__BORDERRIGHTCOLOR.propNumber;
short GROUPSHAPE__TABLEPROPERTIES = EscherPropertyTypes.GROUPSHAPE__TABLEPROPERTIES.propNumber;
short GROUPSHAPE__TABLEROWPROPERTIES = EscherPropertyTypes.GROUPSHAPE__TABLEROWPROPERTIES.propNumber;
short GROUPSHAPE__WEBBOT = EscherPropertyTypes.GROUPSHAPE__WEBBOT.propNumber;
short GROUPSHAPE__METROBLOB = EscherPropertyTypes.GROUPSHAPE__METROBLOB.propNumber;
short GROUPSHAPE__ZORDER = EscherPropertyTypes.GROUPSHAPE__ZORDER.propNumber;
short GROUPSHAPE__EDITEDWRAP = EscherPropertyTypes.GROUPSHAPE__EDITEDWRAP.propNumber;
short GROUPSHAPE__BEHINDDOCUMENT = EscherPropertyTypes.GROUPSHAPE__BEHINDDOCUMENT.propNumber;
short GROUPSHAPE__ONDBLCLICKNOTIFY = EscherPropertyTypes.GROUPSHAPE__ONDBLCLICKNOTIFY.propNumber;
short GROUPSHAPE__ISBUTTON = EscherPropertyTypes.GROUPSHAPE__ISBUTTON.propNumber;
short GROUPSHAPE__1DADJUSTMENT = EscherPropertyTypes.GROUPSHAPE__1DADJUSTMENT.propNumber;
short GROUPSHAPE__HIDDEN = EscherPropertyTypes.GROUPSHAPE__HIDDEN.propNumber;
short GROUPSHAPE__FLAGS = EscherPropertyTypes.GROUPSHAPE__FLAGS.propNumber;
short GROUPSHAPE__PRINT = EscherPropertyTypes.GROUPSHAPE__FLAGS.propNumber;
// Property constants
public static final short TRANSFORM__ROTATION = 4;
public static final short PROTECTION__LOCKROTATION = 119;
public static final short PROTECTION__LOCKASPECTRATIO = 120;
public static final short PROTECTION__LOCKPOSITION = 121;
public static final short PROTECTION__LOCKAGAINSTSELECT = 122;
public static final short PROTECTION__LOCKCROPPING = 123;
public static final short PROTECTION__LOCKVERTICES = 124;
public static final short PROTECTION__LOCKTEXT = 125;
public static final short PROTECTION__LOCKADJUSTHANDLES = 126;
public static final short PROTECTION__LOCKAGAINSTGROUPING = 127;
public static final short TEXT__TEXTID = 128;
public static final short TEXT__TEXTLEFT = 129;
public static final short TEXT__TEXTTOP = 130;
public static final short TEXT__TEXTRIGHT = 131;
public static final short TEXT__TEXTBOTTOM = 132;
public static final short TEXT__WRAPTEXT = 133;
public static final short TEXT__SCALETEXT = 134;
public static final short TEXT__ANCHORTEXT = 135;
public static final short TEXT__TEXTFLOW = 136;
public static final short TEXT__FONTROTATION = 137;
public static final short TEXT__IDOFNEXTSHAPE = 138;
public static final short TEXT__BIDIR = 139;
public static final short TEXT__SINGLECLICKSELECTS = 187;
public static final short TEXT__USEHOSTMARGINS = 188;
public static final short TEXT__ROTATETEXTWITHSHAPE = 189;
public static final short TEXT__SIZESHAPETOFITTEXT = 190;
public static final short TEXT__SIZE_TEXT_TO_FIT_SHAPE = 191;
public static final short GEOTEXT__UNICODE = 192;
public static final short GEOTEXT__RTFTEXT = 193;
public static final short GEOTEXT__ALIGNMENTONCURVE = 194;
public static final short GEOTEXT__DEFAULTPOINTSIZE = 195;
public static final short GEOTEXT__TEXTSPACING = 196;
public static final short GEOTEXT__FONTFAMILYNAME = 197;
public static final short GEOTEXT__REVERSEROWORDER = 240;
public static final short GEOTEXT__HASTEXTEFFECT = 241;
public static final short GEOTEXT__ROTATECHARACTERS = 242;
public static final short GEOTEXT__KERNCHARACTERS = 243;
public static final short GEOTEXT__TIGHTORTRACK = 244;
public static final short GEOTEXT__STRETCHTOFITSHAPE = 245;
public static final short GEOTEXT__CHARBOUNDINGBOX = 246;
public static final short GEOTEXT__SCALETEXTONPATH = 247;
public static final short GEOTEXT__STRETCHCHARHEIGHT = 248;
public static final short GEOTEXT__NOMEASUREALONGPATH = 249;
public static final short GEOTEXT__BOLDFONT = 250;
public static final short GEOTEXT__ITALICFONT = 251;
public static final short GEOTEXT__UNDERLINEFONT = 252;
public static final short GEOTEXT__SHADOWFONT = 253;
public static final short GEOTEXT__SMALLCAPSFONT = 254;
public static final short GEOTEXT__STRIKETHROUGHFONT = 255;
public static final short BLIP__CROPFROMTOP = 256;
public static final short BLIP__CROPFROMBOTTOM = 257;
public static final short BLIP__CROPFROMLEFT = 258;
public static final short BLIP__CROPFROMRIGHT = 259;
public static final short BLIP__BLIPTODISPLAY = 260;
public static final short BLIP__BLIPFILENAME = 261;
public static final short BLIP__BLIPFLAGS = 262;
public static final short BLIP__TRANSPARENTCOLOR = 263;
public static final short BLIP__CONTRASTSETTING = 264;
public static final short BLIP__BRIGHTNESSSETTING = 265;
public static final short BLIP__GAMMA = 266;
public static final short BLIP__PICTUREID = 267;
public static final short BLIP__DOUBLEMOD = 268;
public static final short BLIP__PICTUREFILLMOD = 269;
public static final short BLIP__PICTURELINE = 270;
public static final short BLIP__PRINTBLIP = 271;
public static final short BLIP__PRINTBLIPFILENAME = 272;
public static final short BLIP__PRINTFLAGS = 273;
public static final short BLIP__NOHITTESTPICTURE = 316;
public static final short BLIP__PICTUREGRAY = 317;
public static final short BLIP__PICTUREBILEVEL = 318;
public static final short BLIP__PICTUREACTIVE = 319;
public static final short GEOMETRY__LEFT = 320;
public static final short GEOMETRY__TOP = 321;
public static final short GEOMETRY__RIGHT = 322;
public static final short GEOMETRY__BOTTOM = 323;
public static final short GEOMETRY__SHAPEPATH = 324;
public static final short GEOMETRY__VERTICES = 325;
public static final short GEOMETRY__SEGMENTINFO = 326;
public static final short GEOMETRY__ADJUSTVALUE = 327;
public static final short GEOMETRY__ADJUST2VALUE = 328;
public static final short GEOMETRY__ADJUST3VALUE = 329;
public static final short GEOMETRY__ADJUST4VALUE = 330;
public static final short GEOMETRY__ADJUST5VALUE = 331;
public static final short GEOMETRY__ADJUST6VALUE = 332;
public static final short GEOMETRY__ADJUST7VALUE = 333;
public static final short GEOMETRY__ADJUST8VALUE = 334;
public static final short GEOMETRY__ADJUST9VALUE = 335;
public static final short GEOMETRY__ADJUST10VALUE = 336;
public static final short GEOMETRY__PCONNECTIONSITES = 337;
public static final short GEOMETRY__PCONNECTIONSITESDIR = 338;
public static final short GEOMETRY__XLIMO = 339;
public static final short GEOMETRY__YLIMO = 340;
public static final short GEOMETRY__PADJUSTHANDLES = 341;
public static final short GEOMETRY__PGUIDES = 342;
public static final short GEOMETRY__PINSCRIBE = 343;
public static final short GEOMETRY__CXK = 344;
public static final short GEOMETRY__PFRAGMENTS = 345;
public static final short GEOMETRY__SHADOWok = 378;
public static final short GEOMETRY__3DOK = 379;
public static final short GEOMETRY__LINEOK = 380;
public static final short GEOMETRY__GEOTEXTOK = 381;
public static final short GEOMETRY__FILLSHADESHAPEOK = 382;
public static final short GEOMETRY__FILLOK = 383;
public static final short FILL__FILLTYPE = 384;
public static final short FILL__FILLCOLOR = 385;
public static final short FILL__FILLOPACITY = 386;
public static final short FILL__FILLBACKCOLOR = 387;
public static final short FILL__BACKOPACITY = 388;
public static final short FILL__CRMOD = 389;
public static final short FILL__PATTERNTEXTURE = 390;
public static final short FILL__BLIPFILENAME = 391;
public static final short FILL__BLIPFLAGS = 392;
public static final short FILL__WIDTH = 393;
public static final short FILL__HEIGHT = 394;
public static final short FILL__ANGLE = 395;
public static final short FILL__FOCUS = 396;
public static final short FILL__TOLEFT = 397;
public static final short FILL__TOTOP = 398;
public static final short FILL__TORIGHT = 399;
public static final short FILL__TOBOTTOM = 400;
public static final short FILL__RECTLEFT = 401;
public static final short FILL__RECTTOP = 402;
public static final short FILL__RECTRIGHT = 403;
public static final short FILL__RECTBOTTOM = 404;
public static final short FILL__DZTYPE = 405;
public static final short FILL__SHADEPRESET = 406;
public static final short FILL__SHADECOLORS = 407;
public static final short FILL__ORIGINX = 408;
public static final short FILL__ORIGINY = 409;
public static final short FILL__SHAPEORIGINX = 410;
public static final short FILL__SHAPEORIGINY = 411;
public static final short FILL__SHADETYPE = 412;
public static final short FILL__FILLED = 443;
public static final short FILL__HITTESTFILL = 444;
public static final short FILL__SHAPE = 445;
public static final short FILL__USERECT = 446;
public static final short FILL__NOFILLHITTEST = 447;
public static final short LINESTYLE__COLOR = 448;
public static final short LINESTYLE__OPACITY = 449;
public static final short LINESTYLE__BACKCOLOR = 450;
public static final short LINESTYLE__CRMOD = 451;
public static final short LINESTYLE__LINETYPE = 452;
public static final short LINESTYLE__FILLBLIP = 453;
public static final short LINESTYLE__FILLBLIPNAME = 454;
public static final short LINESTYLE__FILLBLIPFLAGS = 455;
public static final short LINESTYLE__FILLWIDTH = 456;
public static final short LINESTYLE__FILLHEIGHT = 457;
public static final short LINESTYLE__FILLDZTYPE = 458;
public static final short LINESTYLE__LINEWIDTH = 459;
public static final short LINESTYLE__LINEMITERLIMIT = 460;
public static final short LINESTYLE__LINESTYLE = 461;
public static final short LINESTYLE__LINEDASHING = 462;
public static final short LINESTYLE__LINEDASHSTYLE = 463;
public static final short LINESTYLE__LINESTARTARROWHEAD = 464;
public static final short LINESTYLE__LINEENDARROWHEAD = 465;
public static final short LINESTYLE__LINESTARTARROWWIDTH = 466;
public static final short LINESTYLE__LINESTARTARROWLENGTH = 467;
public static final short LINESTYLE__LINEENDARROWWIDTH = 468;
public static final short LINESTYLE__LINEENDARROWLENGTH = 469;
public static final short LINESTYLE__LINEJOINSTYLE = 470;
public static final short LINESTYLE__LINEENDCAPSTYLE = 471;
public static final short LINESTYLE__ARROWHEADSOK = 507;
public static final short LINESTYLE__ANYLINE = 508;
public static final short LINESTYLE__HITLINETEST = 509;
public static final short LINESTYLE__LINEFILLSHAPE = 510;
public static final short LINESTYLE__NOLINEDRAWDASH = 511;
public static final short LINESTYLE__NOLINEDRAWDASH_LEFT = 0x057F;
public static final short LINESTYLE__NOLINEDRAWDASH_TOP = 0x05BF;
public static final short LINESTYLE__NOLINEDRAWDASH_BOTTOM = 0x063F;
public static final short LINESTYLE__NOLINEDRAWDASH_RIGHT = 0x05FF;
public static final short SHADOWSTYLE__TYPE = 512;
public static final short SHADOWSTYLE__COLOR = 513;
public static final short SHADOWSTYLE__HIGHLIGHT = 514;
public static final short SHADOWSTYLE__CRMOD = 515;
public static final short SHADOWSTYLE__OPACITY = 516;
public static final short SHADOWSTYLE__OFFSETX = 517;
public static final short SHADOWSTYLE__OFFSETY = 518;
public static final short SHADOWSTYLE__SECONDOFFSETX = 519;
public static final short SHADOWSTYLE__SECONDOFFSETY = 520;
public static final short SHADOWSTYLE__SCALEXTOX = 521;
public static final short SHADOWSTYLE__SCALEYTOX = 522;
public static final short SHADOWSTYLE__SCALEXTOY = 523;
public static final short SHADOWSTYLE__SCALEYTOY = 524;
public static final short SHADOWSTYLE__PERSPECTIVEX = 525;
public static final short SHADOWSTYLE__PERSPECTIVEY = 526;
public static final short SHADOWSTYLE__WEIGHT = 527;
public static final short SHADOWSTYLE__ORIGINX = 528;
public static final short SHADOWSTYLE__ORIGINY = 529;
public static final short SHADOWSTYLE__SHADOW = 574;
public static final short SHADOWSTYLE__SHADOWOBSURED = 575;
public static final short PERSPECTIVE__TYPE = 576;
public static final short PERSPECTIVE__OFFSETX = 577;
public static final short PERSPECTIVE__OFFSETY = 578;
public static final short PERSPECTIVE__SCALEXTOX = 579;
public static final short PERSPECTIVE__SCALEYTOX = 580;
public static final short PERSPECTIVE__SCALEXTOY = 581;
public static final short PERSPECTIVE__SCALEYTOY = 582;
public static final short PERSPECTIVE__PERSPECTIVEX = 583;
public static final short PERSPECTIVE__PERSPECTIVEY = 584;
public static final short PERSPECTIVE__WEIGHT = 585;
public static final short PERSPECTIVE__ORIGINX = 586;
public static final short PERSPECTIVE__ORIGINY = 587;
public static final short PERSPECTIVE__PERSPECTIVEON = 639;
public static final short THREED__SPECULARAMOUNT = 640;
public static final short THREED__DIFFUSEAMOUNT = 661;
public static final short THREED__SHININESS = 662;
public static final short THREED__EDGETHICKNESS = 663;
public static final short THREED__EXTRUDEFORWARD = 664;
public static final short THREED__EXTRUDEBACKWARD = 665;
public static final short THREED__EXTRUDEPLANE = 666;
public static final short THREED__EXTRUSIONCOLOR = 667;
public static final short THREED__CRMOD = 648;
public static final short THREED__3DEFFECT = 700;
public static final short THREED__METALLIC = 701;
public static final short THREED__USEEXTRUSIONCOLOR = 702;
public static final short THREED__LIGHTFACE = 703;
public static final short THREEDSTYLE__YROTATIONANGLE = 704;
public static final short THREEDSTYLE__XROTATIONANGLE = 705;
public static final short THREEDSTYLE__ROTATIONAXISX = 706;
public static final short THREEDSTYLE__ROTATIONAXISY = 707;
public static final short THREEDSTYLE__ROTATIONAXISZ = 708;
public static final short THREEDSTYLE__ROTATIONANGLE = 709;
public static final short THREEDSTYLE__ROTATIONCENTERX = 710;
public static final short THREEDSTYLE__ROTATIONCENTERY = 711;
public static final short THREEDSTYLE__ROTATIONCENTERZ = 712;
public static final short THREEDSTYLE__RENDERMODE = 713;
public static final short THREEDSTYLE__TOLERANCE = 714;
public static final short THREEDSTYLE__XVIEWPOINT = 715;
public static final short THREEDSTYLE__YVIEWPOINT = 716;
public static final short THREEDSTYLE__ZVIEWPOINT = 717;
public static final short THREEDSTYLE__ORIGINX = 718;
public static final short THREEDSTYLE__ORIGINY = 719;
public static final short THREEDSTYLE__SKEWANGLE = 720;
public static final short THREEDSTYLE__SKEWAMOUNT = 721;
public static final short THREEDSTYLE__AMBIENTINTENSITY = 722;
public static final short THREEDSTYLE__KEYX = 723;
public static final short THREEDSTYLE__KEYY = 724;
public static final short THREEDSTYLE__KEYZ = 725;
public static final short THREEDSTYLE__KEYINTENSITY = 726;
public static final short THREEDSTYLE__FILLX = 727;
public static final short THREEDSTYLE__FILLY = 728;
public static final short THREEDSTYLE__FILLZ = 729;
public static final short THREEDSTYLE__FILLINTENSITY = 730;
public static final short THREEDSTYLE__CONSTRAINROTATION = 763;
public static final short THREEDSTYLE__ROTATIONCENTERAUTO = 764;
public static final short THREEDSTYLE__PARALLEL = 765;
public static final short THREEDSTYLE__KEYHARSH = 766;
public static final short THREEDSTYLE__FILLHARSH = 767;
public static final short SHAPE__MASTER = 769;
public static final short SHAPE__CONNECTORSTYLE = 771;
public static final short SHAPE__BLACKANDWHITESETTINGS = 772;
public static final short SHAPE__WMODEPUREBW = 773;
public static final short SHAPE__WMODEBW = 774;
public static final short SHAPE__OLEICON = 826;
public static final short SHAPE__PREFERRELATIVERESIZE = 827;
public static final short SHAPE__LOCKSHAPETYPE = 828;
public static final short SHAPE__DELETEATTACHEDOBJECT = 830;
public static final short SHAPE__BACKGROUNDSHAPE = 831;
public static final short CALLOUT__CALLOUTTYPE = 832;
public static final short CALLOUT__XYCALLOUTGAP = 833;
public static final short CALLOUT__CALLOUTANGLE = 834;
public static final short CALLOUT__CALLOUTDROPTYPE = 835;
public static final short CALLOUT__CALLOUTDROPSPECIFIED = 836;
public static final short CALLOUT__CALLOUTLENGTHSPECIFIED = 837;
public static final short CALLOUT__ISCALLOUT = 889;
public static final short CALLOUT__CALLOUTACCENTBAR = 890;
public static final short CALLOUT__CALLOUTTEXTBORDER = 891;
public static final short CALLOUT__CALLOUTMINUSX = 892;
public static final short CALLOUT__CALLOUTMINUSY = 893;
public static final short CALLOUT__DROPAUTO = 894;
public static final short CALLOUT__LENGTHSPECIFIED = 895;
public static final short GROUPSHAPE__SHAPENAME = 0x0380;
public static final short GROUPSHAPE__DESCRIPTION = 0x0381;
public static final short GROUPSHAPE__HYPERLINK = 0x0382;
public static final short GROUPSHAPE__WRAPPOLYGONVERTICES = 0x0383;
public static final short GROUPSHAPE__WRAPDISTLEFT = 0x0384;
public static final short GROUPSHAPE__WRAPDISTTOP = 0x0385;
public static final short GROUPSHAPE__WRAPDISTRIGHT = 0x0386;
public static final short GROUPSHAPE__WRAPDISTBOTTOM = 0x0387;
public static final short GROUPSHAPE__REGROUPID = 0x0388;
public static final short GROUPSHAPE__UNUSED906 = 0x038A;
public static final short GROUPSHAPE__TOOLTIP = 0x038D;
public static final short GROUPSHAPE__SCRIPT = 0x038E;
public static final short GROUPSHAPE__POSH = 0x038F;
public static final short GROUPSHAPE__POSRELH = 0x0390;
public static final short GROUPSHAPE__POSV = 0x0391;
public static final short GROUPSHAPE__POSRELV = 0x0392;
public static final short GROUPSHAPE__HR_PCT = 0x0393;
public static final short GROUPSHAPE__HR_ALIGN = 0x0394;
public static final short GROUPSHAPE__HR_HEIGHT = 0x0395;
public static final short GROUPSHAPE__HR_WIDTH = 0x0396;
public static final short GROUPSHAPE__SCRIPTEXT = 0x0397;
public static final short GROUPSHAPE__SCRIPTLANG = 0x0398;
public static final short GROUPSHAPE__BORDERTOPCOLOR = 0x039B;
public static final short GROUPSHAPE__BORDERLEFTCOLOR = 0x039C;
public static final short GROUPSHAPE__BORDERBOTTOMCOLOR = 0x039D;
public static final short GROUPSHAPE__BORDERRIGHTCOLOR = 0x039E;
public static final short GROUPSHAPE__TABLEPROPERTIES = 0x039F;
public static final short GROUPSHAPE__TABLEROWPROPERTIES = 0x03A0;
public static final short GROUPSHAPE__WEBBOT = 0x03A5;
public static final short GROUPSHAPE__METROBLOB = 0x03A9;
public static final short GROUPSHAPE__ZORDER = 0x03AA;
public static final short GROUPSHAPE__FLAGS = 0x03BF;
public static final short GROUPSHAPE__EDITEDWRAP = 953;
public static final short GROUPSHAPE__BEHINDDOCUMENT = 954;
public static final short GROUPSHAPE__ONDBLCLICKNOTIFY = 955;
public static final short GROUPSHAPE__ISBUTTON = 956;
public static final short GROUPSHAPE__1DADJUSTMENT = 957;
public static final short GROUPSHAPE__HIDDEN = 958;
public static final short GROUPSHAPE__PRINT = 959;
private static final Map<Short, EscherPropertyMetaData> properties = initProps(); static String getPropertyName(short propertyId) {
return EscherPropertyTypes.forPropertyID(propertyId).propName;
private EscherProperties() {
} }
private static Map<Short, EscherPropertyMetaData> initProps() { static byte getPropertyType(short propertyId) {
Map<Short, EscherPropertyMetaData> m = new HashMap<>(); return (byte)EscherPropertyTypes.forPropertyID(propertyId).holder.ordinal();
addProp(m, TRANSFORM__ROTATION, "transform.rotation");
addProp(m, PROTECTION__LOCKROTATION, "protection.lockrotation");
addProp(m, PROTECTION__LOCKASPECTRATIO, "protection.lockaspectratio");
addProp(m, PROTECTION__LOCKPOSITION, "protection.lockposition");
addProp(m, PROTECTION__LOCKAGAINSTSELECT, "protection.lockagainstselect");
addProp(m, PROTECTION__LOCKCROPPING, "protection.lockcropping");
addProp(m, PROTECTION__LOCKVERTICES, "protection.lockvertices");
addProp(m, PROTECTION__LOCKTEXT, "protection.locktext");
addProp(m, PROTECTION__LOCKADJUSTHANDLES, "protection.lockadjusthandles");
addProp(m, PROTECTION__LOCKAGAINSTGROUPING, "protection.lockagainstgrouping", EscherPropertyMetaData.TYPE_BOOLEAN);
addProp(m, TEXT__TEXTID, "text.textid");
addProp(m, TEXT__TEXTLEFT, "text.textleft");
addProp(m, TEXT__TEXTTOP, "text.texttop");
addProp(m, TEXT__TEXTRIGHT, "text.textright");
addProp(m, TEXT__TEXTBOTTOM, "text.textbottom");
addProp(m, TEXT__WRAPTEXT, "text.wraptext");
addProp(m, TEXT__SCALETEXT, "text.scaletext");
addProp(m, TEXT__ANCHORTEXT, "text.anchortext");
addProp(m, TEXT__TEXTFLOW, "text.textflow");
addProp(m, TEXT__FONTROTATION, "text.fontrotation");
addProp(m, TEXT__IDOFNEXTSHAPE, "text.idofnextshape");
addProp(m, TEXT__BIDIR, "text.bidir");
addProp(m, TEXT__SINGLECLICKSELECTS, "text.singleclickselects");
addProp(m, TEXT__USEHOSTMARGINS, "text.usehostmargins");
addProp(m, TEXT__ROTATETEXTWITHSHAPE, "text.rotatetextwithshape");
addProp(m, TEXT__SIZESHAPETOFITTEXT, "text.sizeshapetofittext");
addProp(m, TEXT__SIZE_TEXT_TO_FIT_SHAPE, "text.sizetexttofitshape", EscherPropertyMetaData.TYPE_BOOLEAN);
addProp(m, GEOTEXT__UNICODE, "geotext.unicode");
addProp(m, GEOTEXT__RTFTEXT, "geotext.rtftext");
addProp(m, GEOTEXT__ALIGNMENTONCURVE, "geotext.alignmentoncurve");
addProp(m, GEOTEXT__DEFAULTPOINTSIZE, "geotext.defaultpointsize");
addProp(m, GEOTEXT__TEXTSPACING, "geotext.textspacing");
addProp(m, GEOTEXT__FONTFAMILYNAME, "geotext.fontfamilyname");
addProp(m, GEOTEXT__REVERSEROWORDER, "geotext.reverseroworder");
addProp(m, GEOTEXT__HASTEXTEFFECT, "geotext.hastexteffect");
addProp(m, GEOTEXT__ROTATECHARACTERS, "geotext.rotatecharacters");
addProp(m, GEOTEXT__KERNCHARACTERS, "geotext.kerncharacters");
addProp(m, GEOTEXT__TIGHTORTRACK, "geotext.tightortrack");
addProp(m, GEOTEXT__STRETCHTOFITSHAPE, "geotext.stretchtofitshape");
addProp(m, GEOTEXT__CHARBOUNDINGBOX, "geotext.charboundingbox");
addProp(m, GEOTEXT__SCALETEXTONPATH, "geotext.scaletextonpath");
addProp(m, GEOTEXT__STRETCHCHARHEIGHT, "geotext.stretchcharheight");
addProp(m, GEOTEXT__NOMEASUREALONGPATH, "geotext.nomeasurealongpath");
addProp(m, GEOTEXT__BOLDFONT, "geotext.boldfont");
addProp(m, GEOTEXT__ITALICFONT, "geotext.italicfont");
addProp(m, GEOTEXT__UNDERLINEFONT, "geotext.underlinefont");
addProp(m, GEOTEXT__SHADOWFONT, "geotext.shadowfont");
addProp(m, GEOTEXT__SMALLCAPSFONT, "geotext.smallcapsfont");
addProp(m, GEOTEXT__STRIKETHROUGHFONT, "geotext.strikethroughfont");
addProp(m, BLIP__CROPFROMTOP, "blip.cropfromtop");
addProp(m, BLIP__CROPFROMBOTTOM, "blip.cropfrombottom");
addProp(m, BLIP__CROPFROMLEFT, "blip.cropfromleft");
addProp(m, BLIP__CROPFROMRIGHT, "blip.cropfromright");
addProp(m, BLIP__BLIPTODISPLAY, "blip.bliptodisplay");
addProp(m, BLIP__BLIPFILENAME, "blip.blipfilename");
addProp(m, BLIP__BLIPFLAGS, "blip.blipflags");
addProp(m, BLIP__TRANSPARENTCOLOR, "blip.transparentcolor");
addProp(m, BLIP__CONTRASTSETTING, "blip.contrastsetting");
addProp(m, BLIP__BRIGHTNESSSETTING, "blip.brightnesssetting");
addProp(m, BLIP__GAMMA, "blip.gamma");
addProp(m, BLIP__PICTUREID, "blip.pictureid");
addProp(m, BLIP__DOUBLEMOD, "blip.doublemod");
addProp(m, BLIP__PICTUREFILLMOD, "blip.picturefillmod");
addProp(m, BLIP__PICTURELINE, "blip.pictureline");
addProp(m, BLIP__PRINTBLIP, "blip.printblip");
addProp(m, BLIP__PRINTBLIPFILENAME, "blip.printblipfilename");
addProp(m, BLIP__PRINTFLAGS, "blip.printflags");
addProp(m, BLIP__NOHITTESTPICTURE, "blip.nohittestpicture");
addProp(m, BLIP__PICTUREGRAY, "blip.picturegray");
addProp(m, BLIP__PICTUREBILEVEL, "blip.picturebilevel");
addProp(m, BLIP__PICTUREACTIVE, "blip.pictureactive");
addProp(m, GEOMETRY__LEFT, "geometry.left");
addProp(m, GEOMETRY__TOP, "geometry.top");
addProp(m, GEOMETRY__RIGHT, "geometry.right");
addProp(m, GEOMETRY__BOTTOM, "geometry.bottom");
addProp(m, GEOMETRY__SHAPEPATH, "geometry.shapepath", EscherPropertyMetaData.TYPE_SHAPEPATH);
addProp(m, GEOMETRY__VERTICES, "geometry.vertices", EscherPropertyMetaData.TYPE_ARRAY);
addProp(m, GEOMETRY__SEGMENTINFO, "geometry.segmentinfo", EscherPropertyMetaData.TYPE_ARRAY);
addProp(m, GEOMETRY__ADJUSTVALUE, "geometry.adjustvalue");
addProp(m, GEOMETRY__ADJUST2VALUE, "geometry.adjust2value");
addProp(m, GEOMETRY__ADJUST3VALUE, "geometry.adjust3value");
addProp(m, GEOMETRY__ADJUST4VALUE, "geometry.adjust4value");
addProp(m, GEOMETRY__ADJUST5VALUE, "geometry.adjust5value");
addProp(m, GEOMETRY__ADJUST6VALUE, "geometry.adjust6value");
addProp(m, GEOMETRY__ADJUST7VALUE, "geometry.adjust7value");
addProp(m, GEOMETRY__ADJUST8VALUE, "geometry.adjust8value");
addProp(m, GEOMETRY__ADJUST9VALUE, "geometry.adjust9value");
addProp(m, GEOMETRY__ADJUST10VALUE, "geometry.adjust10value");
addProp(m, GEOMETRY__PCONNECTIONSITES, "geometry.pConnectionSites");
addProp(m, GEOMETRY__PCONNECTIONSITESDIR, "geometry.pConnectionSitesDir");
addProp(m, GEOMETRY__XLIMO, "geometry.xLimo");
addProp(m, GEOMETRY__YLIMO, "geometry.yLimo");
addProp(m, GEOMETRY__PADJUSTHANDLES, "geometry.pAdjustHandles");
addProp(m, GEOMETRY__PGUIDES, "geometry.pGuides");
addProp(m, GEOMETRY__PINSCRIBE, "geometry.pInscribe");
addProp(m, GEOMETRY__CXK, "geometry.cxk");
addProp(m, GEOMETRY__PFRAGMENTS, "geometry.pFragments");
addProp(m, GEOMETRY__SHADOWok, "geometry.shadowOK");
addProp(m, GEOMETRY__3DOK, "geometry.3dok");
addProp(m, GEOMETRY__LINEOK, "geometry.lineok");
addProp(m, GEOMETRY__GEOTEXTOK, "geometry.geotextok");
addProp(m, GEOMETRY__FILLSHADESHAPEOK, "geometry.fillshadeshapeok");
addProp(m, GEOMETRY__FILLOK, "geometry.fillok", EscherPropertyMetaData.TYPE_BOOLEAN);
addProp(m, FILL__FILLTYPE, "fill.filltype");
addProp(m, FILL__FILLCOLOR, "fill.fillcolor", EscherPropertyMetaData.TYPE_RGB);
addProp(m, FILL__FILLOPACITY, "fill.fillopacity");
addProp(m, FILL__FILLBACKCOLOR, "fill.fillbackcolor", EscherPropertyMetaData.TYPE_RGB);
addProp(m, FILL__BACKOPACITY, "fill.backopacity");
addProp(m, FILL__CRMOD, "fill.crmod");
addProp(m, FILL__PATTERNTEXTURE, "fill.patterntexture");
addProp(m, FILL__BLIPFILENAME, "fill.blipfilename");
addProp(m, FILL__BLIPFLAGS, "fill.blipflags");
addProp(m, FILL__WIDTH, "fill.width");
addProp(m, FILL__HEIGHT, "fill.height");
addProp(m, FILL__ANGLE, "fill.angle");
addProp(m, FILL__FOCUS, "fill.focus");
addProp(m, FILL__TOLEFT, "fill.toleft");
addProp(m, FILL__TOTOP, "fill.totop");
addProp(m, FILL__TORIGHT, "fill.toright");
addProp(m, FILL__TOBOTTOM, "fill.tobottom");
addProp(m, FILL__RECTLEFT, "fill.rectleft");
addProp(m, FILL__RECTTOP, "fill.recttop");
addProp(m, FILL__RECTRIGHT, "fill.rectright");
addProp(m, FILL__RECTBOTTOM, "fill.rectbottom");
addProp(m, FILL__DZTYPE, "fill.dztype");
addProp(m, FILL__SHADEPRESET, "fill.shadepreset");
addProp(m, FILL__SHADECOLORS, "fill.shadecolors", EscherPropertyMetaData.TYPE_ARRAY);
addProp(m, FILL__ORIGINX, "fill.originx");
addProp(m, FILL__ORIGINY, "fill.originy");
addProp(m, FILL__SHAPEORIGINX, "fill.shapeoriginx");
addProp(m, FILL__SHAPEORIGINY, "fill.shapeoriginy");
addProp(m, FILL__SHADETYPE, "fill.shadetype");
addProp(m, FILL__FILLED, "fill.filled");
addProp(m, FILL__HITTESTFILL, "fill.hittestfill");
addProp(m, FILL__SHAPE, "fill.shape");
addProp(m, FILL__USERECT, "fill.userect");
addProp(m, FILL__NOFILLHITTEST, "fill.nofillhittest", EscherPropertyMetaData.TYPE_BOOLEAN);
addProp(m, LINESTYLE__COLOR, "linestyle.color", EscherPropertyMetaData.TYPE_RGB);
addProp(m, LINESTYLE__OPACITY, "linestyle.opacity");
addProp(m, LINESTYLE__BACKCOLOR, "linestyle.backcolor", EscherPropertyMetaData.TYPE_RGB);
addProp(m, LINESTYLE__CRMOD, "linestyle.crmod");
addProp(m, LINESTYLE__LINETYPE, "linestyle.linetype");
addProp(m, LINESTYLE__FILLBLIP, "linestyle.fillblip");
addProp(m, LINESTYLE__FILLBLIPNAME, "linestyle.fillblipname");
addProp(m, LINESTYLE__FILLBLIPFLAGS, "linestyle.fillblipflags");
addProp(m, LINESTYLE__FILLWIDTH, "linestyle.fillwidth");
addProp(m, LINESTYLE__FILLHEIGHT, "linestyle.fillheight");
addProp(m, LINESTYLE__FILLDZTYPE, "linestyle.filldztype");
addProp(m, LINESTYLE__LINEWIDTH, "linestyle.linewidth");
addProp(m, LINESTYLE__LINEMITERLIMIT, "linestyle.linemiterlimit");
addProp(m, LINESTYLE__LINESTYLE, "linestyle.linestyle");
addProp(m, LINESTYLE__LINEDASHING, "linestyle.linedashing");
addProp(m, LINESTYLE__LINEDASHSTYLE, "linestyle.linedashstyle", EscherPropertyMetaData.TYPE_ARRAY);
addProp(m, LINESTYLE__LINESTARTARROWHEAD, "linestyle.linestartarrowhead");
addProp(m, LINESTYLE__LINEENDARROWHEAD, "linestyle.lineendarrowhead");
addProp(m, LINESTYLE__LINESTARTARROWWIDTH, "linestyle.linestartarrowwidth");
addProp(m, LINESTYLE__LINESTARTARROWLENGTH, "linestyle.linestartarrowlength");
addProp(m, LINESTYLE__LINEENDARROWWIDTH, "linestyle.lineendarrowwidth");
addProp(m, LINESTYLE__LINEENDARROWLENGTH, "linestyle.lineendarrowlength");
addProp(m, LINESTYLE__LINEJOINSTYLE, "linestyle.linejoinstyle");
addProp(m, LINESTYLE__LINEENDCAPSTYLE, "linestyle.lineendcapstyle");
addProp(m, LINESTYLE__ARROWHEADSOK, "linestyle.arrowheadsok");
addProp(m, LINESTYLE__ANYLINE, "linestyle.anyline");
addProp(m, LINESTYLE__HITLINETEST, "linestyle.hitlinetest");
addProp(m, LINESTYLE__LINEFILLSHAPE, "linestyle.linefillshape");
addProp(m, LINESTYLE__NOLINEDRAWDASH, "linestyle.nolinedrawdash", EscherPropertyMetaData.TYPE_BOOLEAN);
addProp(m, LINESTYLE__NOLINEDRAWDASH_LEFT, "linestyle.nolinedrawdash.left", EscherPropertyMetaData.TYPE_BOOLEAN);
addProp(m, LINESTYLE__NOLINEDRAWDASH_TOP, "linestyle.nolinedrawdash.top", EscherPropertyMetaData.TYPE_BOOLEAN);
addProp(m, LINESTYLE__NOLINEDRAWDASH_BOTTOM, "linestyle.nolinedrawdash.bottom", EscherPropertyMetaData.TYPE_BOOLEAN);
addProp(m, LINESTYLE__NOLINEDRAWDASH_RIGHT, "linestyle.nolinedrawdash.right", EscherPropertyMetaData.TYPE_BOOLEAN);
addProp(m, SHADOWSTYLE__TYPE, "shadowstyle.type");
addProp(m, SHADOWSTYLE__COLOR, "shadowstyle.color", EscherPropertyMetaData.TYPE_RGB);
addProp(m, SHADOWSTYLE__HIGHLIGHT, "shadowstyle.highlight");
addProp(m, SHADOWSTYLE__CRMOD, "shadowstyle.crmod");
addProp(m, SHADOWSTYLE__OPACITY, "shadowstyle.opacity");
addProp(m, SHADOWSTYLE__OFFSETX, "shadowstyle.offsetx");
addProp(m, SHADOWSTYLE__OFFSETY, "shadowstyle.offsety");
addProp(m, SHADOWSTYLE__SECONDOFFSETX, "shadowstyle.secondoffsetx");
addProp(m, SHADOWSTYLE__SECONDOFFSETY, "shadowstyle.secondoffsety");
addProp(m, SHADOWSTYLE__SCALEXTOX, "shadowstyle.scalextox");
addProp(m, SHADOWSTYLE__SCALEYTOX, "shadowstyle.scaleytox");
addProp(m, SHADOWSTYLE__SCALEXTOY, "shadowstyle.scalextoy");
addProp(m, SHADOWSTYLE__SCALEYTOY, "shadowstyle.scaleytoy");
addProp(m, SHADOWSTYLE__PERSPECTIVEX, "shadowstyle.perspectivex");
addProp(m, SHADOWSTYLE__PERSPECTIVEY, "shadowstyle.perspectivey");
addProp(m, SHADOWSTYLE__WEIGHT, "shadowstyle.weight");
addProp(m, SHADOWSTYLE__ORIGINX, "shadowstyle.originx");
addProp(m, SHADOWSTYLE__ORIGINY, "shadowstyle.originy");
addProp(m, SHADOWSTYLE__SHADOW, "shadowstyle.shadow");
addProp(m, SHADOWSTYLE__SHADOWOBSURED, "shadowstyle.shadowobscured");
addProp(m, PERSPECTIVE__TYPE, "perspective.type");
addProp(m, PERSPECTIVE__OFFSETX, "perspective.offsetx");
addProp(m, PERSPECTIVE__OFFSETY, "perspective.offsety");
addProp(m, PERSPECTIVE__SCALEXTOX, "perspective.scalextox");
addProp(m, PERSPECTIVE__SCALEYTOX, "perspective.scaleytox");
addProp(m, PERSPECTIVE__SCALEXTOY, "perspective.scalextoy");
addProp(m, PERSPECTIVE__SCALEYTOY, "perspective.scaleytoy");
addProp(m, PERSPECTIVE__PERSPECTIVEX, "perspective.perspectivex");
addProp(m, PERSPECTIVE__PERSPECTIVEY, "perspective.perspectivey");
addProp(m, PERSPECTIVE__WEIGHT, "perspective.weight");
addProp(m, PERSPECTIVE__ORIGINX, "perspective.originx");
addProp(m, PERSPECTIVE__ORIGINY, "perspective.originy");
addProp(m, PERSPECTIVE__PERSPECTIVEON, "perspective.perspectiveon");
addProp(m, THREED__SPECULARAMOUNT, "3d.specularamount");
addProp(m, THREED__DIFFUSEAMOUNT, "3d.diffuseamount");
addProp(m, THREED__SHININESS, "3d.shininess");
addProp(m, THREED__EDGETHICKNESS, "3d.edgethickness");
addProp(m, THREED__EXTRUDEFORWARD, "3d.extrudeforward");
addProp(m, THREED__EXTRUDEBACKWARD, "3d.extrudebackward");
addProp(m, THREED__EXTRUDEPLANE, "3d.extrudeplane");
addProp(m, THREED__EXTRUSIONCOLOR, "3d.extrusioncolor", EscherPropertyMetaData.TYPE_RGB);
addProp(m, THREED__CRMOD, "3d.crmod");
addProp(m, THREED__3DEFFECT, "3d.3deffect");
addProp(m, THREED__METALLIC, "3d.metallic");
addProp(m, THREED__USEEXTRUSIONCOLOR, "3d.useextrusioncolor", EscherPropertyMetaData.TYPE_RGB);
addProp(m, THREED__LIGHTFACE, "3d.lightface");
addProp(m, THREEDSTYLE__YROTATIONANGLE, "3dstyle.yrotationangle");
addProp(m, THREEDSTYLE__XROTATIONANGLE, "3dstyle.xrotationangle");
addProp(m, THREEDSTYLE__ROTATIONAXISX, "3dstyle.rotationaxisx");
addProp(m, THREEDSTYLE__ROTATIONAXISY, "3dstyle.rotationaxisy");
addProp(m, THREEDSTYLE__ROTATIONAXISZ, "3dstyle.rotationaxisz");
addProp(m, THREEDSTYLE__ROTATIONANGLE, "3dstyle.rotationangle");
addProp(m, THREEDSTYLE__ROTATIONCENTERX, "3dstyle.rotationcenterx");
addProp(m, THREEDSTYLE__ROTATIONCENTERY, "3dstyle.rotationcentery");
addProp(m, THREEDSTYLE__ROTATIONCENTERZ, "3dstyle.rotationcenterz");
addProp(m, THREEDSTYLE__RENDERMODE, "3dstyle.rendermode");
addProp(m, THREEDSTYLE__TOLERANCE, "3dstyle.tolerance");
addProp(m, THREEDSTYLE__XVIEWPOINT, "3dstyle.xviewpoint");
addProp(m, THREEDSTYLE__YVIEWPOINT, "3dstyle.yviewpoint");
addProp(m, THREEDSTYLE__ZVIEWPOINT, "3dstyle.zviewpoint");
addProp(m, THREEDSTYLE__ORIGINX, "3dstyle.originx");
addProp(m, THREEDSTYLE__ORIGINY, "3dstyle.originy");
addProp(m, THREEDSTYLE__SKEWANGLE, "3dstyle.skewangle");
addProp(m, THREEDSTYLE__SKEWAMOUNT, "3dstyle.skewamount");
addProp(m, THREEDSTYLE__AMBIENTINTENSITY, "3dstyle.ambientintensity");
addProp(m, THREEDSTYLE__KEYX, "3dstyle.keyx");
addProp(m, THREEDSTYLE__KEYY, "3dstyle.keyy");
addProp(m, THREEDSTYLE__KEYZ, "3dstyle.keyz");
addProp(m, THREEDSTYLE__KEYINTENSITY, "3dstyle.keyintensity");
addProp(m, THREEDSTYLE__FILLX, "3dstyle.fillx");
addProp(m, THREEDSTYLE__FILLY, "3dstyle.filly");
addProp(m, THREEDSTYLE__FILLZ, "3dstyle.fillz");
addProp(m, THREEDSTYLE__FILLINTENSITY, "3dstyle.fillintensity");
addProp(m, THREEDSTYLE__CONSTRAINROTATION, "3dstyle.constrainrotation");
addProp(m, THREEDSTYLE__ROTATIONCENTERAUTO, "3dstyle.rotationcenterauto");
addProp(m, THREEDSTYLE__PARALLEL, "3dstyle.parallel");
addProp(m, THREEDSTYLE__KEYHARSH, "3dstyle.keyharsh");
addProp(m, THREEDSTYLE__FILLHARSH, "3dstyle.fillharsh");
addProp(m, SHAPE__MASTER, "shape.master");
addProp(m, SHAPE__CONNECTORSTYLE, "shape.connectorstyle");
addProp(m, SHAPE__BLACKANDWHITESETTINGS, "shape.blackandwhitesettings");
addProp(m, SHAPE__WMODEPUREBW, "shape.wmodepurebw");
addProp(m, SHAPE__WMODEBW, "shape.wmodebw");
addProp(m, SHAPE__OLEICON, "shape.oleicon");
addProp(m, SHAPE__PREFERRELATIVERESIZE, "shape.preferrelativeresize");
addProp(m, SHAPE__LOCKSHAPETYPE, "shape.lockshapetype");
addProp(m, SHAPE__DELETEATTACHEDOBJECT, "shape.deleteattachedobject");
addProp(m, SHAPE__BACKGROUNDSHAPE, "shape.backgroundshape");
addProp(m, CALLOUT__CALLOUTTYPE, "callout.callouttype");
addProp(m, CALLOUT__XYCALLOUTGAP, "callout.xycalloutgap");
addProp(m, CALLOUT__CALLOUTANGLE, "callout.calloutangle");
addProp(m, CALLOUT__CALLOUTDROPTYPE, "callout.calloutdroptype");
addProp(m, CALLOUT__CALLOUTDROPSPECIFIED, "callout.calloutdropspecified");
addProp(m, CALLOUT__CALLOUTLENGTHSPECIFIED, "callout.calloutlengthspecified");
addProp(m, CALLOUT__ISCALLOUT, "callout.iscallout");
addProp(m, CALLOUT__CALLOUTACCENTBAR, "callout.calloutaccentbar");
addProp(m, CALLOUT__CALLOUTTEXTBORDER, "callout.callouttextborder");
addProp(m, CALLOUT__CALLOUTMINUSX, "callout.calloutminusx");
addProp(m, CALLOUT__CALLOUTMINUSY, "callout.calloutminusy");
addProp(m, CALLOUT__DROPAUTO, "callout.dropauto");
addProp(m, CALLOUT__LENGTHSPECIFIED, "callout.lengthspecified");
addProp(m, GROUPSHAPE__SHAPENAME, "groupshape.shapename");
addProp(m, GROUPSHAPE__DESCRIPTION, "groupshape.description");
addProp(m, GROUPSHAPE__HYPERLINK, "groupshape.hyperlink");
addProp(m, GROUPSHAPE__WRAPPOLYGONVERTICES, "groupshape.wrappolygonvertices", EscherPropertyMetaData.TYPE_ARRAY);
addProp(m, GROUPSHAPE__WRAPDISTLEFT, "groupshape.wrapdistleft");
addProp(m, GROUPSHAPE__WRAPDISTTOP, "groupshape.wrapdisttop");
addProp(m, GROUPSHAPE__WRAPDISTRIGHT, "groupshape.wrapdistright");
addProp(m, GROUPSHAPE__WRAPDISTBOTTOM, "groupshape.wrapdistbottom");
addProp(m, GROUPSHAPE__REGROUPID, "groupshape.regroupid");
addProp( m, GROUPSHAPE__UNUSED906, "unused906" ); // 0x038A;
addProp( m, GROUPSHAPE__TOOLTIP, "groupshape.wzTooltip" ); // 0x038D;
addProp( m, GROUPSHAPE__SCRIPT, "groupshape.wzScript" ); // 0x038E;
addProp( m, GROUPSHAPE__POSH, "groupshape.posh" ); // 0x038F;
addProp( m, GROUPSHAPE__POSRELH, "groupshape.posrelh" ); // 0x0390;
addProp( m, GROUPSHAPE__POSV, "groupshape.posv" ); // 0x0391;
addProp( m, GROUPSHAPE__POSRELV, "groupshape.posrelv" ); // 0x0392;
addProp( m, GROUPSHAPE__HR_PCT, "groupshape.pctHR" ); // 0x0393;
addProp( m, GROUPSHAPE__HR_ALIGN, "groupshape.alignHR" ); // 0x0394;
addProp( m, GROUPSHAPE__HR_HEIGHT, "groupshape.dxHeightHR" ); // 0x0395;
addProp( m, GROUPSHAPE__HR_WIDTH, "groupshape.dxWidthHR" ); // 0x0396;
addProp( m, GROUPSHAPE__SCRIPTEXT, "groupshape.wzScriptExtAttr" ); // 0x0397;
addProp( m, GROUPSHAPE__SCRIPTLANG, "groupshape.scriptLang" ); // 0x0398;
addProp( m, GROUPSHAPE__BORDERTOPCOLOR, "groupshape.borderTopColor" ); // 0x039B;
addProp( m, GROUPSHAPE__BORDERLEFTCOLOR, "groupshape.borderLeftColor" ); // 0x039C;
addProp( m, GROUPSHAPE__BORDERBOTTOMCOLOR, "groupshape.borderBottomColor" ); // 0x039D;
addProp( m, GROUPSHAPE__BORDERRIGHTCOLOR, "groupshape.borderRightColor" ); // 0x039E;
addProp( m, GROUPSHAPE__TABLEPROPERTIES, "groupshape.tableProperties" ); // 0x039F;
addProp( m, GROUPSHAPE__TABLEROWPROPERTIES, "groupshape.tableRowProperties", EscherPropertyMetaData.TYPE_ARRAY ); // 0x03A0;
addProp( m, GROUPSHAPE__WEBBOT, "groupshape.wzWebBot" ); // 0x03A5;
addProp( m, GROUPSHAPE__METROBLOB, "groupshape.metroBlob" ); // 0x03A9;
addProp( m, GROUPSHAPE__ZORDER, "groupshape.dhgt" ); // 0x03AA;
addProp( m, GROUPSHAPE__FLAGS, "groupshape.GroupShapeBooleanProperties" ); // 0x03BF;
addProp(m, GROUPSHAPE__EDITEDWRAP, "groupshape.editedwrap");
addProp(m, GROUPSHAPE__BEHINDDOCUMENT, "groupshape.behinddocument");
addProp(m, GROUPSHAPE__ONDBLCLICKNOTIFY, "groupshape.ondblclicknotify");
addProp(m, GROUPSHAPE__ISBUTTON, "groupshape.isbutton");
addProp(m, GROUPSHAPE__1DADJUSTMENT, "groupshape.1dadjustment");
addProp(m, GROUPSHAPE__HIDDEN, "groupshape.hidden");
addProp(m, GROUPSHAPE__PRINT, "groupshape.print", EscherPropertyMetaData.TYPE_BOOLEAN);
return m;
}
private static void addProp(Map<Short, EscherPropertyMetaData> m, int s, String propName) {
m.put((short) s, new EscherPropertyMetaData(propName));
}
private static void addProp(Map<Short, EscherPropertyMetaData> m, int s, String propName, byte type) {
m.put((short) s, new EscherPropertyMetaData(propName, type));
}
public static String getPropertyName(short propertyId) {
EscherPropertyMetaData o = properties.get(propertyId);
return o == null ? "unknown" : o.getDescription();
}
public static byte getPropertyType(short propertyId) {
EscherPropertyMetaData escherPropertyMetaData = properties.get(propertyId);
return escherPropertyMetaData == null ? 0 : escherPropertyMetaData.getType();
} }
} }

View File

@ -17,13 +17,28 @@
package org.apache.poi.ddf; package org.apache.poi.ddf;
import java.util.List;
import java.util.Map;
import java.util.function.Supplier;
import org.apache.poi.common.usermodel.GenericRecord;
import org.apache.poi.util.GenericRecordJsonWriter;
import org.apache.poi.util.GenericRecordUtil;
import org.apache.poi.util.GenericRecordXmlWriter;
/** /**
* This is the abstract base class for all escher properties. * This is the abstract base class for all escher properties.
* *
* @see EscherOptRecord * @see EscherOptRecord
*/ */
public abstract class EscherProperty { public abstract class EscherProperty implements GenericRecord {
private short _id; private final short id;
static final int IS_BLIP = 0x4000;
static final int IS_COMPLEX = 0x8000;
private static final int[] FLAG_MASK = { IS_BLIP, IS_COMPLEX };
private static final String[] FLAG_NAMES = { "IS_BLIP", "IS_COMPLEX" };
/** /**
* The id is distinct from the actual property number. The id includes the property number the blip id * The id is distinct from the actual property number. The id includes the property number the blip id
@ -31,8 +46,8 @@ public abstract class EscherProperty {
* *
* @param id the combined id * @param id the combined id
*/ */
public EscherProperty(short id) { protected EscherProperty(short id) {
_id = id; this.id = id;
} }
/** /**
@ -43,30 +58,44 @@ public abstract class EscherProperty {
* @param isComplex true, if this is a complex property * @param isComplex true, if this is a complex property
* @param isBlipId true, if this property is a blip id * @param isBlipId true, if this property is a blip id
*/ */
public EscherProperty(short propertyNumber, boolean isComplex, boolean isBlipId) { protected EscherProperty(short propertyNumber, boolean isComplex, boolean isBlipId) {
_id = (short)(propertyNumber + this((short)(propertyNumber |
(isComplex ? 0x8000 : 0x0) + (isComplex ? IS_COMPLEX : 0x0) |
(isBlipId ? 0x4000 : 0x0)); (isBlipId ? IS_BLIP : 0x0)));
}
/**
* Constructs a new escher property. The three parameters are combined to form a property
* id.
*
* @param propertyNumber the property number
* @param isComplex true, if this is a complex property
* @param isBlipId true, if this property is a blip id
*/
protected EscherProperty(EscherPropertyTypes type, boolean isComplex, boolean isBlipId) {
this((short)(type.propNumber |
(isComplex ? IS_COMPLEX : 0) |
(isBlipId ? IS_BLIP : 0)));
} }
public short getId() { public short getId() {
return _id; return id;
} }
public short getPropertyNumber() { public short getPropertyNumber() {
return (short) (_id & (short) 0x3FFF); return (short) (id & 0x3FFF);
} }
public boolean isComplex() { public boolean isComplex() {
return (_id & (short) 0x8000) != 0; return (id & IS_COMPLEX) != 0;
} }
public boolean isBlipId() { public boolean isBlipId() {
return (_id & (short) 0x4000) != 0; return (id & IS_BLIP) != 0;
} }
public String getName() { public String getName() {
return EscherProperties.getPropertyName(getPropertyNumber()); return EscherPropertyTypes.forPropertyID(getPropertyNumber()).propName;
} }
/** /**
@ -79,13 +108,6 @@ public abstract class EscherProperty {
return 6; return 6;
} }
public String toXml(String tab){
StringBuilder builder = new StringBuilder();
builder.append(tab).append("<").append(getClass().getSimpleName()).append(" id=\"").append(getId()).append("\" name=\"").append(getName()).append("\" blipId=\"")
.append(isBlipId()).append("\"/>\n");
return builder.toString();
}
/** /**
* Escher properties consist of a simple fixed length part and a complex variable length part. * Escher properties consist of a simple fixed length part and a complex variable length part.
* The fixed length part is serialized first. * The fixed length part is serialized first.
@ -110,5 +132,32 @@ public abstract class EscherProperty {
@Override @Override
abstract public String toString(); public final String toString() {
return GenericRecordJsonWriter.marshal(this);
}
public final String toXml(String tab){
return GenericRecordXmlWriter.marshal(this);
}
@Override
public Map<String, Supplier<?>> getGenericProperties() {
return GenericRecordUtil.getGenericProperties(
"id", this::getId,
"name", this::getName,
"propertyNumber", this::getPropertyNumber,
"propertySize", this::getPropertySize,
"flags", GenericRecordUtil.getBitsAsString(this::getId, FLAG_MASK, FLAG_NAMES)
);
}
@Override
public List<? extends GenericRecord> getGenericChildren() {
return null;
}
@Override
public EscherPropertyTypes getGenericRecordType() {
return EscherPropertyTypes.forPropertyID(id);
}
} }

View File

@ -19,8 +19,8 @@ package org.apache.poi.ddf;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
import java.util.function.BiFunction;
import org.apache.poi.util.IOUtils;
import org.apache.poi.util.LittleEndian; import org.apache.poi.util.LittleEndian;
/** /**
@ -28,9 +28,6 @@ import org.apache.poi.util.LittleEndian;
*/ */
public final class EscherPropertyFactory { public final class EscherPropertyFactory {
//arbitrarily selected; may need to increase
private static final int MAX_RECORD_LENGTH = 100_000_000;
/** /**
* Create new properties from a byte array. * Create new properties from a byte array.
* *
@ -45,57 +42,52 @@ public final class EscherPropertyFactory {
int pos = offset; int pos = offset;
for (int i = 0; i < numProperties; i++) { for (int i = 0; i < numProperties; i++) {
short propId; final short propId = LittleEndian.getShort( data, pos );
int propData; final int propData = LittleEndian.getInt( data, pos + 2 );
propId = LittleEndian.getShort( data, pos ); final boolean isComplex = ( propId & EscherProperty.IS_COMPLEX ) != 0;
propData = LittleEndian.getInt( data, pos + 2 );
short propNumber = (short) ( propId & (short) 0x3FFF );
boolean isComplex = ( propId & (short) 0x8000 ) != 0;
// boolean isBlipId = ( propId & (short) 0x4000 ) != 0;
byte propertyType = EscherProperties.getPropertyType(propNumber); EscherPropertyTypes propertyType = EscherPropertyTypes.forPropertyID(propId);
EscherProperty ep;
switch (propertyType) { final BiFunction<Short,Integer,EscherProperty> con;
case EscherPropertyMetaData.TYPE_BOOLEAN: switch (propertyType.holder) {
ep = new EscherBoolProperty( propId, propData ); case BOOLEAN:
con = EscherBoolProperty::new;
break; break;
case EscherPropertyMetaData.TYPE_RGB: case RGB:
ep = new EscherRGBProperty( propId, propData ); con = EscherRGBProperty::new;
break; break;
case EscherPropertyMetaData.TYPE_SHAPEPATH: case SHAPE_PATH:
ep = new EscherShapePathProperty( propId, propData ); con = EscherShapePathProperty::new;
break; break;
default: default:
if ( !isComplex ) { if ( isComplex ) {
ep = new EscherSimpleProperty( propId, propData ); con = (propertyType.holder == EscherPropertyTypesHolder.ARRAY)
} else if ( propertyType == EscherPropertyMetaData.TYPE_ARRAY) { ? EscherArrayProperty::new
ep = new EscherArrayProperty( propId, IOUtils.safelyAllocate(propData, MAX_RECORD_LENGTH)); : EscherComplexProperty::new;
} else { } else {
ep = new EscherComplexProperty( propId, IOUtils.safelyAllocate(propData, MAX_RECORD_LENGTH)); con = EscherSimpleProperty::new;
} }
break; break;
} }
results.add( ep );
results.add( con.apply(propId,propData) );
pos += 6; pos += 6;
} }
// Get complex data // Get complex data
for (EscherProperty p : results) { for (EscherProperty p : results) {
if (p instanceof EscherComplexProperty) {
if (p instanceof EscherArrayProperty) { if (p instanceof EscherArrayProperty) {
pos += ((EscherArrayProperty)p).setArrayData(data, pos); EscherArrayProperty eap = (EscherArrayProperty)p;
} else { pos += eap.setArrayData(data, pos);
byte[] complexData = ((EscherComplexProperty)p).getComplexData(); } else if (p instanceof EscherComplexProperty) {
EscherComplexProperty ecp = (EscherComplexProperty)p;
int cdLen = ecp.getComplexData().length;
int leftover = data.length - pos; int leftover = data.length - pos;
if (leftover < complexData.length) { if (leftover < cdLen) {
throw new IllegalStateException("Could not read complex escher property, length was " + complexData.length + ", but had only " + throw new IllegalStateException("Could not read complex escher property, length was " +
leftover + " bytes left"); cdLen + ", but had only " + leftover + " bytes left");
}
System.arraycopy(data, pos, complexData, 0, complexData.length);
pos += complexData.length;
} }
pos += ecp.setComplexData(data, pos);
} }
} }
return results; return results;

View File

@ -0,0 +1,376 @@
/* ====================================================================
Licensed to the Apache Software Foundation (ASF) under one or more
contributor license agreements. See the NOTICE file distributed with
this work for additional information regarding copyright ownership.
The ASF licenses this file to You under the Apache License, Version 2.0
(the "License")), you may not use this file except in compliance with
the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
==================================================================== */
package org.apache.poi.ddf;
import java.util.Map;
import java.util.function.Function;
import java.util.stream.Collectors;
import java.util.stream.Stream;
/**
* Provides a list of all known escher properties including the description and type.
*/
public enum EscherPropertyTypes {
TRANSFORM__ROTATION(0x0004, "transform.rotation"),
PROTECTION__LOCKROTATION(0x0077, "protection.lockrotation"),
PROTECTION__LOCKASPECTRATIO(0x0078, "protection.lockaspectratio"),
PROTECTION__LOCKPOSITION(0x0079, "protection.lockposition"),
PROTECTION__LOCKAGAINSTSELECT(0x007a, "protection.lockagainstselect"),
PROTECTION__LOCKCROPPING(0x007b, "protection.lockcropping"),
PROTECTION__LOCKVERTICES(0x007c, "protection.lockvertices"),
PROTECTION__LOCKTEXT(0x007d, "protection.locktext"),
PROTECTION__LOCKADJUSTHANDLES(0x007e, "protection.lockadjusthandles"),
PROTECTION__LOCKAGAINSTGROUPING(0x007f, "protection.lockagainstgrouping", EscherPropertyTypesHolder.BOOLEAN),
TEXT__TEXTID(0x0080, "text.textid"),
TEXT__TEXTLEFT(0x0081, "text.textleft"),
TEXT__TEXTTOP(0x0082, "text.texttop"),
TEXT__TEXTRIGHT(0x0083, "text.textright"),
TEXT__TEXTBOTTOM(0x0084, "text.textbottom"),
TEXT__WRAPTEXT(0x0085, "text.wraptext"),
TEXT__SCALETEXT(0x0086, "text.scaletext"),
TEXT__ANCHORTEXT(0x0087, "text.anchortext"),
TEXT__TEXTFLOW(0x0088, "text.textflow"),
TEXT__FONTROTATION(0x0089, "text.fontrotation"),
TEXT__IDOFNEXTSHAPE(0x008a, "text.idofnextshape"),
TEXT__BIDIR(0x008b, "text.bidir"),
TEXT__SINGLECLICKSELECTS(0x00bb, "text.singleclickselects"),
TEXT__USEHOSTMARGINS(0x00bc, "text.usehostmargins"),
TEXT__ROTATETEXTWITHSHAPE(0x00bd, "text.rotatetextwithshape"),
TEXT__SIZESHAPETOFITTEXT(0x00be, "text.sizeshapetofittext"),
TEXT__SIZE_TEXT_TO_FIT_SHAPE(0x00bf, "text.sizetexttofitshape", EscherPropertyTypesHolder.BOOLEAN),
GEOTEXT__UNICODE(0x00c0, "geotext.unicode"),
GEOTEXT__RTFTEXT(0x00c1, "geotext.rtftext"),
GEOTEXT__ALIGNMENTONCURVE(0x00c2, "geotext.alignmentoncurve"),
GEOTEXT__DEFAULTPOINTSIZE(0x00c3, "geotext.defaultpointsize"),
GEOTEXT__TEXTSPACING(0x00c4, "geotext.textspacing"),
GEOTEXT__FONTFAMILYNAME(0x00c5, "geotext.fontfamilyname"),
GEOTEXT__REVERSEROWORDER(0x00f0, "geotext.reverseroworder"),
GEOTEXT__HASTEXTEFFECT(0x00f1, "geotext.hastexteffect"),
GEOTEXT__ROTATECHARACTERS(0x00f2, "geotext.rotatecharacters"),
GEOTEXT__KERNCHARACTERS(0x00f3, "geotext.kerncharacters"),
GEOTEXT__TIGHTORTRACK(0x00f4, "geotext.tightortrack"),
GEOTEXT__STRETCHTOFITSHAPE(0x00f5, "geotext.stretchtofitshape"),
GEOTEXT__CHARBOUNDINGBOX(0x00f6, "geotext.charboundingbox"),
GEOTEXT__SCALETEXTONPATH(0x00f7, "geotext.scaletextonpath"),
GEOTEXT__STRETCHCHARHEIGHT(0x00f8, "geotext.stretchcharheight"),
GEOTEXT__NOMEASUREALONGPATH(0x00f9, "geotext.nomeasurealongpath"),
GEOTEXT__BOLDFONT(0x00fa, "geotext.boldfont"),
GEOTEXT__ITALICFONT(0x00fb, "geotext.italicfont"),
GEOTEXT__UNDERLINEFONT(0x00fc, "geotext.underlinefont"),
GEOTEXT__SHADOWFONT(0x00fd, "geotext.shadowfont"),
GEOTEXT__SMALLCAPSFONT(0x00fe, "geotext.smallcapsfont"),
GEOTEXT__STRIKETHROUGHFONT(0x00ff, "geotext.strikethroughfont"),
BLIP__CROPFROMTOP(0x0100, "blip.cropfromtop"),
BLIP__CROPFROMBOTTOM(0x0101, "blip.cropfrombottom"),
BLIP__CROPFROMLEFT(0x0102, "blip.cropfromleft"),
BLIP__CROPFROMRIGHT(0x0103, "blip.cropfromright"),
BLIP__BLIPTODISPLAY(0x0104, "blip.bliptodisplay"),
BLIP__BLIPFILENAME(0x0105, "blip.blipfilename"),
BLIP__BLIPFLAGS(0x0106, "blip.blipflags"),
BLIP__TRANSPARENTCOLOR(0x0107, "blip.transparentcolor"),
BLIP__CONTRASTSETTING(0x0108, "blip.contrastsetting"),
BLIP__BRIGHTNESSSETTING(0x0109, "blip.brightnesssetting"),
BLIP__GAMMA(0x010a, "blip.gamma"),
BLIP__PICTUREID(0x010b, "blip.pictureid"),
BLIP__DOUBLEMOD(0x010c, "blip.doublemod"),
BLIP__PICTUREFILLMOD(0x010d, "blip.picturefillmod"),
BLIP__PICTURELINE(0x010e, "blip.pictureline"),
BLIP__PRINTBLIP(0x010f, "blip.printblip"),
BLIP__PRINTBLIPFILENAME(0x0110, "blip.printblipfilename"),
BLIP__PRINTFLAGS(0x0111, "blip.printflags"),
BLIP__NOHITTESTPICTURE(0x013c, "blip.nohittestpicture"),
BLIP__PICTUREGRAY(0x013d, "blip.picturegray"),
BLIP__PICTUREBILEVEL(0x013e, "blip.picturebilevel"),
BLIP__PICTUREACTIVE(0x013f, "blip.pictureactive"),
GEOMETRY__LEFT(0x0140, "geometry.left"),
GEOMETRY__TOP(0x0141, "geometry.top"),
GEOMETRY__RIGHT(0x0142, "geometry.right"),
GEOMETRY__BOTTOM(0x0143, "geometry.bottom"),
GEOMETRY__SHAPEPATH(0x0144, "geometry.shapepath", EscherPropertyTypesHolder.SHAPE_PATH),
GEOMETRY__VERTICES(0x0145, "geometry.vertices", EscherPropertyTypesHolder.ARRAY),
GEOMETRY__SEGMENTINFO(0x0146, "geometry.segmentinfo", EscherPropertyTypesHolder.ARRAY),
GEOMETRY__ADJUSTVALUE(0x0147, "geometry.adjustvalue"),
GEOMETRY__ADJUST2VALUE(0x0148, "geometry.adjust2value"),
GEOMETRY__ADJUST3VALUE(0x0149, "geometry.adjust3value"),
GEOMETRY__ADJUST4VALUE(0x014a, "geometry.adjust4value"),
GEOMETRY__ADJUST5VALUE(0x014b, "geometry.adjust5value"),
GEOMETRY__ADJUST6VALUE(0x014c, "geometry.adjust6value"),
GEOMETRY__ADJUST7VALUE(0x014d, "geometry.adjust7value"),
GEOMETRY__ADJUST8VALUE(0x014e, "geometry.adjust8value"),
GEOMETRY__ADJUST9VALUE(0x014f, "geometry.adjust9value"),
GEOMETRY__ADJUST10VALUE(0x0150, "geometry.adjust10value"),
GEOMETRY__PCONNECTIONSITES(0x0151, "geometry.pConnectionSites"),
GEOMETRY__PCONNECTIONSITESDIR(0x0152, "geometry.pConnectionSitesDir"),
GEOMETRY__XLIMO(0x0153, "geometry.xLimo"),
GEOMETRY__YLIMO(0x0154, "geometry.yLimo"),
GEOMETRY__PADJUSTHANDLES(0x0155, "geometry.pAdjustHandles"),
GEOMETRY__PGUIDES(0x0156, "geometry.pGuides"),
GEOMETRY__PINSCRIBE(0x0157, "geometry.pInscribe"),
GEOMETRY__CXK(0x0158, "geometry.cxk"),
GEOMETRY__PFRAGMENTS(0x0159, "geometry.pFragments"),
GEOMETRY__SHADOWOK(0x017a, "geometry.shadowOK"),
GEOMETRY__3DOK(0x017b, "geometry.3dok"),
GEOMETRY__LINEOK(0x017c, "geometry.lineok"),
GEOMETRY__GEOTEXTOK(0x017d, "geometry.geotextok"),
GEOMETRY__FILLSHADESHAPEOK(0x017e, "geometry.fillshadeshapeok"),
GEOMETRY__FILLOK(0x017f, "geometry.fillok", EscherPropertyTypesHolder.BOOLEAN),
FILL__FILLTYPE(0x0180, "fill.filltype"),
FILL__FILLCOLOR(0x0181, "fill.fillcolor", EscherPropertyTypesHolder.RGB),
FILL__FILLOPACITY(0x0182, "fill.fillopacity"),
FILL__FILLBACKCOLOR(0x0183, "fill.fillbackcolor", EscherPropertyTypesHolder.RGB),
FILL__BACKOPACITY(0x0184, "fill.backopacity"),
FILL__CRMOD(0x0185, "fill.crmod"),
FILL__PATTERNTEXTURE(0x0186, "fill.patterntexture"),
FILL__BLIPFILENAME(0x0187, "fill.blipfilename"),
FILL__BLIPFLAGS(0x0188, "fill.blipflags"),
FILL__WIDTH(0x0189, "fill.width"),
FILL__HEIGHT(0x018a, "fill.height"),
FILL__ANGLE(0x018b, "fill.angle"),
FILL__FOCUS(0x018c, "fill.focus"),
FILL__TOLEFT(0x018d, "fill.toleft"),
FILL__TOTOP(0x018e, "fill.totop"),
FILL__TORIGHT(0x018f, "fill.toright"),
FILL__TOBOTTOM(0x0190, "fill.tobottom"),
FILL__RECTLEFT(0x0191, "fill.rectleft"),
FILL__RECTTOP(0x0192, "fill.recttop"),
FILL__RECTRIGHT(0x0193, "fill.rectright"),
FILL__RECTBOTTOM(0x0194, "fill.rectbottom"),
FILL__DZTYPE(0x0195, "fill.dztype"),
FILL__SHADEPRESET(0x0196, "fill.shadepreset"),
FILL__SHADECOLORS(0x0197, "fill.shadecolors", EscherPropertyTypesHolder.ARRAY),
FILL__ORIGINX(0x0198, "fill.originx"),
FILL__ORIGINY(0x0199, "fill.originy"),
FILL__SHAPEORIGINX(0x019a, "fill.shapeoriginx"),
FILL__SHAPEORIGINY(0x019b, "fill.shapeoriginy"),
FILL__SHADETYPE(0x019c, "fill.shadetype"),
FILL__FILLED(0x01bb, "fill.filled"),
FILL__HITTESTFILL(0x01bc, "fill.hittestfill"),
FILL__SHAPE(0x01bd, "fill.shape"),
FILL__USERECT(0x01be, "fill.userect"),
FILL__NOFILLHITTEST(0x01bf, "fill.nofillhittest", EscherPropertyTypesHolder.BOOLEAN),
LINESTYLE__COLOR(0x01c0, "linestyle.color", EscherPropertyTypesHolder.RGB),
LINESTYLE__OPACITY(0x01c1, "linestyle.opacity"),
LINESTYLE__BACKCOLOR(0x01c2, "linestyle.backcolor", EscherPropertyTypesHolder.RGB),
LINESTYLE__CRMOD(0x01c3, "linestyle.crmod"),
LINESTYLE__LINETYPE(0x01c4, "linestyle.linetype"),
LINESTYLE__FILLBLIP(0x01c5, "linestyle.fillblip"),
LINESTYLE__FILLBLIPNAME(0x01c6, "linestyle.fillblipname"),
LINESTYLE__FILLBLIPFLAGS(0x01c7, "linestyle.fillblipflags"),
LINESTYLE__FILLWIDTH(0x01c8, "linestyle.fillwidth"),
LINESTYLE__FILLHEIGHT(0x01c9, "linestyle.fillheight"),
LINESTYLE__FILLDZTYPE(0x01ca, "linestyle.filldztype"),
LINESTYLE__LINEWIDTH(0x01cb, "linestyle.linewidth"),
LINESTYLE__LINEMITERLIMIT(0x01cc, "linestyle.linemiterlimit"),
LINESTYLE__LINESTYLE(0x01cd, "linestyle.linestyle"),
LINESTYLE__LINEDASHING(0x01ce, "linestyle.linedashing"),
LINESTYLE__LINEDASHSTYLE(0x01cf, "linestyle.linedashstyle", EscherPropertyTypesHolder.ARRAY),
LINESTYLE__LINESTARTARROWHEAD(0x01d0, "linestyle.linestartarrowhead"),
LINESTYLE__LINEENDARROWHEAD(0x01d1, "linestyle.lineendarrowhead"),
LINESTYLE__LINESTARTARROWWIDTH(0x01d2, "linestyle.linestartarrowwidth"),
LINESTYLE__LINESTARTARROWLENGTH(0x01d3, "linestyle.linestartarrowlength"),
LINESTYLE__LINEENDARROWWIDTH(0x01d4, "linestyle.lineendarrowwidth"),
LINESTYLE__LINEENDARROWLENGTH(0x01d5, "linestyle.lineendarrowlength"),
LINESTYLE__LINEJOINSTYLE(0x01d6, "linestyle.linejoinstyle"),
LINESTYLE__LINEENDCAPSTYLE(0x01d7, "linestyle.lineendcapstyle"),
LINESTYLE__ARROWHEADSOK(0x01fb, "linestyle.arrowheadsok"),
LINESTYLE__ANYLINE(0x01fc, "linestyle.anyline"),
LINESTYLE__HITLINETEST(0x01fd, "linestyle.hitlinetest"),
LINESTYLE__LINEFILLSHAPE(0x01fe, "linestyle.linefillshape"),
LINESTYLE__NOLINEDRAWDASH(0x01ff, "linestyle.nolinedrawdash", EscherPropertyTypesHolder.BOOLEAN),
LINESTYLE__NOLINEDRAWDASH_LEFT(0x057F, "linestyle.nolinedrawdash.left", EscherPropertyTypesHolder.BOOLEAN),
LINESTYLE__NOLINEDRAWDASH_TOP(0x05BF, "linestyle.nolinedrawdash.top", EscherPropertyTypesHolder.BOOLEAN),
LINESTYLE__NOLINEDRAWDASH_BOTTOM(0x063F, "linestyle.nolinedrawdash.bottom", EscherPropertyTypesHolder.BOOLEAN),
LINESTYLE__NOLINEDRAWDASH_RIGHT(0x05FF, "linestyle.nolinedrawdash.right", EscherPropertyTypesHolder.BOOLEAN),
SHADOWSTYLE__TYPE(0x0200, "shadowstyle.type"),
SHADOWSTYLE__COLOR(0x0201, "shadowstyle.color", EscherPropertyTypesHolder.RGB),
SHADOWSTYLE__HIGHLIGHT(0x0202, "shadowstyle.highlight"),
SHADOWSTYLE__CRMOD(0x0203, "shadowstyle.crmod"),
SHADOWSTYLE__OPACITY(0x0204, "shadowstyle.opacity"),
SHADOWSTYLE__OFFSETX(0x0205, "shadowstyle.offsetx"),
SHADOWSTYLE__OFFSETY(0x0206, "shadowstyle.offsety"),
SHADOWSTYLE__SECONDOFFSETX(0x0207, "shadowstyle.secondoffsetx"),
SHADOWSTYLE__SECONDOFFSETY(0x0208, "shadowstyle.secondoffsety"),
SHADOWSTYLE__SCALEXTOX(0x0209, "shadowstyle.scalextox"),
SHADOWSTYLE__SCALEYTOX(0x020a, "shadowstyle.scaleytox"),
SHADOWSTYLE__SCALEXTOY(0x020b, "shadowstyle.scalextoy"),
SHADOWSTYLE__SCALEYTOY(0x020c, "shadowstyle.scaleytoy"),
SHADOWSTYLE__PERSPECTIVEX(0x020d, "shadowstyle.perspectivex"),
SHADOWSTYLE__PERSPECTIVEY(0x020e, "shadowstyle.perspectivey"),
SHADOWSTYLE__WEIGHT(0x020f, "shadowstyle.weight"),
SHADOWSTYLE__ORIGINX(0x0210, "shadowstyle.originx"),
SHADOWSTYLE__ORIGINY(0x0211, "shadowstyle.originy"),
SHADOWSTYLE__SHADOW(0x023e, "shadowstyle.shadow"),
SHADOWSTYLE__SHADOWOBSURED(0x023f, "shadowstyle.shadowobscured"),
PERSPECTIVE__TYPE(0x0240, "perspective.type"),
PERSPECTIVE__OFFSETX(0x0241, "perspective.offsetx"),
PERSPECTIVE__OFFSETY(0x0242, "perspective.offsety"),
PERSPECTIVE__SCALEXTOX(0x0243, "perspective.scalextox"),
PERSPECTIVE__SCALEYTOX(0x0244, "perspective.scaleytox"),
PERSPECTIVE__SCALEXTOY(0x0245, "perspective.scalextoy"),
PERSPECTIVE__SCALEYTOY(0x0246, "perspective.scaleytoy"),
PERSPECTIVE__PERSPECTIVEX(0x0247, "perspective.perspectivex"),
PERSPECTIVE__PERSPECTIVEY(0x0248, "perspective.perspectivey"),
PERSPECTIVE__WEIGHT(0x0249, "perspective.weight"),
PERSPECTIVE__ORIGINX(0x024a, "perspective.originx"),
PERSPECTIVE__ORIGINY(0x024b, "perspective.originy"),
PERSPECTIVE__PERSPECTIVEON(0x027f, "perspective.perspectiveon"),
THREED__SPECULARAMOUNT(0x0280, "3d.specularamount"),
THREED__DIFFUSEAMOUNT(0x0281, "3d.diffuseamount"),
THREED__SHININESS(0x0282, "3d.shininess"),
THREED__EDGETHICKNESS(0x0283, "3d.edgethickness"),
THREED__EXTRUDEFORWARD(0x0284, "3d.extrudeforward"),
THREED__EXTRUDEBACKWARD(0x0285, "3d.extrudebackward"),
RESERVED646(0x0286, "reserved646"),
THREED__EXTRUSIONCOLOR(0x0287, "3d.extrusioncolor", EscherPropertyTypesHolder.RGB),
THREED__CRMOD(0x0288, "3d.crmod"),
THREED__EXTRUSIONCOLOREXT(0x0289, "3d.extrusioncolorext"),
RESERVED650(0x028A, "reserved650"),
THREED__EXTRUSIONCOLOREXTMOD(0x028B, "3d.extrusioncolorextmod"),
RESERVED652(0x028c, "reserved652"),
RESERVED653(0x028d, "reserved653"),
THREED__BOOLEAN_PROPERTIES(0x028f, "3d.booleanproperties"),
THREED__EXTRUDEPLANE(0x029a, "3d.extrudeplane"),
THREED__3DEFFECT(0x02bc, "3d.3deffect"),
THREED__METALLIC(0x02bd, "3d.metallic"),
THREED__USEEXTRUSIONCOLOR(0x02be, "3d.useextrusioncolor", EscherPropertyTypesHolder.RGB),
THREED__LIGHTFACE(0x02bf, "3d.lightface"),
THREEDSTYLE__YROTATIONANGLE(0x02c0, "3dstyle.yrotationangle"),
THREEDSTYLE__XROTATIONANGLE(0x02c1, "3dstyle.xrotationangle"),
THREEDSTYLE__ROTATIONAXISX(0x02c2, "3dstyle.rotationaxisx"),
THREEDSTYLE__ROTATIONAXISY(0x02c3, "3dstyle.rotationaxisy"),
THREEDSTYLE__ROTATIONAXISZ(0x02c4, "3dstyle.rotationaxisz"),
THREEDSTYLE__ROTATIONANGLE(0x02c5, "3dstyle.rotationangle"),
THREEDSTYLE__ROTATIONCENTERX(0x02c6, "3dstyle.rotationcenterx"),
THREEDSTYLE__ROTATIONCENTERY(0x02c7, "3dstyle.rotationcentery"),
THREEDSTYLE__ROTATIONCENTERZ(0x02c8, "3dstyle.rotationcenterz"),
THREEDSTYLE__RENDERMODE(0x02c9, "3dstyle.rendermode"),
THREEDSTYLE__TOLERANCE(0x02ca, "3dstyle.tolerance"),
THREEDSTYLE__XVIEWPOINT(0x02cb, "3dstyle.xviewpoint"),
THREEDSTYLE__YVIEWPOINT(0x02cc, "3dstyle.yviewpoint"),
THREEDSTYLE__ZVIEWPOINT(0x02cd, "3dstyle.zviewpoint"),
THREEDSTYLE__ORIGINX(0x02ce, "3dstyle.originx"),
THREEDSTYLE__ORIGINY(0x02cf, "3dstyle.originy"),
THREEDSTYLE__SKEWANGLE(0x02d0, "3dstyle.skewangle"),
THREEDSTYLE__SKEWAMOUNT(0x02d1, "3dstyle.skewamount"),
THREEDSTYLE__AMBIENTINTENSITY(0x02d2, "3dstyle.ambientintensity"),
THREEDSTYLE__KEYX(0x02d3, "3dstyle.keyx"),
THREEDSTYLE__KEYY(0x02d4, "3dstyle.keyy"),
THREEDSTYLE__KEYZ(0x02d5, "3dstyle.keyz"),
THREEDSTYLE__KEYINTENSITY(0x02d6, "3dstyle.keyintensity"),
THREEDSTYLE__FILLX(0x02d7, "3dstyle.fillx"),
THREEDSTYLE__FILLY(0x02d8, "3dstyle.filly"),
THREEDSTYLE__FILLZ(0x02d9, "3dstyle.fillz"),
THREEDSTYLE__FILLINTENSITY(0x02da, "3dstyle.fillintensity"),
THREEDSTYLE__CONSTRAINROTATION(0x02fb, "3dstyle.constrainrotation"),
THREEDSTYLE__ROTATIONCENTERAUTO(0x02fc, "3dstyle.rotationcenterauto"),
THREEDSTYLE__PARALLEL(0x02fd, "3dstyle.parallel"),
THREEDSTYLE__KEYHARSH(0x02fe, "3dstyle.keyharsh"),
THREEDSTYLE__FILLHARSH(0x02ff, "3dstyle.fillharsh"),
SHAPE__MASTER(0x0301, "shape.master"),
SHAPE__CONNECTORSTYLE(0x0303, "shape.connectorstyle"),
SHAPE__BLACKANDWHITESETTINGS(0x0304, "shape.blackandwhitesettings"),
SHAPE__WMODEPUREBW(0x0305, "shape.wmodepurebw"),
SHAPE__WMODEBW(0x0306, "shape.wmodebw"),
SHAPE__OLEICON(0x033a, "shape.oleicon"),
SHAPE__PREFERRELATIVERESIZE(0x033b, "shape.preferrelativeresize"),
SHAPE__LOCKSHAPETYPE(0x033c, "shape.lockshapetype"),
SHAPE__DELETEATTACHEDOBJECT(0x033e, "shape.deleteattachedobject"),
SHAPE__BACKGROUNDSHAPE(0x033f, "shape.backgroundshape"),
CALLOUT__CALLOUTTYPE(0x0340, "callout.callouttype"),
CALLOUT__XYCALLOUTGAP(0x0341, "callout.xycalloutgap"),
CALLOUT__CALLOUTANGLE(0x0342, "callout.calloutangle"),
CALLOUT__CALLOUTDROPTYPE(0x0343, "callout.calloutdroptype"),
CALLOUT__CALLOUTDROPSPECIFIED(0x0344, "callout.calloutdropspecified"),
CALLOUT__CALLOUTLENGTHSPECIFIED(0x0345, "callout.calloutlengthspecified"),
CALLOUT__ISCALLOUT(0x0379, "callout.iscallout"),
CALLOUT__CALLOUTACCENTBAR(0x037a, "callout.calloutaccentbar"),
CALLOUT__CALLOUTTEXTBORDER(0x037b, "callout.callouttextborder"),
CALLOUT__CALLOUTMINUSX(0x037c, "callout.calloutminusx"),
CALLOUT__CALLOUTMINUSY(0x037d, "callout.calloutminusy"),
CALLOUT__DROPAUTO(0x037e, "callout.dropauto"),
CALLOUT__LENGTHSPECIFIED(0x037f, "callout.lengthspecified"),
GROUPSHAPE__SHAPENAME(0x0380, "groupshape.shapename"),
GROUPSHAPE__DESCRIPTION(0x0381, "groupshape.description"),
GROUPSHAPE__HYPERLINK(0x0382, "groupshape.hyperlink"),
GROUPSHAPE__WRAPPOLYGONVERTICES(0x0383, "groupshape.wrappolygonvertices", EscherPropertyTypesHolder.ARRAY),
GROUPSHAPE__WRAPDISTLEFT(0x0384, "groupshape.wrapdistleft"),
GROUPSHAPE__WRAPDISTTOP(0x0385, "groupshape.wrapdisttop"),
GROUPSHAPE__WRAPDISTRIGHT(0x0386, "groupshape.wrapdistright"),
GROUPSHAPE__WRAPDISTBOTTOM(0x0387, "groupshape.wrapdistbottom"),
GROUPSHAPE__REGROUPID(0x0388, "groupshape.regroupid"),
GROUPSHAPE__UNUSED906(0x038A, "unused906"),
GROUPSHAPE__TOOLTIP(0x038D, "groupshape.wzTooltip"),
GROUPSHAPE__SCRIPT(0x038E, "groupshape.wzScript"),
GROUPSHAPE__POSH(0x038F, "groupshape.posh"),
GROUPSHAPE__POSRELH(0x0390, "groupshape.posrelh"),
GROUPSHAPE__POSV(0x0391, "groupshape.posv"),
GROUPSHAPE__POSRELV(0x0392, "groupshape.posrelv"),
GROUPSHAPE__HR_PCT(0x0393, "groupshape.pctHR"),
GROUPSHAPE__HR_ALIGN(0x0394, "groupshape.alignHR"),
GROUPSHAPE__HR_HEIGHT(0x0395, "groupshape.dxHeightHR"),
GROUPSHAPE__HR_WIDTH(0x0396, "groupshape.dxWidthHR"),
GROUPSHAPE__SCRIPTEXT(0x0397, "groupshape.wzScriptExtAttr"),
GROUPSHAPE__SCRIPTLANG(0x0398, "groupshape.scriptLang"),
GROUPSHAPE__BORDERTOPCOLOR(0x039B, "groupshape.borderTopColor"),
GROUPSHAPE__BORDERLEFTCOLOR(0x039C, "groupshape.borderLeftColor"),
GROUPSHAPE__BORDERBOTTOMCOLOR(0x039D, "groupshape.borderBottomColor"),
GROUPSHAPE__BORDERRIGHTCOLOR(0x039E, "groupshape.borderRightColor"),
GROUPSHAPE__TABLEPROPERTIES(0x039F, "groupshape.tableProperties"),
GROUPSHAPE__TABLEROWPROPERTIES(0x03A0, "groupshape.tableRowProperties", EscherPropertyTypesHolder.ARRAY),
GROUPSHAPE__WEBBOT(0x03A5, "groupshape.wzWebBot"),
GROUPSHAPE__METROBLOB(0x03A9, "groupshape.metroBlob"),
GROUPSHAPE__ZORDER(0x03AA, "groupshape.dhgt"),
GROUPSHAPE__EDITEDWRAP(0x03b9, "groupshape.editedwrap"),
GROUPSHAPE__BEHINDDOCUMENT(0x03ba, "groupshape.behinddocument"),
GROUPSHAPE__ONDBLCLICKNOTIFY(0x03bb, "groupshape.ondblclicknotify"),
GROUPSHAPE__ISBUTTON(0x03bc, "groupshape.isbutton"),
GROUPSHAPE__1DADJUSTMENT(0x03bd, "groupshape.1dadjustment"),
GROUPSHAPE__HIDDEN(0x03be, "groupshape.hidden"),
GROUPSHAPE__FLAGS(0x03bf, "groupshape.groupShapeBooleanProperties"),
UNKNOWN(0xffff, "unknown")
;
/** the property number part of the property id, i.e. the id without is_blip/is_complex flag */
public final short propNumber;
public final String propName;
public final EscherPropertyTypesHolder holder;
EscherPropertyTypes(int propNumber, String name) {
this(propNumber, name, EscherPropertyTypesHolder.UNKNOWN);
}
EscherPropertyTypes(int propNumber, String propName, EscherPropertyTypesHolder holder) {
this.propNumber = (short) propNumber;
this.propName = propName;
this.holder = holder;
}
public short getPropertyId() {
return propNumber;
}
private static final Map<Short, EscherPropertyTypes> LOOKUP =
Stream.of(values()).collect(Collectors.toMap(EscherPropertyTypes::getPropertyId, Function.identity()));
public static EscherPropertyTypes forPropertyID(int propertyId) {
EscherPropertyTypes rt = LOOKUP.get((short)(propertyId & 0x3FFF));
return (rt != null) ? rt : EscherPropertyTypes.UNKNOWN;
}
}

View File

@ -0,0 +1,30 @@
/* ====================================================================
Licensed to the Apache Software Foundation (ASF) under one or more
contributor license agreements. See the NOTICE file distributed with
this work for additional information regarding copyright ownership.
The ASF licenses this file to You under the Apache License, Version 2.0
(the "License"); you may not use this file except in compliance with
the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
==================================================================== */
package org.apache.poi.ddf;
import org.apache.poi.util.Internal;
@Internal
public enum EscherPropertyTypesHolder {
UNKNOWN,
BOOLEAN,
RGB,
SHAPE_PATH,
SIMPLE,
ARRAY
}

View File

@ -17,8 +17,6 @@
package org.apache.poi.ddf; package org.apache.poi.ddf;
import org.apache.poi.util.HexDump;
/** /**
* A color property. * A color property.
*/ */
@ -26,11 +24,27 @@ public class EscherRGBProperty
extends EscherSimpleProperty extends EscherSimpleProperty
{ {
public EscherRGBProperty( short propertyNumber, int rgbColor ) /**
{ * Create an instance of an escher boolean property.
*
* @param propertyNumber The property number (or id)
* @param rgbColor The 24 bit value of this rgb property
*/
public EscherRGBProperty( short propertyNumber, int rgbColor ) {
super( propertyNumber, rgbColor ); super( propertyNumber, rgbColor );
} }
/**
* Create an instance of an escher boolean property.
*
* @param propertyNumber The property type
* @param rgbColor The 24 bit value of this rgb property
*/
public EscherRGBProperty( EscherPropertyTypes propertyType, int rgbColor ) {
super(propertyType.propNumber, rgbColor );
}
/** /**
* @return the rgb color as int value * @return the rgb color as int value
*/ */
@ -62,13 +76,4 @@ public class EscherRGBProperty
{ {
return (byte) ( (getRgbColor() >> 16) & 0xFF ); return (byte) ( (getRgbColor() >> 16) & 0xFF );
} }
@Override
public String toXml(String tab){
StringBuilder builder = new StringBuilder();
builder.append(tab).append("<").append(getClass().getSimpleName()).append(" id=\"0x").append(HexDump.toHex(getId()))
.append("\" name=\"").append(getName()).append("\" blipId=\"")
.append(isBlipId()).append("\" value=\"0x").append(HexDump.toHex(getRgbColor())).append("\"/>");
return builder.toString();
}
} }

View File

@ -27,8 +27,9 @@ import java.util.function.Supplier;
import org.apache.poi.common.usermodel.GenericRecord; import org.apache.poi.common.usermodel.GenericRecord;
import org.apache.poi.util.BitField; import org.apache.poi.util.BitField;
import org.apache.poi.util.BitFieldFactory; import org.apache.poi.util.BitFieldFactory;
import org.apache.poi.util.GenericRecordJsonWriter;
import org.apache.poi.util.GenericRecordUtil; import org.apache.poi.util.GenericRecordUtil;
import org.apache.poi.util.HexDump; import org.apache.poi.util.GenericRecordXmlWriter;
import org.apache.poi.util.Internal; import org.apache.poi.util.Internal;
import org.apache.poi.util.LittleEndian; import org.apache.poi.util.LittleEndian;
@ -321,188 +322,12 @@ public abstract class EscherRecord implements Cloneable, GenericRecord {
* @return xml representation of this record * @return xml representation of this record
*/ */
public final String toXml(String tab){ public final String toXml(String tab){
final String nl = System.getProperty( "line.separator" ); return GenericRecordXmlWriter.marshal(this);
String clsNm = getClass().getSimpleName();
StringBuilder sb = new StringBuilder(1000);
sb.append(tab).append("<").append(clsNm)
.append(" recordId=\"0x").append(HexDump.toHex(getRecordId()))
.append("\" version=\"0x").append(HexDump.toHex(getVersion()))
.append("\" instance=\"0x").append(HexDump.toHex(getInstance()))
.append("\" options=\"0x").append(HexDump.toHex(getOptions()))
.append("\" recordSize=\"").append(getRecordSize());
Object[][] attrList = getAttributeMap();
if (attrList == null || attrList.length == 0) {
sb.append("\" />").append(nl);
} else {
sb.append("\">").append(nl);
String childTab = tab+" ";
for (Object[] attrs : attrList) {
String tagName = capitalizeAndTrim((String)attrs[0]);
boolean hasValue = false;
boolean lastChildComplex = false;
for (int i=0; i<attrs.length-1; i+=2) {
Object value = attrs[i+1];
if (value == null) {
// ignore null values
continue;
}
if (!hasValue) {
// only add tagname, when there was a value
sb.append(childTab).append("<").append(tagName).append(">");
}
// add names for optional attributes
String optName = capitalizeAndTrim((String)attrs[i+0]);
if (i>0) {
sb.append(nl).append(childTab).append(" <").append(optName).append(">");
}
lastChildComplex = appendValue(sb, value, true, childTab);
if (i>0) {
sb.append(nl).append(childTab).append(" </").append(optName).append(">");
}
hasValue = true;
}
if (hasValue) {
if (lastChildComplex) {
sb.append(nl).append(childTab);
}
sb.append("</").append(tagName).append(">").append(nl);
}
}
sb.append(tab).append("</").append(clsNm).append(">");
}
return sb.toString();
} }
@Override @Override
public final String toString() { public final String toString() {
final String nl = System.getProperty( "line.separator" ); return GenericRecordJsonWriter.marshal(this);
StringBuilder sb = new StringBuilder(1000);
sb.append(getClass().getName()).append(" (").append(getRecordName()).append("):").append(nl)
.append(" RecordId: 0x").append(HexDump.toHex( getRecordId() )).append(nl)
.append(" Version: 0x").append(HexDump.toHex( getVersion() )).append(nl)
.append(" Instance: 0x").append(HexDump.toHex( getInstance() )).append(nl)
.append(" Options: 0x").append(HexDump.toHex( getOptions() )).append(nl)
.append(" Record Size: ").append( getRecordSize() );
Object[][] attrList = getAttributeMap();
if (attrList != null && attrList.length > 0) {
String childTab = " ";
for (Object[] attrs : attrList) {
for (int i=0; i<attrs.length-1; i+=2) {
Object value = attrs[i+1];
if (value == null) {
// ignore null values
continue;
}
String name = (String)attrs[i+0];
sb.append(nl).append(childTab).append(name).append(": ");
appendValue(sb, value, false, childTab);
}
}
}
return sb.toString();
}
/**
* @return true, if value was a complex record, false otherwise
*/
private static boolean appendValue(StringBuilder sb, Object value, boolean toXML, String childTab) {
final String nl = System.getProperty( "line.separator" );
boolean isComplex = false;
if (value instanceof String) {
if (toXML) {
escapeXML((String)value, sb);
} else {
sb.append((String)value);
}
} else if (value instanceof Byte) {
sb.append("0x").append(HexDump.toHex((Byte)value));
} else if (value instanceof Short) {
sb.append("0x").append(HexDump.toHex((Short)value));
} else if (value instanceof Integer) {
sb.append("0x").append(HexDump.toHex((Integer)value));
} else if (value instanceof byte[]) {
sb.append(nl).append(HexDump.toHex((byte[])value, 32).replaceAll("(?m)^",childTab+" "));
} else if (value instanceof Boolean) {
sb.append(((Boolean)value).booleanValue());
} else if (value instanceof EscherRecord) {
EscherRecord er = (EscherRecord)value;
if (toXML) {
sb.append(nl).append(er.toXml(childTab+" "));
} else {
sb.append(er.toString().replaceAll("(?m)^",childTab));
}
isComplex = true;
} else if (value instanceof EscherProperty) {
EscherProperty ep = (EscherProperty)value;
if (toXML) {
sb.append(nl).append(ep.toXml(childTab+" "));
} else {
sb.append(ep.toString().replaceAll("(?m)^",childTab));
}
isComplex = true;
} else {
throw new IllegalArgumentException("unknown attribute type "+value.getClass().getSimpleName());
}
return isComplex;
}
/**
* For the purpose of providing toString() and toXml() a subclass can either override those methods
* or provide a Object[][] array in the form {@code { { "Attribute Name (Header)", value, "optional attribute", value }, ... } }.<p>
*
* Null values won't be printed.<p>
*
* The attributes record, version, instance, options must not be returned.
*
* @return the attribute map
*
* @since POI 3.17-beta2
*/
@Internal
protected abstract Object[][] getAttributeMap();
private static String capitalizeAndTrim(final String str) {
if (str == null || str.length() == 0) {
return str;
}
StringBuilder sb = new StringBuilder(str.length());
boolean capitalizeNext = true;
for (char ch : str.toCharArray()) {
if (!Character.isLetterOrDigit(ch)) {
capitalizeNext = true;
continue;
}
if (capitalizeNext) {
if (!Character.isLetter(ch)) {
sb.append('_');
} else {
ch = Character.toTitleCase(ch);
}
capitalizeNext = false;
}
sb.append(ch);
}
return sb.toString();
}
private static void escapeXML(String s, StringBuilder out) {
if (s == null || s.isEmpty()) {
return;
}
for (char c : s.toCharArray()) {
if (c > 127 || c == '"' || c == '<' || c == '>' || c == '&') {
out.append("&#");
out.append((int) c);
out.append(';');
} else {
out.append(c);
}
}
} }
@Override @Override

View File

@ -19,8 +19,6 @@ package org.apache.poi.ddf;
/** /**
* Defines the constants for the various possible shape paths. * Defines the constants for the various possible shape paths.
*
* @author Glen Stampoultzis (glens at apache.org)
*/ */
public class EscherShapePathProperty extends EscherSimpleProperty { public class EscherShapePathProperty extends EscherSimpleProperty {
@ -30,8 +28,17 @@ public class EscherShapePathProperty extends EscherSimpleProperty {
public static final int CLOSED_CURVES = 3; public static final int CLOSED_CURVES = 3;
public static final int COMPLEX = 4; public static final int COMPLEX = 4;
public EscherShapePathProperty( short propertyNumber, int shapePath ) /**
{ * Create an instance of an escher shape path property.
*
* @param propertyNumber
* @param shapePath
*/
public EscherShapePathProperty( short propertyNumber, int shapePath ) {
super( propertyNumber, false, false, shapePath ); super( propertyNumber, false, false, shapePath );
} }
public EscherShapePathProperty( EscherPropertyTypes type, int shapePath ) {
super( type, false, false, shapePath );
}
} }

View File

@ -17,7 +17,10 @@
package org.apache.poi.ddf; package org.apache.poi.ddf;
import org.apache.poi.util.HexDump; import java.util.Map;
import java.util.function.Supplier;
import org.apache.poi.util.GenericRecordUtil;
import org.apache.poi.util.LittleEndian; import org.apache.poi.util.LittleEndian;
/** /**
@ -36,12 +39,35 @@ public class EscherSimpleProperty extends EscherProperty
* @param id the property id * @param id the property id
* @param propertyValue the property value * @param propertyValue the property value
*/ */
public EscherSimpleProperty( short id, int propertyValue ) public EscherSimpleProperty( short id, int propertyValue ) {
{
super( id ); super( id );
this.propertyValue = propertyValue; this.propertyValue = propertyValue;
} }
/**
* The id is distinct from the actual property number. The id includes the property number the blip id
* flag and an indicator whether the property is complex or not.
*
* @param type the property type
* @param propertyValue the property value
*/
public EscherSimpleProperty( EscherPropertyTypes type, int propertyValue ) {
this(type, false, false, propertyValue);
}
/**
* Constructs a new escher property. The three parameters are combined to form a property id.
*
* @param propertyNumber the property number
* @param isComplex true, if its a complex property
* @param isBlipId true, if its a blip
* @param propertyValue the property value
*/
public EscherSimpleProperty( short propertyNumber, boolean isComplex, boolean isBlipId, int propertyValue ) {
super( propertyNumber, isComplex, isBlipId );
this.propertyValue = propertyValue;
}
/** /**
* Constructs a new escher property. The three parameters are combined to form a property id. * Constructs a new escher property. The three parameters are combined to form a property id.
* *
@ -50,9 +76,8 @@ public class EscherSimpleProperty extends EscherProperty
* @param isBlipId true, if its a blip * @param isBlipId true, if its a blip
* @param propertyValue the property value * @param propertyValue the property value
*/ */
public EscherSimpleProperty( short propertyNumber, boolean isComplex, boolean isBlipId, int propertyValue ) public EscherSimpleProperty( EscherPropertyTypes type, boolean isComplex, boolean isBlipId, int propertyValue ) {
{ super( type, isComplex, isBlipId );
super( propertyNumber, isComplex, isBlipId );
this.propertyValue = propertyValue; this.propertyValue = propertyValue;
} }
@ -122,27 +147,11 @@ public class EscherSimpleProperty extends EscherProperty
return propertyValue; return propertyValue;
} }
/**
* @return the string representation of this property.
*/
@Override @Override
public String toString() public Map<String, Supplier<?>> getGenericProperties() {
{ return GenericRecordUtil.getGenericProperties(
return "propNum: " + getPropertyNumber() "base", super::getGenericProperties,
+ ", RAW: 0x" + HexDump.toHex( getId() ) "value", this::getPropertyValue
+ ", propName: " + EscherProperties.getPropertyName( getPropertyNumber() ) );
+ ", complex: " + isComplex()
+ ", blipId: " + isBlipId()
+ ", value: " + propertyValue + " (0x" + HexDump.toHex(propertyValue) + ")";
}
@Override
public String toXml(String tab){
StringBuilder builder = new StringBuilder();
builder.append(tab).append("<").append(getClass().getSimpleName()).append(" id=\"0x").append(HexDump.toHex(getId()))
.append("\" name=\"").append(getName()).append("\" blipId=\"")
.append(isBlipId()).append("\" complex=\"").append(isComplex()).append("\" value=\"").append("0x")
.append(HexDump.toHex(propertyValue)).append("\"/>");
return builder.toString();
} }
} }

View File

@ -23,7 +23,6 @@ import java.util.Map;
import java.util.function.Supplier; import java.util.function.Supplier;
import org.apache.poi.util.GenericRecordUtil; import org.apache.poi.util.GenericRecordUtil;
import org.apache.poi.util.HexDump;
import org.apache.poi.util.LittleEndian; import org.apache.poi.util.LittleEndian;
/** /**
@ -247,15 +246,6 @@ public class EscherSpRecord extends EscherRecord {
setInstance( value ); setInstance( value );
} }
@Override
protected Object[][] getAttributeMap() {
return new Object[][] {
{ "ShapeType", getShapeType() },
{ "ShapeId", field_1_shapeId },
{ "Flags", decodeFlags(field_2_flags)+" (0x"+HexDump.toHex(field_2_flags)+")" }
};
}
@Override @Override
public Map<String, Supplier<?>> getGenericProperties() { public Map<String, Supplier<?>> getGenericProperties() {
return GenericRecordUtil.getGenericProperties( return GenericRecordUtil.getGenericProperties(

View File

@ -167,16 +167,6 @@ public class EscherSpgrRecord extends EscherRecord {
this.field_4_rectY2 = rectY2; this.field_4_rectY2 = rectY2;
} }
@Override
protected Object[][] getAttributeMap() {
return new Object[][] {
{ "RectX", field_1_rectX1 },
{ "RectY", field_2_rectY1 },
{ "RectWidth", field_3_rectX2 },
{ "RectHeight", field_4_rectY2 }
};
}
@Override @Override
public Map<String, Supplier<?>> getGenericProperties() { public Map<String, Supplier<?>> getGenericProperties() {
return GenericRecordUtil.getGenericProperties( return GenericRecordUtil.getGenericProperties(

View File

@ -158,16 +158,6 @@ public class EscherSplitMenuColorsRecord extends EscherRecord {
this.field_4_color4 = field_4_color4; this.field_4_color4 = field_4_color4;
} }
@Override
protected Object[][] getAttributeMap() {
return new Object[][] {
{ "Color1", field_1_color1 },
{ "Color2", field_2_color2 },
{ "Color3", field_3_color3 },
{ "Color4", field_4_color4 }
};
}
@Override @Override
public Map<String, Supplier<?>> getGenericProperties() { public Map<String, Supplier<?>> getGenericProperties() {
return GenericRecordUtil.getGenericProperties( return GenericRecordUtil.getGenericProperties(

View File

@ -17,8 +17,6 @@
package org.apache.poi.ddf; package org.apache.poi.ddf;
import java.util.ArrayList;
import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.function.Supplier; import java.util.function.Supplier;
@ -139,24 +137,6 @@ public final class EscherTextboxRecord extends EscherRecord implements Cloneable
return EscherRecordTypes.CLIENT_TEXTBOX.recordName; return EscherRecordTypes.CLIENT_TEXTBOX.recordName;
} }
@Override
protected Object[][] getAttributeMap() {
int numCh = getChildRecords().size();
List<Object> chLst = new ArrayList<>(numCh * 2 + 2);
chLst.add("children");
chLst.add(numCh);
for (EscherRecord er : getChildRecords()) {
chLst.add(er.getRecordName());
chLst.add(er);
}
return new Object[][] {
{ "isContainer", isContainerRecord() },
chLst.toArray(),
{ "Extra Data", thedata }
};
}
@Override @Override
public Enum getGenericRecordType() { public Enum getGenericRecordType() {
return EscherRecordTypes.CLIENT_TEXTBOX; return EscherRecordTypes.CLIENT_TEXTBOX;

View File

@ -144,24 +144,6 @@ public final class UnknownEscherRecord extends EscherRecord implements Cloneable
getChildRecords().add( childRecord ); getChildRecords().add( childRecord );
} }
@Override
protected Object[][] getAttributeMap() {
int numCh = getChildRecords().size();
List<Object> chLst = new ArrayList<>(numCh * 2 + 2);
chLst.add("children");
chLst.add(numCh);
for (EscherRecord er : _childRecords) {
chLst.add(er.getRecordName());
chLst.add(er);
}
return new Object[][] {
{ "isContainer", isContainerRecord() },
chLst.toArray(),
{ "Extra Data", thedata }
};
}
@Override @Override
public Map<String, Supplier<?>> getGenericProperties() { public Map<String, Supplier<?>> getGenericProperties() {
return GenericRecordUtil.getGenericProperties( return GenericRecordUtil.getGenericProperties(

View File

@ -32,56 +32,14 @@ import org.apache.poi.ddf.EscherContainerRecord;
import org.apache.poi.ddf.EscherDgRecord; import org.apache.poi.ddf.EscherDgRecord;
import org.apache.poi.ddf.EscherDggRecord; import org.apache.poi.ddf.EscherDggRecord;
import org.apache.poi.ddf.EscherOptRecord; import org.apache.poi.ddf.EscherOptRecord;
import org.apache.poi.ddf.EscherProperties; import org.apache.poi.ddf.EscherPropertyTypes;
import org.apache.poi.ddf.EscherRGBProperty; import org.apache.poi.ddf.EscherRGBProperty;
import org.apache.poi.ddf.EscherRecord; import org.apache.poi.ddf.EscherRecord;
import org.apache.poi.ddf.EscherSimpleProperty; import org.apache.poi.ddf.EscherSimpleProperty;
import org.apache.poi.ddf.EscherSpRecord; import org.apache.poi.ddf.EscherSpRecord;
import org.apache.poi.ddf.EscherSplitMenuColorsRecord; import org.apache.poi.ddf.EscherSplitMenuColorsRecord;
import org.apache.poi.hssf.extractor.OldExcelExtractor; import org.apache.poi.hssf.extractor.OldExcelExtractor;
import org.apache.poi.hssf.record.BOFRecord; import org.apache.poi.hssf.record.*;
import org.apache.poi.hssf.record.BackupRecord;
import org.apache.poi.hssf.record.BookBoolRecord;
import org.apache.poi.hssf.record.BoundSheetRecord;
import org.apache.poi.hssf.record.CodepageRecord;
import org.apache.poi.hssf.record.CountryRecord;
import org.apache.poi.hssf.record.DSFRecord;
import org.apache.poi.hssf.record.DateWindow1904Record;
import org.apache.poi.hssf.record.DrawingGroupRecord;
import org.apache.poi.hssf.record.EOFRecord;
import org.apache.poi.hssf.record.EscherAggregate;
import org.apache.poi.hssf.record.ExtSSTRecord;
import org.apache.poi.hssf.record.ExtendedFormatRecord;
import org.apache.poi.hssf.record.ExternSheetRecord;
import org.apache.poi.hssf.record.FileSharingRecord;
import org.apache.poi.hssf.record.FnGroupCountRecord;
import org.apache.poi.hssf.record.FontRecord;
import org.apache.poi.hssf.record.FormatRecord;
import org.apache.poi.hssf.record.HideObjRecord;
import org.apache.poi.hssf.record.HyperlinkRecord;
import org.apache.poi.hssf.record.InterfaceEndRecord;
import org.apache.poi.hssf.record.InterfaceHdrRecord;
import org.apache.poi.hssf.record.MMSRecord;
import org.apache.poi.hssf.record.NameCommentRecord;
import org.apache.poi.hssf.record.NameRecord;
import org.apache.poi.hssf.record.PaletteRecord;
import org.apache.poi.hssf.record.PasswordRecord;
import org.apache.poi.hssf.record.PasswordRev4Record;
import org.apache.poi.hssf.record.PrecisionRecord;
import org.apache.poi.hssf.record.ProtectRecord;
import org.apache.poi.hssf.record.ProtectionRev4Record;
import org.apache.poi.hssf.record.RecalcIdRecord;
import org.apache.poi.hssf.record.Record;
import org.apache.poi.hssf.record.RefreshAllRecord;
import org.apache.poi.hssf.record.SSTRecord;
import org.apache.poi.hssf.record.StyleRecord;
import org.apache.poi.hssf.record.SupBookRecord;
import org.apache.poi.hssf.record.TabIdRecord;
import org.apache.poi.hssf.record.UseSelFSRecord;
import org.apache.poi.hssf.record.WindowOneRecord;
import org.apache.poi.hssf.record.WindowProtectRecord;
import org.apache.poi.hssf.record.WriteAccessRecord;
import org.apache.poi.hssf.record.WriteProtectRecord;
import org.apache.poi.hssf.record.common.UnicodeString; import org.apache.poi.hssf.record.common.UnicodeString;
import org.apache.poi.hssf.util.HSSFColor.HSSFColorPredefined; import org.apache.poi.hssf.util.HSSFColor.HSSFColorPredefined;
import org.apache.poi.poifs.crypt.CryptoFunctions; import org.apache.poi.poifs.crypt.CryptoFunctions;
@ -1961,9 +1919,9 @@ public final class InternalWorkbook {
} }
opt.setRecordId((short) 0xF00B); opt.setRecordId((short) 0xF00B);
opt.setOptions((short) 0x0033); opt.setOptions((short) 0x0033);
opt.addEscherProperty( new EscherBoolProperty(EscherProperties.TEXT__SIZE_TEXT_TO_FIT_SHAPE, 524296) ); opt.addEscherProperty( new EscherBoolProperty(EscherPropertyTypes.TEXT__SIZE_TEXT_TO_FIT_SHAPE, 524296) );
opt.addEscherProperty( new EscherRGBProperty(EscherProperties.FILL__FILLCOLOR, 0x08000041) ); opt.addEscherProperty( new EscherRGBProperty(EscherPropertyTypes.FILL__FILLCOLOR, 0x08000041) );
opt.addEscherProperty( new EscherRGBProperty(EscherProperties.LINESTYLE__COLOR, 134217792) ); opt.addEscherProperty( new EscherRGBProperty(EscherPropertyTypes.LINESTYLE__COLOR, 134217792) );
splitMenuColors.setRecordId((short) 0xF11E); splitMenuColors.setRecordId((short) 0xF11E);
splitMenuColors.setOptions((short) 0x0040); splitMenuColors.setOptions((short) 0x0040);
splitMenuColors.setColor1(0x0800000D); splitMenuColors.setColor1(0x0800000D);
@ -2190,7 +2148,7 @@ public final class InternalWorkbook {
} else if (recordId == EscherOptRecord.RECORD_ID){ } else if (recordId == EscherOptRecord.RECORD_ID){
EscherOptRecord opt = (EscherOptRecord)shapeChildRecord; EscherOptRecord opt = (EscherOptRecord)shapeChildRecord;
EscherSimpleProperty prop = opt.lookup( EscherSimpleProperty prop = opt.lookup(
EscherProperties.BLIP__BLIPTODISPLAY ); EscherPropertyTypes.BLIP__BLIPTODISPLAY );
if (prop != null){ if (prop != null){
int pictureIndex = prop.getPropertyValue(); int pictureIndex = prop.getPropertyValue();
// increment reference count for pictures // increment reference count for pictures

View File

@ -17,8 +17,21 @@
package org.apache.poi.hssf.usermodel; package org.apache.poi.hssf.usermodel;
import org.apache.poi.ddf.*; import org.apache.poi.ddf.EscherBoolProperty;
import org.apache.poi.hssf.record.*; import org.apache.poi.ddf.EscherClientDataRecord;
import org.apache.poi.ddf.EscherContainerRecord;
import org.apache.poi.ddf.EscherOptRecord;
import org.apache.poi.ddf.EscherPropertyTypes;
import org.apache.poi.ddf.EscherRecord;
import org.apache.poi.ddf.EscherSimpleProperty;
import org.apache.poi.ddf.EscherSpRecord;
import org.apache.poi.hssf.record.CommonObjectDataSubRecord;
import org.apache.poi.hssf.record.EndSubRecord;
import org.apache.poi.hssf.record.EscherAggregate;
import org.apache.poi.hssf.record.FtCblsSubRecord;
import org.apache.poi.hssf.record.LbsDataSubRecord;
import org.apache.poi.hssf.record.ObjRecord;
import org.apache.poi.hssf.record.TextObjectRecord;
import org.apache.poi.ss.usermodel.ClientAnchor.AnchorType; import org.apache.poi.ss.usermodel.ClientAnchor.AnchorType;
/** /**
@ -56,10 +69,10 @@ public class HSSFCombobox extends HSSFSimpleShape {
sp.setFlags(EscherSpRecord.FLAG_HAVEANCHOR | EscherSpRecord.FLAG_HASSHAPETYPE); sp.setFlags(EscherSpRecord.FLAG_HAVEANCHOR | EscherSpRecord.FLAG_HASSHAPETYPE);
opt.setRecordId(EscherOptRecord.RECORD_ID); opt.setRecordId(EscherOptRecord.RECORD_ID);
opt.addEscherProperty(new EscherBoolProperty(EscherProperties.PROTECTION__LOCKAGAINSTGROUPING, 17039620)); opt.addEscherProperty(new EscherBoolProperty(EscherPropertyTypes.PROTECTION__LOCKAGAINSTGROUPING, 17039620));
opt.addEscherProperty(new EscherBoolProperty(EscherProperties.TEXT__SIZE_TEXT_TO_FIT_SHAPE, 0x00080008)); opt.addEscherProperty(new EscherBoolProperty(EscherPropertyTypes.TEXT__SIZE_TEXT_TO_FIT_SHAPE, 0x00080008));
opt.addEscherProperty(new EscherBoolProperty(EscherProperties.LINESTYLE__NOLINEDRAWDASH, 0x00080000)); opt.addEscherProperty(new EscherBoolProperty(EscherPropertyTypes.LINESTYLE__NOLINEDRAWDASH, 0x00080000));
opt.addEscherProperty(new EscherSimpleProperty(EscherProperties.GROUPSHAPE__PRINT, 0x00020000)); opt.addEscherProperty(new EscherSimpleProperty(EscherPropertyTypes.GROUPSHAPE__FLAGS, 0x00020000));
HSSFClientAnchor userAnchor = (HSSFClientAnchor) getAnchor(); HSSFClientAnchor userAnchor = (HSSFClientAnchor) getAnchor();
userAnchor.setAnchorType(AnchorType.DONT_MOVE_DO_RESIZE); userAnchor.setAnchorType(AnchorType.DONT_MOVE_DO_RESIZE);

View File

@ -20,7 +20,7 @@ import org.apache.poi.ddf.DefaultEscherRecordFactory;
import org.apache.poi.ddf.EscherBSERecord; import org.apache.poi.ddf.EscherBSERecord;
import org.apache.poi.ddf.EscherContainerRecord; import org.apache.poi.ddf.EscherContainerRecord;
import org.apache.poi.ddf.EscherOptRecord; import org.apache.poi.ddf.EscherOptRecord;
import org.apache.poi.ddf.EscherProperties; import org.apache.poi.ddf.EscherPropertyTypes;
import org.apache.poi.ddf.EscherSimpleProperty; import org.apache.poi.ddf.EscherSimpleProperty;
import org.apache.poi.hssf.record.CommonObjectDataSubRecord; import org.apache.poi.hssf.record.CommonObjectDataSubRecord;
import org.apache.poi.hssf.record.EndSubRecord; import org.apache.poi.hssf.record.EndSubRecord;
@ -98,11 +98,11 @@ public class HSSFComment extends HSSFTextbox implements Comment {
protected EscherContainerRecord createSpContainer() { protected EscherContainerRecord createSpContainer() {
EscherContainerRecord spContainer = super.createSpContainer(); EscherContainerRecord spContainer = super.createSpContainer();
EscherOptRecord opt = spContainer.getChildById(EscherOptRecord.RECORD_ID); EscherOptRecord opt = spContainer.getChildById(EscherOptRecord.RECORD_ID);
opt.removeEscherProperty(EscherProperties.TEXT__TEXTLEFT); opt.removeEscherProperty(EscherPropertyTypes.TEXT__TEXTLEFT);
opt.removeEscherProperty(EscherProperties.TEXT__TEXTRIGHT); opt.removeEscherProperty(EscherPropertyTypes.TEXT__TEXTRIGHT);
opt.removeEscherProperty(EscherProperties.TEXT__TEXTTOP); opt.removeEscherProperty(EscherPropertyTypes.TEXT__TEXTTOP);
opt.removeEscherProperty(EscherProperties.TEXT__TEXTBOTTOM); opt.removeEscherProperty(EscherPropertyTypes.TEXT__TEXTBOTTOM);
opt.setEscherProperty(new EscherSimpleProperty(EscherProperties.GROUPSHAPE__PRINT, false, false, GROUP_SHAPE_PROPERTY_DEFAULT_VALUE)); opt.setEscherProperty(new EscherSimpleProperty(EscherPropertyTypes.GROUPSHAPE__FLAGS, false, false, GROUP_SHAPE_PROPERTY_DEFAULT_VALUE));
return spContainer; return spContainer;
} }
@ -290,34 +290,34 @@ public class HSSFComment extends HSSFTextbox implements Comment {
} }
public void setBackgroundImage(int pictureIndex){ public void setBackgroundImage(int pictureIndex){
setPropertyValue(new EscherSimpleProperty( EscherProperties.FILL__PATTERNTEXTURE, false, true, pictureIndex)); setPropertyValue(new EscherSimpleProperty( EscherPropertyTypes.FILL__PATTERNTEXTURE, false, true, pictureIndex));
setPropertyValue(new EscherSimpleProperty( EscherProperties.FILL__FILLTYPE, false, false, FILL_TYPE_PICTURE)); setPropertyValue(new EscherSimpleProperty( EscherPropertyTypes.FILL__FILLTYPE, false, false, FILL_TYPE_PICTURE));
EscherBSERecord bse = getPatriarch().getSheet().getWorkbook().getWorkbook().getBSERecord(pictureIndex); EscherBSERecord bse = getPatriarch().getSheet().getWorkbook().getWorkbook().getBSERecord(pictureIndex);
bse.setRef(bse.getRef() + 1); bse.setRef(bse.getRef() + 1);
} }
public void resetBackgroundImage(){ public void resetBackgroundImage(){
EscherSimpleProperty property = getOptRecord().lookup(EscherProperties.FILL__PATTERNTEXTURE); EscherSimpleProperty property = getOptRecord().lookup(EscherPropertyTypes.FILL__PATTERNTEXTURE);
if (null != property){ if (null != property){
EscherBSERecord bse = getPatriarch().getSheet().getWorkbook().getWorkbook().getBSERecord(property.getPropertyValue()); EscherBSERecord bse = getPatriarch().getSheet().getWorkbook().getWorkbook().getBSERecord(property.getPropertyValue());
bse.setRef(bse.getRef() - 1); bse.setRef(bse.getRef() - 1);
getOptRecord().removeEscherProperty(EscherProperties.FILL__PATTERNTEXTURE); getOptRecord().removeEscherProperty(EscherPropertyTypes.FILL__PATTERNTEXTURE);
} }
setPropertyValue(new EscherSimpleProperty( EscherProperties.FILL__FILLTYPE, false, false, FILL_TYPE_SOLID)); setPropertyValue(new EscherSimpleProperty( EscherPropertyTypes.FILL__FILLTYPE, false, false, FILL_TYPE_SOLID));
} }
public int getBackgroundImageId(){ public int getBackgroundImageId(){
EscherSimpleProperty property = getOptRecord().lookup(EscherProperties.FILL__PATTERNTEXTURE); EscherSimpleProperty property = getOptRecord().lookup(EscherPropertyTypes.FILL__PATTERNTEXTURE);
return property == null ? 0 : property.getPropertyValue(); return property == null ? 0 : property.getPropertyValue();
} }
private void setHidden(boolean value){ private void setHidden(boolean value){
EscherSimpleProperty property = getOptRecord().lookup(EscherProperties.GROUPSHAPE__PRINT); EscherSimpleProperty property = getOptRecord().lookup(EscherPropertyTypes.GROUPSHAPE__FLAGS);
// see http://msdn.microsoft.com/en-us/library/dd949807(v=office.12).aspx // see http://msdn.microsoft.com/en-us/library/dd949807(v=office.12).aspx
if (value){ if (value){
setPropertyValue(new EscherSimpleProperty(EscherProperties.GROUPSHAPE__PRINT, false, false, property.getPropertyValue() | GROUP_SHAPE_HIDDEN_MASK)); setPropertyValue(new EscherSimpleProperty(EscherPropertyTypes.GROUPSHAPE__FLAGS, false, false, property.getPropertyValue() | GROUP_SHAPE_HIDDEN_MASK));
} else { } else {
setPropertyValue(new EscherSimpleProperty(EscherProperties.GROUPSHAPE__PRINT, false, false, property.getPropertyValue() & GROUP_SHAPE_NOT_HIDDEN_MASK)); setPropertyValue(new EscherSimpleProperty(EscherPropertyTypes.GROUPSHAPE__FLAGS, false, false, property.getPropertyValue() & GROUP_SHAPE_NOT_HIDDEN_MASK));
} }
} }

View File

@ -27,7 +27,7 @@ import org.apache.poi.ddf.EscherClientDataRecord;
import org.apache.poi.ddf.EscherComplexProperty; import org.apache.poi.ddf.EscherComplexProperty;
import org.apache.poi.ddf.EscherContainerRecord; import org.apache.poi.ddf.EscherContainerRecord;
import org.apache.poi.ddf.EscherOptRecord; import org.apache.poi.ddf.EscherOptRecord;
import org.apache.poi.ddf.EscherProperties; import org.apache.poi.ddf.EscherPropertyTypes;
import org.apache.poi.ddf.EscherSimpleProperty; import org.apache.poi.ddf.EscherSimpleProperty;
import org.apache.poi.ddf.EscherTextboxRecord; import org.apache.poi.ddf.EscherTextboxRecord;
import org.apache.poi.hssf.model.InternalWorkbook; import org.apache.poi.hssf.model.InternalWorkbook;
@ -72,7 +72,7 @@ public class HSSFPicture extends HSSFSimpleShape implements Picture {
public int getPictureIndex() public int getPictureIndex()
{ {
EscherSimpleProperty property = getOptRecord().lookup(EscherProperties.BLIP__BLIPTODISPLAY); EscherSimpleProperty property = getOptRecord().lookup(EscherPropertyTypes.BLIP__BLIPTODISPLAY);
if (null == property){ if (null == property){
return -1; return -1;
} }
@ -81,15 +81,15 @@ public class HSSFPicture extends HSSFSimpleShape implements Picture {
public void setPictureIndex( int pictureIndex ) public void setPictureIndex( int pictureIndex )
{ {
setPropertyValue(new EscherSimpleProperty( EscherProperties.BLIP__BLIPTODISPLAY, false, true, pictureIndex)); setPropertyValue(new EscherSimpleProperty( EscherPropertyTypes.BLIP__BLIPTODISPLAY, false, true, pictureIndex));
} }
@Override @Override
protected EscherContainerRecord createSpContainer() { protected EscherContainerRecord createSpContainer() {
EscherContainerRecord spContainer = super.createSpContainer(); EscherContainerRecord spContainer = super.createSpContainer();
EscherOptRecord opt = spContainer.getChildById(EscherOptRecord.RECORD_ID); EscherOptRecord opt = spContainer.getChildById(EscherOptRecord.RECORD_ID);
opt.removeEscherProperty(EscherProperties.LINESTYLE__LINEDASHING); opt.removeEscherProperty(EscherPropertyTypes.LINESTYLE__LINEDASHING);
opt.removeEscherProperty(EscherProperties.LINESTYLE__NOLINEDRAWDASH); opt.removeEscherProperty(EscherPropertyTypes.LINESTYLE__NOLINEDRAWDASH);
spContainer.removeChildRecord(spContainer.getChildById(EscherTextboxRecord.RECORD_ID)); spContainer.removeChildRecord(spContainer.getChildById(EscherTextboxRecord.RECORD_ID));
return spContainer; return spContainer;
} }
@ -247,8 +247,7 @@ public class HSSFPicture extends HSSFSimpleShape implements Picture {
* The filename of the embedded image * The filename of the embedded image
*/ */
public String getFileName() { public String getFileName() {
EscherComplexProperty propFile = getOptRecord().lookup( EscherComplexProperty propFile = getOptRecord().lookup(EscherPropertyTypes.BLIP__BLIPFILENAME);
EscherProperties.BLIP__BLIPFILENAME);
return (null == propFile) return (null == propFile)
? "" ? ""
: StringUtil.getFromUnicodeLE(propFile.getComplexData()).trim(); : StringUtil.getFromUnicodeLE(propFile.getComplexData()).trim();
@ -257,7 +256,8 @@ public class HSSFPicture extends HSSFSimpleShape implements Picture {
public void setFileName(String data){ public void setFileName(String data){
// TODO: add trailing \u0000? // TODO: add trailing \u0000?
byte[] bytes = StringUtil.getToUnicodeLE(data); byte[] bytes = StringUtil.getToUnicodeLE(data);
EscherComplexProperty prop = new EscherComplexProperty(EscherProperties.BLIP__BLIPFILENAME, true, bytes); EscherComplexProperty prop = new EscherComplexProperty(EscherPropertyTypes.BLIP__BLIPFILENAME, true, bytes.length);
prop.setComplexData(bytes);
setPropertyValue(prop); setPropertyValue(prop);
} }

View File

@ -17,8 +17,22 @@
package org.apache.poi.hssf.usermodel; package org.apache.poi.hssf.usermodel;
import org.apache.poi.ddf.*; import org.apache.poi.ddf.EscherArrayProperty;
import org.apache.poi.hssf.record.*; import org.apache.poi.ddf.EscherBoolProperty;
import org.apache.poi.ddf.EscherClientDataRecord;
import org.apache.poi.ddf.EscherContainerRecord;
import org.apache.poi.ddf.EscherOptRecord;
import org.apache.poi.ddf.EscherPropertyTypes;
import org.apache.poi.ddf.EscherRGBProperty;
import org.apache.poi.ddf.EscherRecord;
import org.apache.poi.ddf.EscherShapePathProperty;
import org.apache.poi.ddf.EscherSimpleProperty;
import org.apache.poi.ddf.EscherSpRecord;
import org.apache.poi.hssf.record.CommonObjectDataSubRecord;
import org.apache.poi.hssf.record.EndSubRecord;
import org.apache.poi.hssf.record.EscherAggregate;
import org.apache.poi.hssf.record.ObjRecord;
import org.apache.poi.hssf.record.TextObjectRecord;
import org.apache.poi.util.LittleEndian; import org.apache.poi.util.LittleEndian;
import org.apache.poi.util.POILogFactory; import org.apache.poi.util.POILogFactory;
import org.apache.poi.util.POILogger; import org.apache.poi.util.POILogger;
@ -66,24 +80,24 @@ public class HSSFPolygon extends HSSFSimpleShape {
sp.setFlags(EscherSpRecord.FLAG_CHILD | EscherSpRecord.FLAG_HAVEANCHOR | EscherSpRecord.FLAG_HASSHAPETYPE); sp.setFlags(EscherSpRecord.FLAG_CHILD | EscherSpRecord.FLAG_HAVEANCHOR | EscherSpRecord.FLAG_HASSHAPETYPE);
} }
opt.setRecordId(EscherOptRecord.RECORD_ID); opt.setRecordId(EscherOptRecord.RECORD_ID);
opt.setEscherProperty(new EscherSimpleProperty(EscherProperties.TRANSFORM__ROTATION, false, false, 0)); opt.setEscherProperty(new EscherSimpleProperty(EscherPropertyTypes.TRANSFORM__ROTATION, false, false, 0));
opt.setEscherProperty(new EscherSimpleProperty(EscherProperties.GEOMETRY__RIGHT, false, false, 100)); opt.setEscherProperty(new EscherSimpleProperty(EscherPropertyTypes.GEOMETRY__RIGHT, false, false, 100));
opt.setEscherProperty(new EscherSimpleProperty(EscherProperties.GEOMETRY__BOTTOM, false, false, 100)); opt.setEscherProperty(new EscherSimpleProperty(EscherPropertyTypes.GEOMETRY__BOTTOM, false, false, 100));
opt.setEscherProperty(new EscherShapePathProperty(EscherProperties.GEOMETRY__SHAPEPATH, EscherShapePathProperty.COMPLEX)); opt.setEscherProperty(new EscherShapePathProperty(EscherPropertyTypes.GEOMETRY__SHAPEPATH, EscherShapePathProperty.COMPLEX));
opt.setEscherProperty(new EscherSimpleProperty(EscherProperties.GEOMETRY__FILLOK, false, false, 0x00010001)); opt.setEscherProperty(new EscherSimpleProperty(EscherPropertyTypes.GEOMETRY__FILLOK, false, false, 0x00010001));
opt.setEscherProperty(new EscherSimpleProperty(EscherProperties.LINESTYLE__LINESTARTARROWHEAD, false, false, 0x0)); opt.setEscherProperty(new EscherSimpleProperty(EscherPropertyTypes.LINESTYLE__LINESTARTARROWHEAD, false, false, 0x0));
opt.setEscherProperty(new EscherSimpleProperty(EscherProperties.LINESTYLE__LINEENDARROWHEAD, false, false, 0x0)); opt.setEscherProperty(new EscherSimpleProperty(EscherPropertyTypes.LINESTYLE__LINEENDARROWHEAD, false, false, 0x0));
opt.setEscherProperty(new EscherSimpleProperty(EscherProperties.LINESTYLE__LINEENDCAPSTYLE, false, false, 0x0)); opt.setEscherProperty(new EscherSimpleProperty(EscherPropertyTypes.LINESTYLE__LINEENDCAPSTYLE, false, false, 0x0));
opt.setEscherProperty(new EscherSimpleProperty(EscherProperties.LINESTYLE__LINEDASHING, LINESTYLE_SOLID)); opt.setEscherProperty(new EscherSimpleProperty(EscherPropertyTypes.LINESTYLE__LINEDASHING, LINESTYLE_SOLID));
opt.setEscherProperty( new EscherBoolProperty( EscherProperties.LINESTYLE__NOLINEDRAWDASH, 0x00080008)); opt.setEscherProperty( new EscherBoolProperty( EscherPropertyTypes.LINESTYLE__NOLINEDRAWDASH, 0x00080008));
opt.setEscherProperty(new EscherSimpleProperty(EscherProperties.LINESTYLE__LINEWIDTH, LINEWIDTH_DEFAULT)); opt.setEscherProperty(new EscherSimpleProperty(EscherPropertyTypes.LINESTYLE__LINEWIDTH, LINEWIDTH_DEFAULT));
opt.setEscherProperty(new EscherRGBProperty(EscherProperties.FILL__FILLCOLOR, FILL__FILLCOLOR_DEFAULT)); opt.setEscherProperty(new EscherRGBProperty(EscherPropertyTypes.FILL__FILLCOLOR, FILL__FILLCOLOR_DEFAULT));
opt.setEscherProperty(new EscherRGBProperty(EscherProperties.LINESTYLE__COLOR, LINESTYLE__COLOR_DEFAULT)); opt.setEscherProperty(new EscherRGBProperty(EscherPropertyTypes.LINESTYLE__COLOR, LINESTYLE__COLOR_DEFAULT));
opt.setEscherProperty(new EscherBoolProperty(EscherProperties.FILL__NOFILLHITTEST, 1)); opt.setEscherProperty(new EscherBoolProperty(EscherPropertyTypes.FILL__NOFILLHITTEST, 1));
opt.setEscherProperty(new EscherBoolProperty( EscherProperties.GROUPSHAPE__PRINT, 0x080000)); opt.setEscherProperty(new EscherBoolProperty( EscherPropertyTypes.GROUPSHAPE__FLAGS, 0x080000));
EscherRecord anchor = getAnchor().getEscherAnchor(); EscherRecord anchor = getAnchor().getEscherAnchor();
clientData.setRecordId(EscherClientDataRecord.RECORD_ID); clientData.setRecordId(EscherClientDataRecord.RECORD_ID);
@ -123,7 +137,7 @@ public class HSSFPolygon extends HSSFSimpleShape {
* @return array of x coordinates * @return array of x coordinates
*/ */
public int[] getXPoints() { public int[] getXPoints() {
EscherArrayProperty verticesProp = getOptRecord().lookup(EscherProperties.GEOMETRY__VERTICES); EscherArrayProperty verticesProp = getOptRecord().lookup(EscherPropertyTypes.GEOMETRY__VERTICES);
if (null == verticesProp){ if (null == verticesProp){
return new int[]{}; return new int[]{};
} }
@ -140,7 +154,7 @@ public class HSSFPolygon extends HSSFSimpleShape {
* @return array of y coordinates * @return array of y coordinates
*/ */
public int[] getYPoints() { public int[] getYPoints() {
EscherArrayProperty verticesProp = getOptRecord().lookup(EscherProperties.GEOMETRY__VERTICES); EscherArrayProperty verticesProp = getOptRecord().lookup(EscherPropertyTypes.GEOMETRY__VERTICES);
if (null == verticesProp){ if (null == verticesProp){
return new int[]{}; return new int[]{};
} }
@ -165,7 +179,7 @@ public class HSSFPolygon extends HSSFSimpleShape {
if (xPoints.length == 0){ if (xPoints.length == 0){
logger.log( POILogger.ERROR, "HSSFPolygon must have at least one point"); logger.log( POILogger.ERROR, "HSSFPolygon must have at least one point");
} }
EscherArrayProperty verticesProp = new EscherArrayProperty(EscherProperties.GEOMETRY__VERTICES, false, new byte[0] ); EscherArrayProperty verticesProp = new EscherArrayProperty(EscherPropertyTypes.GEOMETRY__VERTICES, false, 0);
verticesProp.setNumberOfElementsInArray(xPoints.length+1); verticesProp.setNumberOfElementsInArray(xPoints.length+1);
verticesProp.setNumberOfElementsInMemory(xPoints.length+1); verticesProp.setNumberOfElementsInMemory(xPoints.length+1);
verticesProp.setSizeOfElements(0xFFF0); verticesProp.setSizeOfElements(0xFFF0);
@ -183,7 +197,7 @@ public class HSSFPolygon extends HSSFSimpleShape {
verticesProp.setElement(point, data); verticesProp.setElement(point, data);
setPropertyValue(verticesProp); setPropertyValue(verticesProp);
EscherArrayProperty segmentsProp = new EscherArrayProperty(EscherProperties.GEOMETRY__SEGMENTINFO, false, null ); EscherArrayProperty segmentsProp = new EscherArrayProperty(EscherPropertyTypes.GEOMETRY__SEGMENTINFO, false, 0);
segmentsProp.setSizeOfElements(0x0002); segmentsProp.setSizeOfElements(0x0002);
segmentsProp.setNumberOfElementsInArray(xPoints.length * 2 + 4); segmentsProp.setNumberOfElementsInArray(xPoints.length * 2 + 4);
segmentsProp.setNumberOfElementsInMemory(xPoints.length * 2 + 4); segmentsProp.setNumberOfElementsInMemory(xPoints.length * 2 + 4);
@ -205,15 +219,15 @@ public class HSSFPolygon extends HSSFSimpleShape {
* @param height * @param height
*/ */
public void setPolygonDrawArea(int width, int height) { public void setPolygonDrawArea(int width, int height) {
setPropertyValue(new EscherSimpleProperty(EscherProperties.GEOMETRY__RIGHT, width)); setPropertyValue(new EscherSimpleProperty(EscherPropertyTypes.GEOMETRY__RIGHT, width));
setPropertyValue(new EscherSimpleProperty(EscherProperties.GEOMETRY__BOTTOM, height)); setPropertyValue(new EscherSimpleProperty(EscherPropertyTypes.GEOMETRY__BOTTOM, height));
} }
/** /**
* @return shape width * @return shape width
*/ */
public int getDrawAreaWidth() { public int getDrawAreaWidth() {
EscherSimpleProperty property = getOptRecord().lookup(EscherProperties.GEOMETRY__RIGHT); EscherSimpleProperty property = getOptRecord().lookup(EscherPropertyTypes.GEOMETRY__RIGHT);
return property == null ? 100: property.getPropertyValue(); return property == null ? 100: property.getPropertyValue();
} }
@ -221,7 +235,7 @@ public class HSSFPolygon extends HSSFSimpleShape {
* @return shape height * @return shape height
*/ */
public int getDrawAreaHeight() { public int getDrawAreaHeight() {
EscherSimpleProperty property = getOptRecord().lookup(EscherProperties.GEOMETRY__BOTTOM); EscherSimpleProperty property = getOptRecord().lookup(EscherPropertyTypes.GEOMETRY__BOTTOM);
return property == null ? 100: property.getPropertyValue(); return property == null ? 100: property.getPropertyValue();
} }
} }

View File

@ -26,8 +26,8 @@ import org.apache.poi.ddf.EscherClientAnchorRecord;
import org.apache.poi.ddf.EscherComplexProperty; import org.apache.poi.ddf.EscherComplexProperty;
import org.apache.poi.ddf.EscherContainerRecord; import org.apache.poi.ddf.EscherContainerRecord;
import org.apache.poi.ddf.EscherOptRecord; import org.apache.poi.ddf.EscherOptRecord;
import org.apache.poi.ddf.EscherProperties;
import org.apache.poi.ddf.EscherProperty; import org.apache.poi.ddf.EscherProperty;
import org.apache.poi.ddf.EscherPropertyTypes;
import org.apache.poi.ddf.EscherRGBProperty; import org.apache.poi.ddf.EscherRGBProperty;
import org.apache.poi.ddf.EscherSimpleProperty; import org.apache.poi.ddf.EscherSimpleProperty;
import org.apache.poi.ddf.EscherSpRecord; import org.apache.poi.ddf.EscherSpRecord;
@ -222,7 +222,7 @@ public abstract class HSSFShape implements Shape {
* The color applied to the lines of this shape. * The color applied to the lines of this shape.
*/ */
public int getLineStyleColor() { public int getLineStyleColor() {
EscherRGBProperty rgbProperty = _optRecord.lookup(EscherProperties.LINESTYLE__COLOR); EscherRGBProperty rgbProperty = _optRecord.lookup(EscherPropertyTypes.LINESTYLE__COLOR);
return rgbProperty == null ? LINESTYLE__COLOR_DEFAULT : rgbProperty.getRgbColor(); return rgbProperty == null ? LINESTYLE__COLOR_DEFAULT : rgbProperty.getRgbColor();
} }
@ -230,20 +230,20 @@ public abstract class HSSFShape implements Shape {
* The color applied to the lines of this shape. * The color applied to the lines of this shape.
*/ */
public void setLineStyleColor(int lineStyleColor) { public void setLineStyleColor(int lineStyleColor) {
setPropertyValue(new EscherRGBProperty(EscherProperties.LINESTYLE__COLOR, lineStyleColor)); setPropertyValue(new EscherRGBProperty(EscherPropertyTypes.LINESTYLE__COLOR, lineStyleColor));
} }
@Override @Override
public void setLineStyleColor(int red, int green, int blue) { public void setLineStyleColor(int red, int green, int blue) {
int lineStyleColor = ((blue) << 16) | ((green) << 8) | red; int lineStyleColor = ((blue) << 16) | ((green) << 8) | red;
setPropertyValue(new EscherRGBProperty(EscherProperties.LINESTYLE__COLOR, lineStyleColor)); setPropertyValue(new EscherRGBProperty(EscherPropertyTypes.LINESTYLE__COLOR, lineStyleColor));
} }
/** /**
* The color used to fill this shape. * The color used to fill this shape.
*/ */
public int getFillColor() { public int getFillColor() {
EscherRGBProperty rgbProperty = _optRecord.lookup(EscherProperties.FILL__FILLCOLOR); EscherRGBProperty rgbProperty = _optRecord.lookup(EscherPropertyTypes.FILL__FILLCOLOR);
return rgbProperty == null ? FILL__FILLCOLOR_DEFAULT : rgbProperty.getRgbColor(); return rgbProperty == null ? FILL__FILLCOLOR_DEFAULT : rgbProperty.getRgbColor();
} }
@ -251,20 +251,20 @@ public abstract class HSSFShape implements Shape {
* The color used to fill this shape. * The color used to fill this shape.
*/ */
public void setFillColor(int fillColor) { public void setFillColor(int fillColor) {
setPropertyValue(new EscherRGBProperty(EscherProperties.FILL__FILLCOLOR, fillColor)); setPropertyValue(new EscherRGBProperty(EscherPropertyTypes.FILL__FILLCOLOR, fillColor));
} }
@Override @Override
public void setFillColor(int red, int green, int blue) { public void setFillColor(int red, int green, int blue) {
int fillColor = ((blue) << 16) | ((green) << 8) | red; int fillColor = ((blue) << 16) | ((green) << 8) | red;
setPropertyValue(new EscherRGBProperty(EscherProperties.FILL__FILLCOLOR, fillColor)); setPropertyValue(new EscherRGBProperty(EscherPropertyTypes.FILL__FILLCOLOR, fillColor));
} }
/** /**
* @return returns with width of the line in EMUs. 12700 = 1 pt. * @return returns with width of the line in EMUs. 12700 = 1 pt.
*/ */
public int getLineWidth() { public int getLineWidth() {
EscherSimpleProperty property = _optRecord.lookup(EscherProperties.LINESTYLE__LINEWIDTH); EscherSimpleProperty property = _optRecord.lookup(EscherPropertyTypes.LINESTYLE__LINEWIDTH);
return property == null ? LINEWIDTH_DEFAULT: property.getPropertyValue(); return property == null ? LINEWIDTH_DEFAULT: property.getPropertyValue();
} }
@ -275,14 +275,14 @@ public abstract class HSSFShape implements Shape {
* @see HSSFShape#LINEWIDTH_ONE_PT * @see HSSFShape#LINEWIDTH_ONE_PT
*/ */
public void setLineWidth(int lineWidth) { public void setLineWidth(int lineWidth) {
setPropertyValue(new EscherSimpleProperty(EscherProperties.LINESTYLE__LINEWIDTH, lineWidth)); setPropertyValue(new EscherSimpleProperty(EscherPropertyTypes.LINESTYLE__LINEWIDTH, lineWidth));
} }
/** /**
* @return One of the constants in LINESTYLE_* * @return One of the constants in LINESTYLE_*
*/ */
public int getLineStyle() { public int getLineStyle() {
EscherSimpleProperty property = _optRecord.lookup(EscherProperties.LINESTYLE__LINEDASHING); EscherSimpleProperty property = _optRecord.lookup(EscherPropertyTypes.LINESTYLE__LINEDASHING);
if (null == property){ if (null == property){
return LINESTYLE_DEFAULT; return LINESTYLE_DEFAULT;
} }
@ -295,26 +295,26 @@ public abstract class HSSFShape implements Shape {
* @param lineStyle One of the constants in LINESTYLE_* * @param lineStyle One of the constants in LINESTYLE_*
*/ */
public void setLineStyle(int lineStyle) { public void setLineStyle(int lineStyle) {
setPropertyValue(new EscherSimpleProperty(EscherProperties.LINESTYLE__LINEDASHING, lineStyle)); setPropertyValue(new EscherSimpleProperty(EscherPropertyTypes.LINESTYLE__LINEDASHING, lineStyle));
if (getLineStyle() != HSSFShape.LINESTYLE_SOLID) { if (getLineStyle() != HSSFShape.LINESTYLE_SOLID) {
setPropertyValue(new EscherSimpleProperty(EscherProperties.LINESTYLE__LINEENDCAPSTYLE, 0)); setPropertyValue(new EscherSimpleProperty(EscherPropertyTypes.LINESTYLE__LINEENDCAPSTYLE, 0));
if (getLineStyle() == HSSFShape.LINESTYLE_NONE){ if (getLineStyle() == HSSFShape.LINESTYLE_NONE){
setPropertyValue(new EscherBoolProperty( EscherProperties.LINESTYLE__NOLINEDRAWDASH, 0x00080000)); setPropertyValue(new EscherBoolProperty( EscherPropertyTypes.LINESTYLE__NOLINEDRAWDASH, 0x00080000));
} else { } else {
setPropertyValue( new EscherBoolProperty( EscherProperties.LINESTYLE__NOLINEDRAWDASH, 0x00080008)); setPropertyValue( new EscherBoolProperty( EscherPropertyTypes.LINESTYLE__NOLINEDRAWDASH, 0x00080008));
} }
} }
} }
@Override @Override
public boolean isNoFill() { public boolean isNoFill() {
EscherBoolProperty property = _optRecord.lookup(EscherProperties.FILL__NOFILLHITTEST); EscherBoolProperty property = _optRecord.lookup(EscherPropertyTypes.FILL__NOFILLHITTEST);
return property == null ? NO_FILL_DEFAULT : property.getPropertyValue() == NO_FILLHITTEST_TRUE; return property == null ? NO_FILL_DEFAULT : property.getPropertyValue() == NO_FILLHITTEST_TRUE;
} }
@Override @Override
public void setNoFill(boolean noFill) { public void setNoFill(boolean noFill) {
setPropertyValue(new EscherBoolProperty(EscherProperties.FILL__NOFILLHITTEST, noFill ? NO_FILLHITTEST_TRUE : NO_FILLHITTEST_FALSE)); setPropertyValue(new EscherBoolProperty(EscherPropertyTypes.FILL__NOFILLHITTEST, noFill ? NO_FILLHITTEST_TRUE : NO_FILLHITTEST_FALSE));
} }
protected void setPropertyValue(EscherProperty property){ protected void setPropertyValue(EscherProperty property){
@ -366,7 +366,7 @@ public abstract class HSSFShape implements Shape {
*/ */
public int getRotationDegree(){ public int getRotationDegree(){
ByteArrayOutputStream bos = new ByteArrayOutputStream(); ByteArrayOutputStream bos = new ByteArrayOutputStream();
EscherSimpleProperty property = getOptRecord().lookup(EscherProperties.TRANSFORM__ROTATION); EscherSimpleProperty property = getOptRecord().lookup(EscherPropertyTypes.TRANSFORM__ROTATION);
if (null == property){ if (null == property){
return 0; return 0;
} }
@ -388,7 +388,7 @@ public abstract class HSSFShape implements Shape {
* @param value * @param value
*/ */
public void setRotationDegree(short value){ public void setRotationDegree(short value){
setPropertyValue(new EscherSimpleProperty(EscherProperties.TRANSFORM__ROTATION , (value << 16))); setPropertyValue(new EscherSimpleProperty(EscherPropertyTypes.TRANSFORM__ROTATION , (value << 16)));
} }
/** /**
@ -420,7 +420,7 @@ public abstract class HSSFShape implements Shape {
if (eor == null) { if (eor == null) {
return null; return null;
} }
EscherProperty ep = eor.lookup(EscherProperties.GROUPSHAPE__SHAPENAME); EscherProperty ep = eor.lookup(EscherPropertyTypes.GROUPSHAPE__SHAPENAME);
if (ep instanceof EscherComplexProperty) { if (ep instanceof EscherComplexProperty) {
return StringUtil.getFromUnicodeLE(((EscherComplexProperty)ep).getComplexData()); return StringUtil.getFromUnicodeLE(((EscherComplexProperty)ep).getComplexData());
} }

View File

@ -23,8 +23,8 @@ import java.util.Map;
import org.apache.poi.ddf.EscherClientDataRecord; import org.apache.poi.ddf.EscherClientDataRecord;
import org.apache.poi.ddf.EscherContainerRecord; import org.apache.poi.ddf.EscherContainerRecord;
import org.apache.poi.ddf.EscherOptRecord; import org.apache.poi.ddf.EscherOptRecord;
import org.apache.poi.ddf.EscherProperties;
import org.apache.poi.ddf.EscherProperty; import org.apache.poi.ddf.EscherProperty;
import org.apache.poi.ddf.EscherPropertyTypes;
import org.apache.poi.ddf.EscherRecord; import org.apache.poi.ddf.EscherRecord;
import org.apache.poi.ddf.EscherRecordTypes; import org.apache.poi.ddf.EscherRecordTypes;
import org.apache.poi.hssf.record.CommonObjectDataSubRecord; import org.apache.poi.hssf.record.CommonObjectDataSubRecord;
@ -110,7 +110,7 @@ public class HSSFShapeFactory {
if(optRecord == null) { if(optRecord == null) {
shape = new HSSFSimpleShape(container, objRecord, txtRecord); shape = new HSSFSimpleShape(container, objRecord, txtRecord);
} else { } else {
EscherProperty property = optRecord.lookup(EscherProperties.GEOMETRY__VERTICES); EscherProperty property = optRecord.lookup(EscherPropertyTypes.GEOMETRY__VERTICES);
if (null != property) { if (null != property) {
shape = new HSSFPolygon(container, objRecord, txtRecord); shape = new HSSFPolygon(container, objRecord, txtRecord);
} else { } else {

View File

@ -29,7 +29,7 @@ import org.apache.poi.ddf.EscherClientAnchorRecord;
import org.apache.poi.ddf.EscherClientDataRecord; import org.apache.poi.ddf.EscherClientDataRecord;
import org.apache.poi.ddf.EscherContainerRecord; import org.apache.poi.ddf.EscherContainerRecord;
import org.apache.poi.ddf.EscherOptRecord; import org.apache.poi.ddf.EscherOptRecord;
import org.apache.poi.ddf.EscherProperties; import org.apache.poi.ddf.EscherPropertyTypes;
import org.apache.poi.ddf.EscherRecord; import org.apache.poi.ddf.EscherRecord;
import org.apache.poi.ddf.EscherRecordTypes; import org.apache.poi.ddf.EscherRecordTypes;
import org.apache.poi.ddf.EscherSpRecord; import org.apache.poi.ddf.EscherSpRecord;
@ -104,8 +104,8 @@ public class HSSFShapeGroup extends HSSFShape implements HSSFShapeContainer {
} }
opt.setRecordId(EscherOptRecord.RECORD_ID); opt.setRecordId(EscherOptRecord.RECORD_ID);
opt.setOptions((short) 0x0023); opt.setOptions((short) 0x0023);
opt.addEscherProperty(new EscherBoolProperty(EscherProperties.PROTECTION__LOCKAGAINSTGROUPING, 0x00040004)); opt.addEscherProperty(new EscherBoolProperty(EscherPropertyTypes.PROTECTION__LOCKAGAINSTGROUPING, 0x00040004));
opt.addEscherProperty(new EscherBoolProperty(EscherProperties.GROUPSHAPE__PRINT, 0x00080000)); opt.addEscherProperty(new EscherBoolProperty(EscherPropertyTypes.GROUPSHAPE__FLAGS, 0x00080000));
anchor = getAnchor().getEscherAnchor(); anchor = getAnchor().getEscherAnchor();
clientData.setRecordId(EscherClientDataRecord.RECORD_ID); clientData.setRecordId(EscherClientDataRecord.RECORD_ID);

View File

@ -17,12 +17,15 @@
package org.apache.poi.hssf.usermodel; package org.apache.poi.hssf.usermodel;
import static org.apache.poi.hssf.record.TextObjectRecord.HORIZONTAL_TEXT_ALIGNMENT_CENTERED;
import static org.apache.poi.hssf.record.TextObjectRecord.VERTICAL_TEXT_ALIGNMENT_CENTER;
import org.apache.poi.ddf.DefaultEscherRecordFactory; import org.apache.poi.ddf.DefaultEscherRecordFactory;
import org.apache.poi.ddf.EscherBoolProperty; import org.apache.poi.ddf.EscherBoolProperty;
import org.apache.poi.ddf.EscherClientDataRecord; import org.apache.poi.ddf.EscherClientDataRecord;
import org.apache.poi.ddf.EscherContainerRecord; import org.apache.poi.ddf.EscherContainerRecord;
import org.apache.poi.ddf.EscherOptRecord; import org.apache.poi.ddf.EscherOptRecord;
import org.apache.poi.ddf.EscherProperties; import org.apache.poi.ddf.EscherPropertyTypes;
import org.apache.poi.ddf.EscherRGBProperty; import org.apache.poi.ddf.EscherRGBProperty;
import org.apache.poi.ddf.EscherShapePathProperty; import org.apache.poi.ddf.EscherShapePathProperty;
import org.apache.poi.ddf.EscherSimpleProperty; import org.apache.poi.ddf.EscherSimpleProperty;
@ -36,9 +39,6 @@ import org.apache.poi.hssf.record.TextObjectRecord;
import org.apache.poi.ss.usermodel.RichTextString; import org.apache.poi.ss.usermodel.RichTextString;
import org.apache.poi.ss.usermodel.SimpleShape; import org.apache.poi.ss.usermodel.SimpleShape;
import static org.apache.poi.hssf.record.TextObjectRecord.HORIZONTAL_TEXT_ALIGNMENT_CENTERED;
import static org.apache.poi.hssf.record.TextObjectRecord.VERTICAL_TEXT_ALIGNMENT_CENTER;
/** /**
* Represents a simple shape such as a line, rectangle or oval. * Represents a simple shape such as a line, rectangle or oval.
*/ */
@ -121,16 +121,16 @@ public class HSSFSimpleShape extends HSSFShape implements SimpleShape
clientData.setOptions( (short) (0x0000) ); clientData.setOptions( (short) (0x0000) );
EscherOptRecord optRecord = new EscherOptRecord(); EscherOptRecord optRecord = new EscherOptRecord();
optRecord.setEscherProperty(new EscherSimpleProperty(EscherProperties.LINESTYLE__LINEDASHING, LINESTYLE_SOLID)); optRecord.setEscherProperty(new EscherSimpleProperty(EscherPropertyTypes.LINESTYLE__LINEDASHING, LINESTYLE_SOLID));
optRecord.setEscherProperty( new EscherBoolProperty( EscherProperties.LINESTYLE__NOLINEDRAWDASH, 0x00080008)); optRecord.setEscherProperty( new EscherBoolProperty( EscherPropertyTypes.LINESTYLE__NOLINEDRAWDASH, 0x00080008));
// optRecord.setEscherProperty(new EscherSimpleProperty(EscherProperties.LINESTYLE__LINEWIDTH, LINEWIDTH_DEFAULT)); // optRecord.setEscherProperty(new EscherSimpleProperty(EscherProperties.LINESTYLE__LINEWIDTH, LINEWIDTH_DEFAULT));
optRecord.setEscherProperty(new EscherRGBProperty(EscherProperties.FILL__FILLCOLOR, FILL__FILLCOLOR_DEFAULT)); optRecord.setEscherProperty(new EscherRGBProperty(EscherPropertyTypes.FILL__FILLCOLOR, FILL__FILLCOLOR_DEFAULT));
optRecord.setEscherProperty(new EscherRGBProperty(EscherProperties.LINESTYLE__COLOR, LINESTYLE__COLOR_DEFAULT)); optRecord.setEscherProperty(new EscherRGBProperty(EscherPropertyTypes.LINESTYLE__COLOR, LINESTYLE__COLOR_DEFAULT));
optRecord.setEscherProperty(new EscherBoolProperty(EscherProperties.FILL__NOFILLHITTEST, NO_FILLHITTEST_FALSE)); optRecord.setEscherProperty(new EscherBoolProperty(EscherPropertyTypes.FILL__NOFILLHITTEST, NO_FILLHITTEST_FALSE));
optRecord.setEscherProperty( new EscherBoolProperty( EscherProperties.LINESTYLE__NOLINEDRAWDASH, 0x00080008)); optRecord.setEscherProperty( new EscherBoolProperty( EscherPropertyTypes.LINESTYLE__NOLINEDRAWDASH, 0x00080008));
optRecord.setEscherProperty( new EscherShapePathProperty( EscherProperties.GEOMETRY__SHAPEPATH, EscherShapePathProperty.COMPLEX ) ); optRecord.setEscherProperty( new EscherShapePathProperty( EscherPropertyTypes.GEOMETRY__SHAPEPATH, EscherShapePathProperty.COMPLEX ) );
optRecord.setEscherProperty(new EscherBoolProperty( EscherProperties.GROUPSHAPE__PRINT, 0x080000)); optRecord.setEscherProperty(new EscherBoolProperty( EscherPropertyTypes.GROUPSHAPE__FLAGS, 0x080000));
optRecord.setRecordId( EscherOptRecord.RECORD_ID ); optRecord.setRecordId( EscherOptRecord.RECORD_ID );
EscherTextboxRecord escherTextbox = new EscherTextboxRecord(); EscherTextboxRecord escherTextbox = new EscherTextboxRecord();
@ -189,7 +189,7 @@ public class HSSFSimpleShape extends HSSFShape implements SimpleShape
TextObjectRecord txo = getOrCreateTextObjRecord(); TextObjectRecord txo = getOrCreateTextObjRecord();
txo.setStr(rtr); txo.setStr(rtr);
if (string.getString() != null){ if (string.getString() != null){
setPropertyValue(new EscherSimpleProperty(EscherProperties.TEXT__TEXTID, string.getString().hashCode())); setPropertyValue(new EscherSimpleProperty(EscherPropertyTypes.TEXT__TEXTID, string.getString().hashCode()));
} }
} }
@ -233,12 +233,12 @@ public class HSSFSimpleShape extends HSSFShape implements SimpleShape
} }
public int getWrapText(){ public int getWrapText(){
EscherSimpleProperty property = getOptRecord().lookup(EscherProperties.TEXT__WRAPTEXT); EscherSimpleProperty property = getOptRecord().lookup(EscherPropertyTypes.TEXT__WRAPTEXT);
return null == property ? WRAP_SQUARE : property.getPropertyValue(); return null == property ? WRAP_SQUARE : property.getPropertyValue();
} }
public void setWrapText(int value){ public void setWrapText(int value){
setPropertyValue(new EscherSimpleProperty(EscherProperties.TEXT__WRAPTEXT, false, false, value)); setPropertyValue(new EscherSimpleProperty(EscherPropertyTypes.TEXT__WRAPTEXT, false, false, value));
} }
/** /**

View File

@ -17,8 +17,22 @@
package org.apache.poi.hssf.usermodel; package org.apache.poi.hssf.usermodel;
import org.apache.poi.ddf.*; import org.apache.poi.ddf.DefaultEscherRecordFactory;
import org.apache.poi.hssf.record.*; import org.apache.poi.ddf.EscherBoolProperty;
import org.apache.poi.ddf.EscherClientDataRecord;
import org.apache.poi.ddf.EscherContainerRecord;
import org.apache.poi.ddf.EscherOptRecord;
import org.apache.poi.ddf.EscherPropertyTypes;
import org.apache.poi.ddf.EscherRGBProperty;
import org.apache.poi.ddf.EscherRecord;
import org.apache.poi.ddf.EscherSimpleProperty;
import org.apache.poi.ddf.EscherSpRecord;
import org.apache.poi.ddf.EscherTextboxRecord;
import org.apache.poi.hssf.record.CommonObjectDataSubRecord;
import org.apache.poi.hssf.record.EndSubRecord;
import org.apache.poi.hssf.record.EscherAggregate;
import org.apache.poi.hssf.record.ObjRecord;
import org.apache.poi.hssf.record.TextObjectRecord;
/** /**
* A textbox is a shape that may hold a rich text string. * A textbox is a shape that may hold a rich text string.
@ -94,23 +108,23 @@ public class HSSFTextbox extends HSSFSimpleShape {
sp.setFlags(EscherSpRecord.FLAG_HAVEANCHOR | EscherSpRecord.FLAG_HASSHAPETYPE); sp.setFlags(EscherSpRecord.FLAG_HAVEANCHOR | EscherSpRecord.FLAG_HASSHAPETYPE);
opt.setRecordId(EscherOptRecord.RECORD_ID); opt.setRecordId(EscherOptRecord.RECORD_ID);
opt.addEscherProperty(new EscherSimpleProperty(EscherProperties.TEXT__TEXTID, 0)); opt.addEscherProperty(new EscherSimpleProperty(EscherPropertyTypes.TEXT__TEXTID, 0));
opt.addEscherProperty(new EscherSimpleProperty(EscherProperties.TEXT__WRAPTEXT, 0)); opt.addEscherProperty(new EscherSimpleProperty(EscherPropertyTypes.TEXT__WRAPTEXT, 0));
opt.addEscherProperty(new EscherSimpleProperty(EscherProperties.TEXT__ANCHORTEXT, 0)); opt.addEscherProperty(new EscherSimpleProperty(EscherPropertyTypes.TEXT__ANCHORTEXT, 0));
opt.addEscherProperty(new EscherSimpleProperty(EscherProperties.GROUPSHAPE__PRINT, 0x00080000)); opt.addEscherProperty(new EscherSimpleProperty(EscherPropertyTypes.GROUPSHAPE__FLAGS, 0x00080000));
opt.addEscherProperty(new EscherSimpleProperty(EscherProperties.TEXT__TEXTLEFT, 0)); opt.addEscherProperty(new EscherSimpleProperty(EscherPropertyTypes.TEXT__TEXTLEFT, 0));
opt.addEscherProperty(new EscherSimpleProperty(EscherProperties.TEXT__TEXTRIGHT, 0)); opt.addEscherProperty(new EscherSimpleProperty(EscherPropertyTypes.TEXT__TEXTRIGHT, 0));
opt.addEscherProperty(new EscherSimpleProperty(EscherProperties.TEXT__TEXTTOP, 0)); opt.addEscherProperty(new EscherSimpleProperty(EscherPropertyTypes.TEXT__TEXTTOP, 0));
opt.addEscherProperty(new EscherSimpleProperty(EscherProperties.TEXT__TEXTBOTTOM, 0)); opt.addEscherProperty(new EscherSimpleProperty(EscherPropertyTypes.TEXT__TEXTBOTTOM, 0));
opt.setEscherProperty(new EscherSimpleProperty(EscherProperties.LINESTYLE__LINEDASHING, LINESTYLE_SOLID)); opt.setEscherProperty(new EscherSimpleProperty(EscherPropertyTypes.LINESTYLE__LINEDASHING, LINESTYLE_SOLID));
opt.setEscherProperty(new EscherBoolProperty(EscherProperties.LINESTYLE__NOLINEDRAWDASH, 0x00080008)); opt.setEscherProperty(new EscherBoolProperty(EscherPropertyTypes.LINESTYLE__NOLINEDRAWDASH, 0x00080008));
opt.setEscherProperty(new EscherSimpleProperty(EscherProperties.LINESTYLE__LINEWIDTH, LINEWIDTH_DEFAULT)); opt.setEscherProperty(new EscherSimpleProperty(EscherPropertyTypes.LINESTYLE__LINEWIDTH, LINEWIDTH_DEFAULT));
opt.setEscherProperty(new EscherRGBProperty(EscherProperties.FILL__FILLCOLOR, FILL__FILLCOLOR_DEFAULT)); opt.setEscherProperty(new EscherRGBProperty(EscherPropertyTypes.FILL__FILLCOLOR, FILL__FILLCOLOR_DEFAULT));
opt.setEscherProperty(new EscherRGBProperty(EscherProperties.LINESTYLE__COLOR, LINESTYLE__COLOR_DEFAULT)); opt.setEscherProperty(new EscherRGBProperty(EscherPropertyTypes.LINESTYLE__COLOR, LINESTYLE__COLOR_DEFAULT));
opt.setEscherProperty(new EscherBoolProperty(EscherProperties.FILL__NOFILLHITTEST, NO_FILLHITTEST_FALSE)); opt.setEscherProperty(new EscherBoolProperty(EscherPropertyTypes.FILL__NOFILLHITTEST, NO_FILLHITTEST_FALSE));
opt.setEscherProperty(new EscherBoolProperty(EscherProperties.GROUPSHAPE__PRINT, 0x080000)); opt.setEscherProperty(new EscherBoolProperty(EscherPropertyTypes.GROUPSHAPE__FLAGS, 0x080000));
EscherRecord anchor = getAnchor().getEscherAnchor(); EscherRecord anchor = getAnchor().getEscherAnchor();
clientData.setRecordId(EscherClientDataRecord.RECORD_ID); clientData.setRecordId(EscherClientDataRecord.RECORD_ID);
@ -140,7 +154,7 @@ public class HSSFTextbox extends HSSFSimpleShape {
* @return Returns the left margin within the textbox. * @return Returns the left margin within the textbox.
*/ */
public int getMarginLeft() { public int getMarginLeft() {
EscherSimpleProperty property = getOptRecord().lookup(EscherProperties.TEXT__TEXTLEFT); EscherSimpleProperty property = getOptRecord().lookup(EscherPropertyTypes.TEXT__TEXTLEFT);
return property == null ? 0 : property.getPropertyValue(); return property == null ? 0 : property.getPropertyValue();
} }
@ -148,14 +162,14 @@ public class HSSFTextbox extends HSSFSimpleShape {
* Sets the left margin within the textbox. * Sets the left margin within the textbox.
*/ */
public void setMarginLeft(int marginLeft) { public void setMarginLeft(int marginLeft) {
setPropertyValue(new EscherSimpleProperty(EscherProperties.TEXT__TEXTLEFT, marginLeft)); setPropertyValue(new EscherSimpleProperty(EscherPropertyTypes.TEXT__TEXTLEFT, marginLeft));
} }
/** /**
* @return returns the right margin within the textbox. * @return returns the right margin within the textbox.
*/ */
public int getMarginRight() { public int getMarginRight() {
EscherSimpleProperty property = getOptRecord().lookup(EscherProperties.TEXT__TEXTRIGHT); EscherSimpleProperty property = getOptRecord().lookup(EscherPropertyTypes.TEXT__TEXTRIGHT);
return property == null ? 0 : property.getPropertyValue(); return property == null ? 0 : property.getPropertyValue();
} }
@ -163,14 +177,14 @@ public class HSSFTextbox extends HSSFSimpleShape {
* Sets the right margin within the textbox. * Sets the right margin within the textbox.
*/ */
public void setMarginRight(int marginRight) { public void setMarginRight(int marginRight) {
setPropertyValue(new EscherSimpleProperty(EscherProperties.TEXT__TEXTRIGHT, marginRight)); setPropertyValue(new EscherSimpleProperty(EscherPropertyTypes.TEXT__TEXTRIGHT, marginRight));
} }
/** /**
* @return returns the top margin within the textbox. * @return returns the top margin within the textbox.
*/ */
public int getMarginTop() { public int getMarginTop() {
EscherSimpleProperty property = getOptRecord().lookup(EscherProperties.TEXT__TEXTTOP); EscherSimpleProperty property = getOptRecord().lookup(EscherPropertyTypes.TEXT__TEXTTOP);
return property == null ? 0 : property.getPropertyValue(); return property == null ? 0 : property.getPropertyValue();
} }
@ -178,14 +192,14 @@ public class HSSFTextbox extends HSSFSimpleShape {
* Sets the top margin within the textbox. * Sets the top margin within the textbox.
*/ */
public void setMarginTop(int marginTop) { public void setMarginTop(int marginTop) {
setPropertyValue(new EscherSimpleProperty(EscherProperties.TEXT__TEXTTOP, marginTop)); setPropertyValue(new EscherSimpleProperty(EscherPropertyTypes.TEXT__TEXTTOP, marginTop));
} }
/** /**
* Gets the bottom margin within the textbox. * Gets the bottom margin within the textbox.
*/ */
public int getMarginBottom() { public int getMarginBottom() {
EscherSimpleProperty property = getOptRecord().lookup(EscherProperties.TEXT__TEXTBOTTOM); EscherSimpleProperty property = getOptRecord().lookup(EscherPropertyTypes.TEXT__TEXTBOTTOM);
return property == null ? 0 : property.getPropertyValue(); return property == null ? 0 : property.getPropertyValue();
} }
@ -193,7 +207,7 @@ public class HSSFTextbox extends HSSFSimpleShape {
* Sets the bottom margin within the textbox. * Sets the bottom margin within the textbox.
*/ */
public void setMarginBottom(int marginBottom) { public void setMarginBottom(int marginBottom) {
setPropertyValue(new EscherSimpleProperty(EscherProperties.TEXT__TEXTBOTTOM, marginBottom)); setPropertyValue(new EscherSimpleProperty(EscherPropertyTypes.TEXT__TEXTBOTTOM, marginBottom));
} }
/** /**

View File

@ -38,7 +38,7 @@ public interface PictureData {
/** GIF image format */ /** GIF image format */
GIF(-1,8,"image/gif",".gif"), GIF(-1,8,"image/gif",".gif"),
/** Tag Image File (.tiff) */ /** Tag Image File (.tiff) */
TIFF(-1,9,"image/tiff",".tif"), TIFF(17,9,"image/tiff",".tif"),
/** Encapsulated Postscript (.eps) */ /** Encapsulated Postscript (.eps) */
EPS(-1,10,"image/x-eps",".eps"), EPS(-1,10,"image/x-eps",".eps"),
/** Windows Bitmap (.bmp) */ /** Windows Bitmap (.bmp) */
@ -48,7 +48,15 @@ public interface PictureData {
/** Microsoft Windows Media Photo image (.wdp) */ /** Microsoft Windows Media Photo image (.wdp) */
WDP(-1,13,"image/vnd.ms-photo",".wdp"), WDP(-1,13,"image/vnd.ms-photo",".wdp"),
/** Scalable vector graphics (.svg) - supported by Office 2016 and higher */ /** Scalable vector graphics (.svg) - supported by Office 2016 and higher */
SVG(-1, -1, "image/svg+xml", ".svg") SVG(-1, -1, "image/svg+xml", ".svg"),
/** Unknown picture type - specific to escher bse record */
UNKNOWN(1, -1, "", ".dat"),
/** Picture type error - specific to escher bse record */
ERROR(0, -1, "", ".dat"),
/** JPEG in the YCCK or CMYK color space. */
CMYKJPEG( 18, -1, "image/jpeg", ".jpg"),
/** client defined blip type - native-id 32 to 255 */
CLIENT( 32, -1, "", ".dat")
; ;
public final int nativeId, ooxmlId; public final int nativeId, ooxmlId;
@ -65,7 +73,7 @@ public interface PictureData {
for (PictureType ans : values()) { for (PictureType ans : values()) {
if (ans.nativeId == nativeId) return ans; if (ans.nativeId == nativeId) return ans;
} }
return null; return nativeId >= CLIENT.nativeId ? CLIENT : UNKNOWN;
} }
public static PictureType forOoxmlID(int ooxmlId) { public static PictureType forOoxmlID(int ooxmlId) {

View File

@ -20,7 +20,7 @@ package org.apache.poi.hslf.model;
import org.apache.poi.ddf.AbstractEscherOptRecord; import org.apache.poi.ddf.AbstractEscherOptRecord;
import org.apache.poi.ddf.EscherComplexProperty; import org.apache.poi.ddf.EscherComplexProperty;
import org.apache.poi.ddf.EscherContainerRecord; import org.apache.poi.ddf.EscherContainerRecord;
import org.apache.poi.ddf.EscherProperties; import org.apache.poi.ddf.EscherPropertyTypes;
import org.apache.poi.ddf.EscherSpRecord; import org.apache.poi.ddf.EscherSpRecord;
import org.apache.poi.hslf.exceptions.HSLFException; import org.apache.poi.hslf.exceptions.HSLFException;
import org.apache.poi.hslf.record.Document; import org.apache.poi.hslf.record.Document;
@ -79,11 +79,11 @@ public final class ActiveXShape extends HSLFPictureShape {
spRecord.setFlags(EscherSpRecord.FLAG_HAVEANCHOR | EscherSpRecord.FLAG_HASSHAPETYPE | EscherSpRecord.FLAG_OLESHAPE); spRecord.setFlags(EscherSpRecord.FLAG_HAVEANCHOR | EscherSpRecord.FLAG_HASSHAPETYPE | EscherSpRecord.FLAG_OLESHAPE);
setShapeType(ShapeType.HOST_CONTROL); setShapeType(ShapeType.HOST_CONTROL);
setEscherProperty(EscherProperties.BLIP__PICTUREID, idx); setEscherProperty(EscherPropertyTypes.BLIP__PICTUREID, idx);
setEscherProperty(EscherProperties.LINESTYLE__COLOR, 0x8000001); setEscherProperty(EscherPropertyTypes.LINESTYLE__COLOR, 0x8000001);
setEscherProperty(EscherProperties.LINESTYLE__NOLINEDRAWDASH, 0x80008); setEscherProperty(EscherPropertyTypes.LINESTYLE__NOLINEDRAWDASH, 0x80008);
setEscherProperty(EscherProperties.SHADOWSTYLE__COLOR, 0x8000002); setEscherProperty(EscherPropertyTypes.SHADOWSTYLE__COLOR, 0x8000002);
setEscherProperty(EscherProperties.PROTECTION__LOCKAGAINSTGROUPING, -1); setEscherProperty(EscherPropertyTypes.PROTECTION__LOCKAGAINSTGROUPING, -1);
HSLFEscherClientDataRecord cldata = getClientData(true); HSLFEscherClientDataRecord cldata = getClientData(true);
cldata.addChild(new ExObjRefAtom()); cldata.addChild(new ExObjRefAtom());
@ -155,7 +155,8 @@ public final class ActiveXShape extends HSLFPictureShape {
String name = ctrl.getProgId() + "-" + getControlIndex() + '\u0000'; String name = ctrl.getProgId() + "-" + getControlIndex() + '\u0000';
byte[] data = StringUtil.getToUnicodeLE(name); byte[] data = StringUtil.getToUnicodeLE(name);
EscherComplexProperty prop = new EscherComplexProperty(EscherProperties.GROUPSHAPE__SHAPENAME, false, data); EscherComplexProperty prop = new EscherComplexProperty(EscherPropertyTypes.GROUPSHAPE__SHAPENAME, false, data.length);
prop.setComplexData(data);
AbstractEscherOptRecord opt = getEscherOptRecord(); AbstractEscherOptRecord opt = getEscherOptRecord();
opt.addEscherProperty(prop); opt.addEscherProperty(prop);
} }

View File

@ -21,7 +21,7 @@ import java.lang.reflect.Method;
import org.apache.poi.ddf.AbstractEscherOptRecord; import org.apache.poi.ddf.AbstractEscherOptRecord;
import org.apache.poi.ddf.EscherComplexProperty; import org.apache.poi.ddf.EscherComplexProperty;
import org.apache.poi.ddf.EscherProperties; import org.apache.poi.ddf.EscherPropertyTypes;
import org.apache.poi.ddf.EscherTertiaryOptRecord; import org.apache.poi.ddf.EscherTertiaryOptRecord;
import org.apache.poi.hslf.usermodel.HSLFShape; import org.apache.poi.hslf.usermodel.HSLFShape;
import org.apache.poi.sl.usermodel.Shape; import org.apache.poi.sl.usermodel.Shape;
@ -60,7 +60,7 @@ public class HSLFMetroShape<T extends Shape<?,?>> {
private EscherComplexProperty getMetroProp() { private EscherComplexProperty getMetroProp() {
AbstractEscherOptRecord opt = shape.getEscherChild(EscherTertiaryOptRecord.RECORD_ID); AbstractEscherOptRecord opt = shape.getEscherChild(EscherTertiaryOptRecord.RECORD_ID);
return (opt == null) ? null : (EscherComplexProperty)opt.lookup(EscherProperties.GROUPSHAPE__METROBLOB); return (opt == null) ? null : (EscherComplexProperty)opt.lookup(EscherPropertyTypes.GROUPSHAPE__METROBLOB.propNumber);
} }
/** /**

View File

@ -18,7 +18,7 @@
package org.apache.poi.hslf.model; package org.apache.poi.hslf.model;
import org.apache.poi.ddf.EscherContainerRecord; import org.apache.poi.ddf.EscherContainerRecord;
import org.apache.poi.ddf.EscherProperties; import org.apache.poi.ddf.EscherPropertyTypes;
import org.apache.poi.hslf.record.AnimationInfo; import org.apache.poi.hslf.record.AnimationInfo;
import org.apache.poi.hslf.record.AnimationInfoAtom; import org.apache.poi.hslf.record.AnimationInfoAtom;
import org.apache.poi.hslf.record.ExMCIMovie; import org.apache.poi.hslf.record.ExMCIMovie;
@ -90,8 +90,8 @@ public final class MovieShape extends HSLFPictureShape {
protected EscherContainerRecord createSpContainer(int idx, boolean isChild) { protected EscherContainerRecord createSpContainer(int idx, boolean isChild) {
EscherContainerRecord ecr = super.createSpContainer(idx, isChild); EscherContainerRecord ecr = super.createSpContainer(idx, isChild);
setEscherProperty(EscherProperties.PROTECTION__LOCKAGAINSTGROUPING, 0x1000100); setEscherProperty(EscherPropertyTypes.PROTECTION__LOCKAGAINSTGROUPING, 0x1000100);
setEscherProperty(EscherProperties.FILL__NOFILLHITTEST, 0x10001); setEscherProperty(EscherPropertyTypes.FILL__NOFILLHITTEST, 0x10001);
ExObjRefAtom oe = new ExObjRefAtom(); ExObjRefAtom oe = new ExObjRefAtom();
InteractiveInfo info = new InteractiveInfo(); InteractiveInfo info = new InteractiveInfo();

View File

@ -17,15 +17,22 @@
package org.apache.poi.hslf.model; package org.apache.poi.hslf.model;
import org.apache.poi.ddf.*; import java.awt.geom.Point2D;
import org.apache.poi.hslf.usermodel.*;
import org.apache.poi.ddf.AbstractEscherOptRecord;
import org.apache.poi.ddf.EscherArrayProperty;
import org.apache.poi.ddf.EscherContainerRecord;
import org.apache.poi.ddf.EscherPropertyTypes;
import org.apache.poi.ddf.EscherSimpleProperty;
import org.apache.poi.hslf.usermodel.HSLFAutoShape;
import org.apache.poi.hslf.usermodel.HSLFGroupShape;
import org.apache.poi.hslf.usermodel.HSLFShape;
import org.apache.poi.hslf.usermodel.HSLFTextParagraph;
import org.apache.poi.sl.usermodel.ShapeContainer; import org.apache.poi.sl.usermodel.ShapeContainer;
import org.apache.poi.sl.usermodel.ShapeType; import org.apache.poi.sl.usermodel.ShapeType;
import org.apache.poi.util.LittleEndian; import org.apache.poi.util.LittleEndian;
import org.apache.poi.util.Units; import org.apache.poi.util.Units;
import java.awt.geom.Point2D;
/** /**
* A simple closed polygon shape * A simple closed polygon shape
* *
@ -76,8 +83,8 @@ public final class Polygon extends HSLFAutoShape {
float top = findSmallest(yPoints); float top = findSmallest(yPoints);
AbstractEscherOptRecord opt = getEscherOptRecord(); AbstractEscherOptRecord opt = getEscherOptRecord();
opt.addEscherProperty(new EscherSimpleProperty(EscherProperties.GEOMETRY__RIGHT, Units.pointsToMaster(right - left))); opt.addEscherProperty(new EscherSimpleProperty(EscherPropertyTypes.GEOMETRY__RIGHT, Units.pointsToMaster(right - left)));
opt.addEscherProperty(new EscherSimpleProperty(EscherProperties.GEOMETRY__BOTTOM, Units.pointsToMaster(bottom - top))); opt.addEscherProperty(new EscherSimpleProperty(EscherPropertyTypes.GEOMETRY__BOTTOM, Units.pointsToMaster(bottom - top)));
for (int i = 0; i < xPoints.length; i++) { for (int i = 0; i < xPoints.length; i++) {
xPoints[i] += -left; xPoints[i] += -left;
@ -86,7 +93,7 @@ public final class Polygon extends HSLFAutoShape {
int numpoints = xPoints.length; int numpoints = xPoints.length;
EscherArrayProperty verticesProp = new EscherArrayProperty(EscherProperties.GEOMETRY__VERTICES, false, new byte[0] ); EscherArrayProperty verticesProp = new EscherArrayProperty(EscherPropertyTypes.GEOMETRY__VERTICES, false, 0);
verticesProp.setNumberOfElementsInArray(numpoints+1); verticesProp.setNumberOfElementsInArray(numpoints+1);
verticesProp.setNumberOfElementsInMemory(numpoints+1); verticesProp.setNumberOfElementsInMemory(numpoints+1);
verticesProp.setSizeOfElements(0xFFF0); verticesProp.setSizeOfElements(0xFFF0);
@ -103,7 +110,7 @@ public final class Polygon extends HSLFAutoShape {
verticesProp.setElement(numpoints, data); verticesProp.setElement(numpoints, data);
opt.addEscherProperty(verticesProp); opt.addEscherProperty(verticesProp);
EscherArrayProperty segmentsProp = new EscherArrayProperty(EscherProperties.GEOMETRY__SEGMENTINFO, false, null ); EscherArrayProperty segmentsProp = new EscherArrayProperty(EscherPropertyTypes.GEOMETRY__SEGMENTINFO, false, 0);
segmentsProp.setSizeOfElements(0x0002); segmentsProp.setSizeOfElements(0x0002);
segmentsProp.setNumberOfElementsInArray(numpoints * 2 + 4); segmentsProp.setNumberOfElementsInArray(numpoints * 2 + 4);
segmentsProp.setNumberOfElementsInMemory(numpoints * 2 + 4); segmentsProp.setNumberOfElementsInMemory(numpoints * 2 + 4);

View File

@ -93,16 +93,6 @@ public class EscherPlaceholder extends EscherRecord {
return size; return size;
} }
@Override
protected Object[][] getAttributeMap() {
return new Object[][] {
{ "position", position },
{ "placementId", placementId },
{ "placehoder size", size },
{ "unused", unused }
};
}
@Override @Override
public Map<String, Supplier<?>> getGenericProperties() { public Map<String, Supplier<?>> getGenericProperties() {
return GenericRecordUtil.getGenericProperties( return GenericRecordUtil.getGenericProperties(

View File

@ -35,7 +35,7 @@ import org.apache.poi.ddf.EscherBoolProperty;
import org.apache.poi.ddf.EscherContainerRecord; import org.apache.poi.ddf.EscherContainerRecord;
import org.apache.poi.ddf.EscherDgRecord; import org.apache.poi.ddf.EscherDgRecord;
import org.apache.poi.ddf.EscherOptRecord; import org.apache.poi.ddf.EscherOptRecord;
import org.apache.poi.ddf.EscherProperties; import org.apache.poi.ddf.EscherPropertyTypes;
import org.apache.poi.ddf.EscherRGBProperty; import org.apache.poi.ddf.EscherRGBProperty;
import org.apache.poi.ddf.EscherRecord; import org.apache.poi.ddf.EscherRecord;
import org.apache.poi.ddf.EscherRecordTypes; import org.apache.poi.ddf.EscherRecordTypes;
@ -331,14 +331,14 @@ public final class PPDrawing extends RecordAtom implements Iterable<EscherRecord
EscherOptRecord opt = new EscherOptRecord(); EscherOptRecord opt = new EscherOptRecord();
opt.setRecordId(EscherOptRecord.RECORD_ID); opt.setRecordId(EscherOptRecord.RECORD_ID);
opt.addEscherProperty(new EscherRGBProperty(EscherProperties.FILL__FILLCOLOR, 134217728)); opt.addEscherProperty(new EscherRGBProperty(EscherPropertyTypes.FILL__FILLCOLOR, 134217728));
opt.addEscherProperty(new EscherRGBProperty(EscherProperties.FILL__FILLBACKCOLOR, 134217733)); opt.addEscherProperty(new EscherRGBProperty(EscherPropertyTypes.FILL__FILLBACKCOLOR, 134217733));
opt.addEscherProperty(new EscherSimpleProperty(EscherProperties.FILL__RECTRIGHT, 10064750)); opt.addEscherProperty(new EscherSimpleProperty(EscherPropertyTypes.FILL__RECTRIGHT, 10064750));
opt.addEscherProperty(new EscherSimpleProperty(EscherProperties.FILL__RECTBOTTOM, 7778750)); opt.addEscherProperty(new EscherSimpleProperty(EscherPropertyTypes.FILL__RECTBOTTOM, 7778750));
opt.addEscherProperty(new EscherBoolProperty(EscherProperties.FILL__NOFILLHITTEST, 1179666)); opt.addEscherProperty(new EscherBoolProperty(EscherPropertyTypes.FILL__NOFILLHITTEST, 1179666));
opt.addEscherProperty(new EscherBoolProperty(EscherProperties.LINESTYLE__NOLINEDRAWDASH, 524288)); opt.addEscherProperty(new EscherBoolProperty(EscherPropertyTypes.LINESTYLE__NOLINEDRAWDASH, 524288));
opt.addEscherProperty(new EscherSimpleProperty(EscherProperties.SHAPE__BLACKANDWHITESETTINGS, 9)); opt.addEscherProperty(new EscherSimpleProperty(EscherPropertyTypes.SHAPE__BLACKANDWHITESETTINGS, 9));
opt.addEscherProperty(new EscherSimpleProperty(EscherProperties.SHAPE__BACKGROUNDSHAPE, 65537)); opt.addEscherProperty(new EscherSimpleProperty(EscherPropertyTypes.SHAPE__BACKGROUNDSHAPE, 65537));
spContainer.addChildRecord(opt); spContainer.addChildRecord(opt);
dgContainer.addChildRecord(spContainer); dgContainer.addChildRecord(spContainer);

View File

@ -27,8 +27,7 @@ import java.util.List;
import org.apache.poi.ddf.AbstractEscherOptRecord; import org.apache.poi.ddf.AbstractEscherOptRecord;
import org.apache.poi.ddf.EscherArrayProperty; import org.apache.poi.ddf.EscherArrayProperty;
import org.apache.poi.ddf.EscherContainerRecord; import org.apache.poi.ddf.EscherContainerRecord;
import org.apache.poi.ddf.EscherProperties; import org.apache.poi.ddf.EscherPropertyTypes;
import org.apache.poi.ddf.EscherProperty;
import org.apache.poi.ddf.EscherSimpleProperty; import org.apache.poi.ddf.EscherSimpleProperty;
import org.apache.poi.sl.draw.binding.CTAdjPoint2D; import org.apache.poi.sl.draw.binding.CTAdjPoint2D;
import org.apache.poi.sl.draw.binding.CTCustomGeometry2D; import org.apache.poi.sl.draw.binding.CTCustomGeometry2D;
@ -73,6 +72,19 @@ public class HSLFAutoShape extends HSLFTextShape implements AutoShape<HSLFShape,
private static final BitField PATH_INFO = BitFieldFactory.getInstance(0xE000); private static final BitField PATH_INFO = BitFieldFactory.getInstance(0xE000);
private static final BitField ESCAPE_INFO = BitFieldFactory.getInstance(0x1F00); private static final BitField ESCAPE_INFO = BitFieldFactory.getInstance(0x1F00);
private static final EscherPropertyTypes[] ADJUST_VALUES = {
EscherPropertyTypes.GEOMETRY__ADJUSTVALUE,
EscherPropertyTypes.GEOMETRY__ADJUST2VALUE,
EscherPropertyTypes.GEOMETRY__ADJUST3VALUE,
EscherPropertyTypes.GEOMETRY__ADJUST4VALUE,
EscherPropertyTypes.GEOMETRY__ADJUST5VALUE,
EscherPropertyTypes.GEOMETRY__ADJUST6VALUE,
EscherPropertyTypes.GEOMETRY__ADJUST7VALUE,
EscherPropertyTypes.GEOMETRY__ADJUST8VALUE,
EscherPropertyTypes.GEOMETRY__ADJUST9VALUE,
EscherPropertyTypes.GEOMETRY__ADJUST10VALUE
};
enum PathInfo { enum PathInfo {
lineTo(0),curveTo(1),moveTo(2),close(3),end(4),escape(5),clientEscape(6); lineTo(0),curveTo(1),moveTo(2),close(3),end(4),escape(5),clientEscape(6);
private final int flag; private final int flag;
@ -153,14 +165,14 @@ public class HSLFAutoShape extends HSLFTextShape implements AutoShape<HSLFShape,
setShapeType(shapeType); setShapeType(shapeType);
//set default properties for an autoshape //set default properties for an autoshape
setEscherProperty(EscherProperties.PROTECTION__LOCKAGAINSTGROUPING, 0x40000); setEscherProperty(EscherPropertyTypes.PROTECTION__LOCKAGAINSTGROUPING, 0x40000);
setEscherProperty(EscherProperties.FILL__FILLCOLOR, 0x8000004); setEscherProperty(EscherPropertyTypes.FILL__FILLCOLOR, 0x8000004);
setEscherProperty(EscherProperties.FILL__FILLCOLOR, 0x8000004); setEscherProperty(EscherPropertyTypes.FILL__FILLCOLOR, 0x8000004);
setEscherProperty(EscherProperties.FILL__FILLBACKCOLOR, 0x8000000); setEscherProperty(EscherPropertyTypes.FILL__FILLBACKCOLOR, 0x8000000);
setEscherProperty(EscherProperties.FILL__NOFILLHITTEST, 0x100010); setEscherProperty(EscherPropertyTypes.FILL__NOFILLHITTEST, 0x100010);
setEscherProperty(EscherProperties.LINESTYLE__COLOR, 0x8000001); setEscherProperty(EscherPropertyTypes.LINESTYLE__COLOR, 0x8000001);
setEscherProperty(EscherProperties.LINESTYLE__NOLINEDRAWDASH, 0x80008); setEscherProperty(EscherPropertyTypes.LINESTYLE__NOLINEDRAWDASH, 0x80008);
setEscherProperty(EscherProperties.SHADOWSTYLE__COLOR, 0x8000002); setEscherProperty(EscherPropertyTypes.SHADOWSTYLE__COLOR, 0x8000002);
return ecr; return ecr;
} }
@ -184,8 +196,7 @@ public class HSLFAutoShape extends HSLFTextShape implements AutoShape<HSLFShape,
*/ */
public int getAdjustmentValue(int idx){ public int getAdjustmentValue(int idx){
if(idx < 0 || idx > 9) throw new IllegalArgumentException("The index of an adjustment value must be in the [0, 9] range"); if(idx < 0 || idx > 9) throw new IllegalArgumentException("The index of an adjustment value must be in the [0, 9] range");
return getEscherProperty(ADJUST_VALUES[idx]);
return getEscherProperty((short)(EscherProperties.GEOMETRY__ADJUSTVALUE + idx));
} }
/** /**
@ -200,8 +211,7 @@ public class HSLFAutoShape extends HSLFTextShape implements AutoShape<HSLFShape,
*/ */
public void setAdjustmentValue(int idx, int val){ public void setAdjustmentValue(int idx, int val){
if(idx < 0 || idx > 9) throw new IllegalArgumentException("The index of an adjustment value must be in the [0, 9] range"); if(idx < 0 || idx > 9) throw new IllegalArgumentException("The index of an adjustment value must be in the [0, 9] range");
setEscherProperty(ADJUST_VALUES[idx], val);
setEscherProperty((short)(EscherProperties.GEOMETRY__ADJUSTVALUE + idx), val);
} }
@Override @Override
@ -219,8 +229,8 @@ public class HSLFAutoShape extends HSLFTextShape implements AutoShape<HSLFShape,
final AbstractEscherOptRecord opt = getEscherOptRecord(); final AbstractEscherOptRecord opt = getEscherOptRecord();
EscherArrayProperty verticesProp = getShapeProp(opt, EscherProperties.GEOMETRY__VERTICES); EscherArrayProperty verticesProp = getEscherProperty(opt, EscherPropertyTypes.GEOMETRY__VERTICES);
EscherArrayProperty segmentsProp = getShapeProp(opt, EscherProperties.GEOMETRY__SEGMENTINFO); EscherArrayProperty segmentsProp = getEscherProperty(opt, EscherPropertyTypes.GEOMETRY__SEGMENTINFO);
// return empty path if either GEOMETRY__VERTICES or GEOMETRY__SEGMENTINFO is missing, see Bugzilla 54188 // return empty path if either GEOMETRY__VERTICES or GEOMETRY__SEGMENTINFO is missing, see Bugzilla 54188
@ -299,17 +309,17 @@ public class HSLFAutoShape extends HSLFTextShape implements AutoShape<HSLFShape,
} }
} }
EscherSimpleProperty shapePath = getShapeProp(opt, EscherProperties.GEOMETRY__SHAPEPATH); EscherSimpleProperty shapePath = getEscherProperty(opt, EscherPropertyTypes.GEOMETRY__SHAPEPATH);
HSLFFreeformShape.ShapePath sp = HSLFFreeformShape.ShapePath.valueOf(shapePath == null ? 1 : shapePath.getPropertyValue()); HSLFFreeformShape.ShapePath sp = HSLFFreeformShape.ShapePath.valueOf(shapePath == null ? 1 : shapePath.getPropertyValue());
if ((sp == HSLFFreeformShape.ShapePath.LINES_CLOSED || sp == HSLFFreeformShape.ShapePath.CURVES_CLOSED) && !isClosed) { if ((sp == HSLFFreeformShape.ShapePath.LINES_CLOSED || sp == HSLFFreeformShape.ShapePath.CURVES_CLOSED) && !isClosed) {
moveLst.add(of.createCTPath2DClose()); moveLst.add(of.createCTPath2DClose());
path2D.closePath(); path2D.closePath();
} }
EscherSimpleProperty geoLeft = getShapeProp(opt, EscherProperties.GEOMETRY__LEFT); EscherSimpleProperty geoLeft = getEscherProperty(opt, EscherPropertyTypes.GEOMETRY__LEFT);
EscherSimpleProperty geoRight = getShapeProp(opt, EscherProperties.GEOMETRY__RIGHT); EscherSimpleProperty geoRight = getEscherProperty(opt, EscherPropertyTypes.GEOMETRY__RIGHT);
EscherSimpleProperty geoTop = getShapeProp(opt, EscherProperties.GEOMETRY__TOP); EscherSimpleProperty geoTop = getEscherProperty(opt, EscherPropertyTypes.GEOMETRY__TOP);
EscherSimpleProperty geoBottom = getShapeProp(opt, EscherProperties.GEOMETRY__BOTTOM); EscherSimpleProperty geoBottom = getEscherProperty(opt, EscherPropertyTypes.GEOMETRY__BOTTOM);
final Rectangle2D bounds; final Rectangle2D bounds;
if (geoLeft != null && geoRight != null && geoTop != null && geoBottom != null) { if (geoLeft != null && geoRight != null && geoTop != null && geoBottom != null) {
@ -438,14 +448,6 @@ public class HSLFAutoShape extends HSLFTextShape implements AutoShape<HSLFShape,
} }
private static <T extends EscherProperty> T getShapeProp(AbstractEscherOptRecord opt, int propId) {
T prop = getEscherProperty(opt, (short)(propId + 0x4000));
if (prop == null) {
prop = getEscherProperty(opt, propId);
}
return prop;
}
private CTAdjPoint2D fillPoint(byte[] xyMaster, int[] xyPoints) { private CTAdjPoint2D fillPoint(byte[] xyMaster, int[] xyPoints) {
if (xyMaster == null || xyPoints == null) { if (xyMaster == null || xyPoints == null) {
LOG.log(POILogger.WARN, "Master bytes or points not set - ignore point"); LOG.log(POILogger.WARN, "Master bytes or points not set - ignore point");

View File

@ -27,7 +27,7 @@ import org.apache.poi.ddf.EscherArrayProperty;
import org.apache.poi.ddf.EscherBSERecord; import org.apache.poi.ddf.EscherBSERecord;
import org.apache.poi.ddf.EscherColorRef; import org.apache.poi.ddf.EscherColorRef;
import org.apache.poi.ddf.EscherContainerRecord; import org.apache.poi.ddf.EscherContainerRecord;
import org.apache.poi.ddf.EscherProperties; import org.apache.poi.ddf.EscherPropertyTypes;
import org.apache.poi.ddf.EscherRecord; import org.apache.poi.ddf.EscherRecord;
import org.apache.poi.ddf.EscherRecordTypes; import org.apache.poi.ddf.EscherRecordTypes;
import org.apache.poi.ddf.EscherSimpleProperty; import org.apache.poi.ddf.EscherSimpleProperty;
@ -258,14 +258,14 @@ public final class HSLFFill {
// NOFILLHITTEST can be in the normal escher opt record but also in the tertiary record // NOFILLHITTEST can be in the normal escher opt record but also in the tertiary record
// the extended bit fields seem to be in the second // the extended bit fields seem to be in the second
AbstractEscherOptRecord opt = shape.getEscherChild(EscherRecordTypes.USER_DEFINED); AbstractEscherOptRecord opt = shape.getEscherChild(EscherRecordTypes.USER_DEFINED);
EscherSimpleProperty p = HSLFShape.getEscherProperty(opt, EscherProperties.FILL__NOFILLHITTEST); EscherSimpleProperty p = HSLFShape.getEscherProperty(opt, EscherPropertyTypes.FILL__NOFILLHITTEST);
int propVal = (p == null) ? 0 : p.getPropertyValue(); int propVal = (p == null) ? 0 : p.getPropertyValue();
return FILL_USE_USE_SHAPE_ANCHOR.isSet(propVal) && FILL_USE_SHAPE_ANCHOR.isSet(propVal); return FILL_USE_USE_SHAPE_ANCHOR.isSet(propVal) && FILL_USE_SHAPE_ANCHOR.isSet(propVal);
} }
private GradientPaint getGradientPaint(final GradientType gradientType) { private GradientPaint getGradientPaint(final GradientType gradientType) {
AbstractEscherOptRecord opt = shape.getEscherOptRecord(); AbstractEscherOptRecord opt = shape.getEscherOptRecord();
final EscherArrayProperty ep = HSLFShape.getEscherProperty(opt, EscherProperties.FILL__SHADECOLORS); final EscherArrayProperty ep = HSLFShape.getEscherProperty(opt, EscherPropertyTypes.FILL__SHADECOLORS);
final int colorCnt = (ep == null) ? 0 : ep.getNumberOfElementsInArray(); final int colorCnt = (ep == null) ? 0 : ep.getNumberOfElementsInArray();
return new GradientPaint() { return new GradientPaint() {
@ -274,7 +274,7 @@ public final class HSLFFill {
// A value of type FixedPoint, as specified in [MS-OSHARED] section 2.2.1.6, // A value of type FixedPoint, as specified in [MS-OSHARED] section 2.2.1.6,
// that specifies the angle of the gradient fill. Zero degrees represents a vertical vector from // that specifies the angle of the gradient fill. Zero degrees represents a vertical vector from
// bottom to top. The default value for this property is 0x00000000. // bottom to top. The default value for this property is 0x00000000.
int rot = shape.getEscherProperty(EscherProperties.FILL__ANGLE); int rot = shape.getEscherProperty(EscherPropertyTypes.FILL__ANGLE);
return 90-Units.fixedPointToDouble(rot); return 90-Units.fixedPointToDouble(rot);
} }
@ -348,7 +348,7 @@ public final class HSLFFill {
@Override @Override
public int getAlpha() { public int getAlpha() {
return (int)(shape.getAlpha(EscherProperties.FILL__FILLOPACITY)*100000.0); return (int)(shape.getAlpha(EscherPropertyTypes.FILL__FILLOPACITY)*100000.0);
} }
@Override @Override
@ -366,13 +366,13 @@ public final class HSLFFill {
*/ */
public int getFillType(){ public int getFillType(){
AbstractEscherOptRecord opt = shape.getEscherOptRecord(); AbstractEscherOptRecord opt = shape.getEscherOptRecord();
EscherSimpleProperty prop = HSLFShape.getEscherProperty(opt, EscherProperties.FILL__FILLTYPE); EscherSimpleProperty prop = HSLFShape.getEscherProperty(opt, EscherPropertyTypes.FILL__FILLTYPE);
return prop == null ? FILL_SOLID : prop.getPropertyValue(); return prop == null ? FILL_SOLID : prop.getPropertyValue();
} }
void afterInsert(HSLFSheet sh){ void afterInsert(HSLFSheet sh){
AbstractEscherOptRecord opt = shape.getEscherOptRecord(); AbstractEscherOptRecord opt = shape.getEscherOptRecord();
EscherSimpleProperty p = HSLFShape.getEscherProperty(opt, EscherProperties.FILL__PATTERNTEXTURE); EscherSimpleProperty p = HSLFShape.getEscherProperty(opt, EscherPropertyTypes.FILL__PATTERNTEXTURE);
if(p != null) { if(p != null) {
int idx = p.getPropertyValue(); int idx = p.getPropertyValue();
EscherBSERecord bse = getEscherBSERecord(idx); EscherBSERecord bse = getEscherBSERecord(idx);
@ -409,7 +409,7 @@ public final class HSLFFill {
*/ */
public void setFillType(int type){ public void setFillType(int type){
AbstractEscherOptRecord opt = shape.getEscherOptRecord(); AbstractEscherOptRecord opt = shape.getEscherOptRecord();
HSLFShape.setEscherProperty(opt, EscherProperties.FILL__FILLTYPE, type); HSLFShape.setEscherProperty(opt, EscherPropertyTypes.FILL__FILLTYPE, type);
} }
/** /**
@ -417,11 +417,11 @@ public final class HSLFFill {
*/ */
public Color getForegroundColor(){ public Color getForegroundColor(){
AbstractEscherOptRecord opt = shape.getEscherOptRecord(); AbstractEscherOptRecord opt = shape.getEscherOptRecord();
EscherSimpleProperty p = HSLFShape.getEscherProperty(opt, EscherProperties.FILL__NOFILLHITTEST); EscherSimpleProperty p = HSLFShape.getEscherProperty(opt, EscherPropertyTypes.FILL__NOFILLHITTEST);
int propVal = (p == null) ? 0 : p.getPropertyValue(); int propVal = (p == null) ? 0 : p.getPropertyValue();
return (FILL_USE_FILLED.isSet(propVal) && FILL_FILLED.isSet(propVal)) return (FILL_USE_FILLED.isSet(propVal) && FILL_FILLED.isSet(propVal))
? shape.getColor(EscherProperties.FILL__FILLCOLOR, EscherProperties.FILL__FILLOPACITY) ? shape.getColor(EscherPropertyTypes.FILL__FILLCOLOR, EscherPropertyTypes.FILL__FILLOPACITY)
: null; : null;
} }
@ -430,20 +430,20 @@ public final class HSLFFill {
*/ */
public void setForegroundColor(Color color){ public void setForegroundColor(Color color){
AbstractEscherOptRecord opt = shape.getEscherOptRecord(); AbstractEscherOptRecord opt = shape.getEscherOptRecord();
opt.removeEscherProperty(EscherProperties.FILL__FILLOPACITY); opt.removeEscherProperty(EscherPropertyTypes.FILL__FILLOPACITY);
opt.removeEscherProperty(EscherProperties.FILL__FILLCOLOR); opt.removeEscherProperty(EscherPropertyTypes.FILL__FILLCOLOR);
if (color != null) { if (color != null) {
int rgb = new Color(color.getBlue(), color.getGreen(), color.getRed(), 0).getRGB(); int rgb = new Color(color.getBlue(), color.getGreen(), color.getRed(), 0).getRGB();
HSLFShape.setEscherProperty(opt, EscherProperties.FILL__FILLCOLOR, rgb); HSLFShape.setEscherProperty(opt, EscherPropertyTypes.FILL__FILLCOLOR, rgb);
int alpha = color.getAlpha(); int alpha = color.getAlpha();
if (alpha < 255) { if (alpha < 255) {
int alphaFP = Units.doubleToFixedPoint(alpha/255d); int alphaFP = Units.doubleToFixedPoint(alpha/255d);
HSLFShape.setEscherProperty(opt, EscherProperties.FILL__FILLOPACITY, alphaFP); HSLFShape.setEscherProperty(opt, EscherPropertyTypes.FILL__FILLOPACITY, alphaFP);
} }
} }
EscherSimpleProperty p = HSLFShape.getEscherProperty(opt, EscherProperties.FILL__NOFILLHITTEST); EscherSimpleProperty p = HSLFShape.getEscherProperty(opt, EscherPropertyTypes.FILL__NOFILLHITTEST);
int propVal = (p == null) ? 0 : p.getPropertyValue(); int propVal = (p == null) ? 0 : p.getPropertyValue();
propVal = FILL_FILLED.setBoolean(propVal, color != null); propVal = FILL_FILLED.setBoolean(propVal, color != null);
propVal = FILL_NO_FILL_HIT_TEST.setBoolean(propVal, color != null); propVal = FILL_NO_FILL_HIT_TEST.setBoolean(propVal, color != null);
@ -453,7 +453,7 @@ public final class HSLFFill {
// TODO: check why we always clear this ... // TODO: check why we always clear this ...
propVal = FILL_FILL_SHAPE.clear(propVal); propVal = FILL_FILL_SHAPE.clear(propVal);
HSLFShape.setEscherProperty(opt, EscherProperties.FILL__NOFILLHITTEST, propVal); HSLFShape.setEscherProperty(opt, EscherPropertyTypes.FILL__NOFILLHITTEST, propVal);
} }
/** /**
@ -461,11 +461,11 @@ public final class HSLFFill {
*/ */
public Color getBackgroundColor(){ public Color getBackgroundColor(){
AbstractEscherOptRecord opt = shape.getEscherOptRecord(); AbstractEscherOptRecord opt = shape.getEscherOptRecord();
EscherSimpleProperty p = HSLFShape.getEscherProperty(opt, EscherProperties.FILL__NOFILLHITTEST); EscherSimpleProperty p = HSLFShape.getEscherProperty(opt, EscherPropertyTypes.FILL__NOFILLHITTEST);
int propVal = (p == null) ? 0 : p.getPropertyValue(); int propVal = (p == null) ? 0 : p.getPropertyValue();
return (FILL_USE_FILLED.isSet(propVal) && FILL_FILLED.isSet(propVal)) return (FILL_USE_FILLED.isSet(propVal) && FILL_FILLED.isSet(propVal))
? shape.getColor(EscherProperties.FILL__FILLBACKCOLOR, EscherProperties.FILL__FILLOPACITY) ? shape.getColor(EscherPropertyTypes.FILL__FILLBACKCOLOR, EscherPropertyTypes.FILL__FILLOPACITY)
: null; : null;
} }
@ -475,11 +475,11 @@ public final class HSLFFill {
public void setBackgroundColor(Color color){ public void setBackgroundColor(Color color){
AbstractEscherOptRecord opt = shape.getEscherOptRecord(); AbstractEscherOptRecord opt = shape.getEscherOptRecord();
if (color == null) { if (color == null) {
HSLFShape.setEscherProperty(opt, EscherProperties.FILL__FILLBACKCOLOR, -1); HSLFShape.setEscherProperty(opt, EscherPropertyTypes.FILL__FILLBACKCOLOR, -1);
} }
else { else {
int rgb = new Color(color.getBlue(), color.getGreen(), color.getRed(), 0).getRGB(); int rgb = new Color(color.getBlue(), color.getGreen(), color.getRed(), 0).getRGB();
HSLFShape.setEscherProperty(opt, EscherProperties.FILL__FILLBACKCOLOR, rgb); HSLFShape.setEscherProperty(opt, EscherPropertyTypes.FILL__FILLBACKCOLOR, rgb);
} }
} }
@ -489,7 +489,7 @@ public final class HSLFFill {
@SuppressWarnings("resource") @SuppressWarnings("resource")
public HSLFPictureData getPictureData(){ public HSLFPictureData getPictureData(){
AbstractEscherOptRecord opt = shape.getEscherOptRecord(); AbstractEscherOptRecord opt = shape.getEscherOptRecord();
EscherSimpleProperty p = HSLFShape.getEscherProperty(opt, EscherProperties.FILL__PATTERNTEXTURE); EscherSimpleProperty p = HSLFShape.getEscherProperty(opt, EscherPropertyTypes.FILL__PATTERNTEXTURE);
if (p == null) { if (p == null) {
return null; return null;
} }
@ -524,7 +524,7 @@ public final class HSLFFill {
*/ */
public void setPictureData(HSLFPictureData data){ public void setPictureData(HSLFPictureData data){
AbstractEscherOptRecord opt = shape.getEscherOptRecord(); AbstractEscherOptRecord opt = shape.getEscherOptRecord();
HSLFShape.setEscherProperty(opt, (short)(EscherProperties.FILL__PATTERNTEXTURE + 0x4000), (data == null ? 0 : data.getIndex())); HSLFShape.setEscherProperty(opt, EscherPropertyTypes.FILL__PATTERNTEXTURE, true, (data == null ? 0 : data.getIndex()));
if(data != null && shape.getSheet() != null) { if(data != null && shape.getSheet() != null) {
EscherBSERecord bse = getEscherBSERecord(data.getIndex()); EscherBSERecord bse = getEscherBSERecord(data.getIndex());
if (bse != null) { if (bse != null) {

View File

@ -28,7 +28,7 @@ import java.util.List;
import org.apache.poi.ddf.AbstractEscherOptRecord; import org.apache.poi.ddf.AbstractEscherOptRecord;
import org.apache.poi.ddf.EscherArrayProperty; import org.apache.poi.ddf.EscherArrayProperty;
import org.apache.poi.ddf.EscherContainerRecord; import org.apache.poi.ddf.EscherContainerRecord;
import org.apache.poi.ddf.EscherProperties; import org.apache.poi.ddf.EscherPropertyTypes;
import org.apache.poi.ddf.EscherSimpleProperty; import org.apache.poi.ddf.EscherSimpleProperty;
import org.apache.poi.sl.usermodel.FreeformShape; import org.apache.poi.sl.usermodel.FreeformShape;
import org.apache.poi.sl.usermodel.ShapeContainer; import org.apache.poi.sl.usermodel.ShapeContainer;
@ -162,9 +162,9 @@ public final class HSLFFreeformShape extends HSLFAutoShape implements FreeformSh
segInfo.add(SEGMENTINFO_END); segInfo.add(SEGMENTINFO_END);
AbstractEscherOptRecord opt = getEscherOptRecord(); AbstractEscherOptRecord opt = getEscherOptRecord();
opt.addEscherProperty(new EscherSimpleProperty(EscherProperties.GEOMETRY__SHAPEPATH, 0x4)); opt.addEscherProperty(new EscherSimpleProperty(EscherPropertyTypes.GEOMETRY__SHAPEPATH, 0x4));
EscherArrayProperty verticesProp = new EscherArrayProperty((short)(EscherProperties.GEOMETRY__VERTICES + 0x4000), false, null); EscherArrayProperty verticesProp = new EscherArrayProperty(EscherPropertyTypes.GEOMETRY__VERTICES, true, 0);
verticesProp.setNumberOfElementsInArray(pntInfo.size()); verticesProp.setNumberOfElementsInArray(pntInfo.size());
verticesProp.setNumberOfElementsInMemory(pntInfo.size()); verticesProp.setNumberOfElementsInMemory(pntInfo.size());
verticesProp.setSizeOfElements(8); verticesProp.setSizeOfElements(8);
@ -177,7 +177,7 @@ public final class HSLFFreeformShape extends HSLFAutoShape implements FreeformSh
} }
opt.addEscherProperty(verticesProp); opt.addEscherProperty(verticesProp);
EscherArrayProperty segmentsProp = new EscherArrayProperty((short)(EscherProperties.GEOMETRY__SEGMENTINFO + 0x4000), false, null); EscherArrayProperty segmentsProp = new EscherArrayProperty(EscherPropertyTypes.GEOMETRY__SEGMENTINFO, true, 0);
segmentsProp.setNumberOfElementsInArray(segInfo.size()); segmentsProp.setNumberOfElementsInArray(segInfo.size());
segmentsProp.setNumberOfElementsInMemory(segInfo.size()); segmentsProp.setNumberOfElementsInMemory(segInfo.size());
segmentsProp.setSizeOfElements(0x2); segmentsProp.setSizeOfElements(0x2);
@ -187,8 +187,8 @@ public final class HSLFFreeformShape extends HSLFAutoShape implements FreeformSh
} }
opt.addEscherProperty(segmentsProp); opt.addEscherProperty(segmentsProp);
opt.addEscherProperty(new EscherSimpleProperty(EscherProperties.GEOMETRY__RIGHT, Units.pointsToMaster(bounds.getWidth()))); opt.addEscherProperty(new EscherSimpleProperty(EscherPropertyTypes.GEOMETRY__RIGHT, Units.pointsToMaster(bounds.getWidth())));
opt.addEscherProperty(new EscherSimpleProperty(EscherProperties.GEOMETRY__BOTTOM, Units.pointsToMaster(bounds.getHeight()))); opt.addEscherProperty(new EscherSimpleProperty(EscherPropertyTypes.GEOMETRY__BOTTOM, Units.pointsToMaster(bounds.getHeight())));
opt.sortProperties(); opt.sortProperties();

View File

@ -19,7 +19,7 @@ package org.apache.poi.hslf.usermodel;
import org.apache.poi.ddf.AbstractEscherOptRecord; import org.apache.poi.ddf.AbstractEscherOptRecord;
import org.apache.poi.ddf.EscherContainerRecord; import org.apache.poi.ddf.EscherContainerRecord;
import org.apache.poi.ddf.EscherProperties; import org.apache.poi.ddf.EscherPropertyTypes;
import org.apache.poi.ddf.EscherSpRecord; import org.apache.poi.ddf.EscherSpRecord;
import org.apache.poi.sl.usermodel.Line; import org.apache.poi.sl.usermodel.Line;
import org.apache.poi.sl.usermodel.ShapeContainer; import org.apache.poi.sl.usermodel.ShapeContainer;
@ -58,12 +58,12 @@ public final class HSLFLine extends HSLFTextShape implements Line<HSLFShape,HSLF
AbstractEscherOptRecord opt = getEscherOptRecord(); AbstractEscherOptRecord opt = getEscherOptRecord();
//default line properties //default line properties
setEscherProperty(opt, EscherProperties.GEOMETRY__SHAPEPATH, 4); setEscherProperty(opt, EscherPropertyTypes.GEOMETRY__SHAPEPATH, 4);
setEscherProperty(opt, EscherProperties.GEOMETRY__FILLOK, 0x10000); setEscherProperty(opt, EscherPropertyTypes.GEOMETRY__FILLOK, 0x10000);
setEscherProperty(opt, EscherProperties.FILL__NOFILLHITTEST, 0x100000); setEscherProperty(opt, EscherPropertyTypes.FILL__NOFILLHITTEST, 0x100000);
setEscherProperty(opt, EscherProperties.LINESTYLE__COLOR, 0x8000001); setEscherProperty(opt, EscherPropertyTypes.LINESTYLE__COLOR, 0x8000001);
setEscherProperty(opt, EscherProperties.LINESTYLE__NOLINEDRAWDASH, 0xA0008); setEscherProperty(opt, EscherPropertyTypes.LINESTYLE__NOLINEDRAWDASH, 0xA0008);
setEscherProperty(opt, EscherProperties.SHADOWSTYLE__COLOR, 0x8000002); setEscherProperty(opt, EscherPropertyTypes.SHADOWSTYLE__COLOR, 0x8000002);
return ecr; return ecr;
} }

View File

@ -23,7 +23,7 @@ import java.io.IOException;
import java.io.OutputStream; import java.io.OutputStream;
import org.apache.poi.ddf.EscherContainerRecord; import org.apache.poi.ddf.EscherContainerRecord;
import org.apache.poi.ddf.EscherProperties; import org.apache.poi.ddf.EscherPropertyTypes;
import org.apache.poi.ddf.EscherSpRecord; import org.apache.poi.ddf.EscherSpRecord;
import org.apache.poi.hslf.record.ExEmbed; import org.apache.poi.hslf.record.ExEmbed;
import org.apache.poi.hslf.record.ExObjList; import org.apache.poi.hslf.record.ExObjList;
@ -86,7 +86,7 @@ public final class HSLFObjectShape extends HSLFPictureShape implements ObjectSha
* @return the unique identifier for the OLE object * @return the unique identifier for the OLE object
*/ */
public int getObjectID(){ public int getObjectID(){
return getEscherProperty(EscherProperties.BLIP__PICTUREID); return getEscherProperty(EscherPropertyTypes.BLIP__PICTUREID);
} }
/** /**
@ -96,7 +96,7 @@ public final class HSLFObjectShape extends HSLFPictureShape implements ObjectSha
* @param objectId the unique identifier for the OLE object * @param objectId the unique identifier for the OLE object
*/ */
public void setObjectID(int objectId){ public void setObjectID(int objectId){
setEscherProperty(EscherProperties.BLIP__PICTUREID, objectId); setEscherProperty(EscherPropertyTypes.BLIP__PICTUREID, objectId);
EscherContainerRecord ecr = getSpContainer(); EscherContainerRecord ecr = getSpContainer();
EscherSpRecord spRecord = ecr.getChildById(EscherSpRecord.RECORD_ID); EscherSpRecord spRecord = ecr.getChildById(EscherSpRecord.RECORD_ID);

View File

@ -25,7 +25,7 @@ import org.apache.poi.ddf.AbstractEscherOptRecord;
import org.apache.poi.ddf.EscherBSERecord; import org.apache.poi.ddf.EscherBSERecord;
import org.apache.poi.ddf.EscherComplexProperty; import org.apache.poi.ddf.EscherComplexProperty;
import org.apache.poi.ddf.EscherContainerRecord; import org.apache.poi.ddf.EscherContainerRecord;
import org.apache.poi.ddf.EscherProperties; import org.apache.poi.ddf.EscherPropertyTypes;
import org.apache.poi.ddf.EscherRecord; import org.apache.poi.ddf.EscherRecord;
import org.apache.poi.ddf.EscherSimpleProperty; import org.apache.poi.ddf.EscherSimpleProperty;
import org.apache.poi.ddf.EscherSpRecord; import org.apache.poi.ddf.EscherSpRecord;
@ -86,7 +86,7 @@ public class HSLFPictureShape extends HSLFSimpleShape implements PictureShape<HS
*/ */
public int getPictureIndex(){ public int getPictureIndex(){
AbstractEscherOptRecord opt = getEscherOptRecord(); AbstractEscherOptRecord opt = getEscherOptRecord();
EscherSimpleProperty prop = getEscherProperty(opt, EscherProperties.BLIP__BLIPTODISPLAY); EscherSimpleProperty prop = getEscherProperty(opt, EscherPropertyTypes.BLIP__BLIPTODISPLAY);
return prop == null ? 0 : prop.getPropertyValue(); return prop == null ? 0 : prop.getPropertyValue();
} }
@ -104,10 +104,10 @@ public class HSLFPictureShape extends HSLFSimpleShape implements PictureShape<HS
//set default properties for a picture //set default properties for a picture
AbstractEscherOptRecord opt = getEscherOptRecord(); AbstractEscherOptRecord opt = getEscherOptRecord();
setEscherProperty(opt, EscherProperties.PROTECTION__LOCKAGAINSTGROUPING, 0x800080); setEscherProperty(opt, EscherPropertyTypes.PROTECTION__LOCKAGAINSTGROUPING, 0x800080);
//another weird feature of powerpoint: for picture id we must add 0x4000. //another weird feature of powerpoint: for picture id we must add 0x4000.
setEscherProperty(opt, (short)(EscherProperties.BLIP__BLIPTODISPLAY + 0x4000), idx); setEscherProperty(opt, EscherPropertyTypes.BLIP__BLIPTODISPLAY, true, idx);
return ecr; return ecr;
} }
@ -158,7 +158,7 @@ public class HSLFPictureShape extends HSLFSimpleShape implements PictureShape<HS
*/ */
public String getPictureName(){ public String getPictureName(){
AbstractEscherOptRecord opt = getEscherOptRecord(); AbstractEscherOptRecord opt = getEscherOptRecord();
EscherComplexProperty prop = getEscherProperty(opt, EscherProperties.BLIP__BLIPFILENAME); EscherComplexProperty prop = getEscherProperty(opt, EscherPropertyTypes.BLIP__BLIPFILENAME);
if (prop == null) return null; if (prop == null) return null;
String name = StringUtil.getFromUnicodeLE(prop.getComplexData()); String name = StringUtil.getFromUnicodeLE(prop.getComplexData());
return name.trim(); return name.trim();
@ -172,7 +172,8 @@ public class HSLFPictureShape extends HSLFSimpleShape implements PictureShape<HS
public void setPictureName(String name){ public void setPictureName(String name){
AbstractEscherOptRecord opt = getEscherOptRecord(); AbstractEscherOptRecord opt = getEscherOptRecord();
byte[] data = StringUtil.getToUnicodeLE(name + '\u0000'); byte[] data = StringUtil.getToUnicodeLE(name + '\u0000');
EscherComplexProperty prop = new EscherComplexProperty(EscherProperties.BLIP__BLIPFILENAME, false, data); EscherComplexProperty prop = new EscherComplexProperty(EscherPropertyTypes.BLIP__BLIPFILENAME, false, data.length);
prop.setComplexData(data);
opt.addEscherProperty(prop); opt.addEscherProperty(prop);
} }
@ -199,10 +200,10 @@ public class HSLFPictureShape extends HSLFSimpleShape implements PictureShape<HS
// i.e. the size of the already clipped image // i.e. the size of the already clipped image
AbstractEscherOptRecord opt = getEscherOptRecord(); AbstractEscherOptRecord opt = getEscherOptRecord();
double top = getFractProp(opt, EscherProperties.BLIP__CROPFROMTOP); double top = getFractProp(opt, EscherPropertyTypes.BLIP__CROPFROMTOP);
double bottom = getFractProp(opt, EscherProperties.BLIP__CROPFROMBOTTOM); double bottom = getFractProp(opt, EscherPropertyTypes.BLIP__CROPFROMBOTTOM);
double left = getFractProp(opt, EscherProperties.BLIP__CROPFROMLEFT); double left = getFractProp(opt, EscherPropertyTypes.BLIP__CROPFROMLEFT);
double right = getFractProp(opt, EscherProperties.BLIP__CROPFROMRIGHT); double right = getFractProp(opt, EscherPropertyTypes.BLIP__CROPFROMRIGHT);
// if all crop values are zero (the default) then no crop rectangle is set, return null // if all crop values are zero (the default) then no crop rectangle is set, return null
return (top==0 && bottom==0 && left==0 && right==0) return (top==0 && bottom==0 && left==0 && right==0)
@ -220,8 +221,8 @@ public class HSLFPictureShape extends HSLFSimpleShape implements PictureShape<HS
/** /**
* @return the fractional property or 0 if not defined * @return the fractional property or 0 if not defined
*/ */
private static double getFractProp(AbstractEscherOptRecord opt, short propertyId) { private static double getFractProp(AbstractEscherOptRecord opt, EscherPropertyTypes type) {
EscherSimpleProperty prop = getEscherProperty(opt, propertyId); EscherSimpleProperty prop = getEscherProperty(opt, type);
if (prop == null) return 0; if (prop == null) return 0;
int fixedPoint = prop.getPropertyValue(); int fixedPoint = prop.getPropertyValue();
return Units.fixedPointToDouble(fixedPoint); return Units.fixedPointToDouble(fixedPoint);

View File

@ -32,8 +32,8 @@ import org.apache.poi.ddf.EscherColorRef.SysIndexProcedure;
import org.apache.poi.ddf.EscherColorRef.SysIndexSource; import org.apache.poi.ddf.EscherColorRef.SysIndexSource;
import org.apache.poi.ddf.EscherComplexProperty; import org.apache.poi.ddf.EscherComplexProperty;
import org.apache.poi.ddf.EscherContainerRecord; import org.apache.poi.ddf.EscherContainerRecord;
import org.apache.poi.ddf.EscherProperties;
import org.apache.poi.ddf.EscherProperty; import org.apache.poi.ddf.EscherProperty;
import org.apache.poi.ddf.EscherPropertyTypes;
import org.apache.poi.ddf.EscherRecord; import org.apache.poi.ddf.EscherRecord;
import org.apache.poi.ddf.EscherRecordTypes; import org.apache.poi.ddf.EscherRecordTypes;
import org.apache.poi.ddf.EscherSimpleProperty; import org.apache.poi.ddf.EscherSimpleProperty;
@ -50,6 +50,7 @@ import org.apache.poi.sl.usermodel.ShapeContainer;
import org.apache.poi.sl.usermodel.ShapeType; import org.apache.poi.sl.usermodel.ShapeType;
import org.apache.poi.util.POILogFactory; import org.apache.poi.util.POILogFactory;
import org.apache.poi.util.POILogger; import org.apache.poi.util.POILogger;
import org.apache.poi.util.Removal;
import org.apache.poi.util.StringUtil; import org.apache.poi.util.StringUtil;
import org.apache.poi.util.Units; import org.apache.poi.util.Units;
@ -127,7 +128,7 @@ public abstract class HSLFShape implements Shape<HSLFShape,HSLFTextParagraph> {
*/ */
@Override @Override
public String getShapeName(){ public String getShapeName(){
final EscherComplexProperty ep = getEscherProperty(getEscherOptRecord(), EscherProperties.GROUPSHAPE__SHAPENAME); final EscherComplexProperty ep = getEscherProperty(getEscherOptRecord(), EscherPropertyTypes.GROUPSHAPE__SHAPENAME);
if (ep != null) { if (ep != null) {
final byte[] cd = ep.getComplexData(); final byte[] cd = ep.getComplexData();
return StringUtil.getFromUnicodeLE0Terminated(cd, 0, cd.length/2); return StringUtil.getFromUnicodeLE0Terminated(cd, 0, cd.length/2);
@ -260,20 +261,37 @@ public abstract class HSLFShape implements Shape<HSLFShape,HSLFTextParagraph> {
* Returns escher property by id. * Returns escher property by id.
* *
* @return escher property or <code>null</code> if not found. * @return escher property or <code>null</code> if not found.
*
* @deprecated use {@link #getEscherProperty(EscherPropertyTypes)} instead
*/ */
@Deprecated
@Removal(version = "5.0.0")
public static <T extends EscherProperty> T getEscherProperty(AbstractEscherOptRecord opt, int propId){ public static <T extends EscherProperty> T getEscherProperty(AbstractEscherOptRecord opt, int propId){
return (opt == null) ? null : opt.lookup(propId); return (opt == null) ? null : opt.lookup(propId);
} }
/**
* Returns escher property by type.
*
* @return escher property or <code>null</code> if not found.
*/
public static <T extends EscherProperty> T getEscherProperty(AbstractEscherOptRecord opt, EscherPropertyTypes type){
return (opt == null) ? null : opt.lookup(type);
}
/** /**
* Set an escher property for this shape. * Set an escher property for this shape.
* *
* @param opt The opt record to set the properties to. * @param opt The opt record to set the properties to.
* @param propId The id of the property. One of the constants defined in EscherOptRecord. * @param propId The id of the property. One of the constants defined in EscherOptRecord.
* @param value value of the property. If value = -1 then the property is removed. * @param value value of the property. If value = -1 then the property is removed.
*
* @deprecated use {@link #setEscherProperty(AbstractEscherOptRecord, EscherPropertyTypes, int)}
*/ */
@Deprecated
@Removal(version = "5.0.0")
public static void setEscherProperty(AbstractEscherOptRecord opt, short propId, int value){ public static void setEscherProperty(AbstractEscherOptRecord opt, short propId, int value){
java.util.List<EscherProperty> props = opt.getEscherProperties(); List<EscherProperty> props = opt.getEscherProperties();
for ( Iterator<EscherProperty> iterator = props.iterator(); iterator.hasNext(); ) { for ( Iterator<EscherProperty> iterator = props.iterator(); iterator.hasNext(); ) {
if (iterator.next().getPropertyNumber() == propId){ if (iterator.next().getPropertyNumber() == propId){
iterator.remove(); iterator.remove();
@ -286,17 +304,59 @@ public abstract class HSLFShape implements Shape<HSLFShape,HSLFTextParagraph> {
} }
} }
/**
* Set an escher property for this shape.
*
* @param opt The opt record to set the properties to.
* @param propType The type of the property.
* @param value value of the property. If value = -1 then the property is removed.
*/
public static void setEscherProperty(AbstractEscherOptRecord opt, EscherPropertyTypes propType, int value){
setEscherProperty(opt, propType, false, value);
}
public static void setEscherProperty(AbstractEscherOptRecord opt, EscherPropertyTypes propType, boolean isBlipId, int value){
List<EscherProperty> props = opt.getEscherProperties();
for ( Iterator<EscherProperty> iterator = props.iterator(); iterator.hasNext(); ) {
if (iterator.next().getPropertyNumber() == propType.propNumber){
iterator.remove();
break;
}
}
if (value != -1) {
opt.addEscherProperty(new EscherSimpleProperty(propType, false, isBlipId, value));
opt.sortProperties();
}
}
/** /**
* Set an simple escher property for this shape. * Set an simple escher property for this shape.
* *
* @param propId The id of the property. One of the constants defined in EscherOptRecord. * @param propId The id of the property. One of the constants defined in EscherOptRecord.
* @param value value of the property. If value = -1 then the property is removed. * @param value value of the property. If value = -1 then the property is removed.
*
* @deprecated use {@link #setEscherProperty(EscherPropertyTypes, int)}
*/ */
@Deprecated
@Removal(version = "5.0.0")
public void setEscherProperty(short propId, int value){ public void setEscherProperty(short propId, int value){
AbstractEscherOptRecord opt = getEscherOptRecord(); AbstractEscherOptRecord opt = getEscherOptRecord();
setEscherProperty(opt, propId, value); setEscherProperty(opt, propId, value);
} }
/**
* Set an simple escher property for this shape.
*
* @param propType The type of the property.
* @param value value of the property. If value = -1 then the property is removed.
*/
public void setEscherProperty(EscherPropertyTypes propType, int value){
AbstractEscherOptRecord opt = getEscherOptRecord();
setEscherProperty(opt, propType, value);
}
/** /**
* Get the value of a simple escher property for this shape. * Get the value of a simple escher property for this shape.
* *
@ -311,14 +371,40 @@ public abstract class HSLFShape implements Shape<HSLFShape,HSLFTextParagraph> {
/** /**
* Get the value of a simple escher property for this shape. * Get the value of a simple escher property for this shape.
* *
* @param propId The id of the property. One of the constants defined in EscherOptRecord. * @param propType The type of the property. One of the constants defined in EscherOptRecord.
*/ */
public int getEscherProperty(EscherPropertyTypes propType){
AbstractEscherOptRecord opt = getEscherOptRecord();
EscherSimpleProperty prop = getEscherProperty(opt, propType);
return prop == null ? 0 : prop.getPropertyValue();
}
/**
* Get the value of a simple escher property for this shape.
*
* @param propId The id of the property. One of the constants defined in EscherOptRecord.
*
* @deprecated use {@link #getEscherProperty(EscherPropertyTypes, int)} instead
*/
@Deprecated
@Removal(version = "5.0.0")
public int getEscherProperty(short propId, int defaultValue){ public int getEscherProperty(short propId, int defaultValue){
AbstractEscherOptRecord opt = getEscherOptRecord(); AbstractEscherOptRecord opt = getEscherOptRecord();
EscherSimpleProperty prop = getEscherProperty(opt, propId); EscherSimpleProperty prop = getEscherProperty(opt, propId);
return prop == null ? defaultValue : prop.getPropertyValue(); return prop == null ? defaultValue : prop.getPropertyValue();
} }
/**
* Get the value of a simple escher property for this shape.
*
* @param type The type of the property.
*/
public int getEscherProperty(EscherPropertyTypes type, int defaultValue){
AbstractEscherOptRecord opt = getEscherOptRecord();
EscherSimpleProperty prop = getEscherProperty(opt, type);
return prop == null ? defaultValue : prop.getPropertyValue();
}
/** /**
* @return The shape container and it's children that can represent this * @return The shape container and it's children that can represent this
* shape. * shape.
@ -358,7 +444,7 @@ public abstract class HSLFShape implements Shape<HSLFShape,HSLFTextParagraph> {
_sheet = sheet; _sheet = sheet;
} }
Color getColor(short colorProperty, short opacityProperty){ Color getColor(EscherPropertyTypes colorProperty, EscherPropertyTypes opacityProperty){
final AbstractEscherOptRecord opt = getEscherOptRecord(); final AbstractEscherOptRecord opt = getEscherOptRecord();
final EscherSimpleProperty colProp = getEscherProperty(opt, colorProperty); final EscherSimpleProperty colProp = getEscherProperty(opt, colorProperty);
final Color col; final Color col;
@ -509,7 +595,7 @@ public abstract class HSLFShape implements Shape<HSLFShape,HSLFTextParagraph> {
return col; return col;
} }
double getAlpha(short opacityProperty) { double getAlpha(EscherPropertyTypes opacityProperty) {
AbstractEscherOptRecord opt = getEscherOptRecord(); AbstractEscherOptRecord opt = getEscherOptRecord();
EscherSimpleProperty op = getEscherProperty(opt, opacityProperty); EscherSimpleProperty op = getEscherProperty(opt, opacityProperty);
int defaultOpacity = 0x00010000; int defaultOpacity = 0x00010000;
@ -607,13 +693,13 @@ public abstract class HSLFShape implements Shape<HSLFShape,HSLFTextParagraph> {
} }
public double getRotation(){ public double getRotation(){
int rot = getEscherProperty(EscherProperties.TRANSFORM__ROTATION); int rot = getEscherProperty(EscherPropertyTypes.TRANSFORM__ROTATION);
return Units.fixedPointToDouble(rot); return Units.fixedPointToDouble(rot);
} }
public void setRotation(double theta){ public void setRotation(double theta){
int rot = Units.doubleToFixedPoint(theta % 360.0); int rot = Units.doubleToFixedPoint(theta % 360.0);
setEscherProperty(EscherProperties.TRANSFORM__ROTATION, rot); setEscherProperty(EscherPropertyTypes.TRANSFORM__ROTATION, rot);
} }
public boolean isPlaceholder() { public boolean isPlaceholder() {

View File

@ -23,9 +23,9 @@ import org.apache.poi.ddf.AbstractEscherOptRecord;
import org.apache.poi.ddf.EscherClientDataRecord; import org.apache.poi.ddf.EscherClientDataRecord;
import org.apache.poi.ddf.EscherContainerRecord; import org.apache.poi.ddf.EscherContainerRecord;
import org.apache.poi.ddf.EscherOptRecord; import org.apache.poi.ddf.EscherOptRecord;
import org.apache.poi.ddf.EscherProperties;
import org.apache.poi.ddf.EscherProperty; import org.apache.poi.ddf.EscherProperty;
import org.apache.poi.ddf.EscherPropertyFactory; import org.apache.poi.ddf.EscherPropertyFactory;
import org.apache.poi.ddf.EscherPropertyTypes;
import org.apache.poi.ddf.EscherRecord; import org.apache.poi.ddf.EscherRecord;
import org.apache.poi.ddf.EscherRecordTypes; import org.apache.poi.ddf.EscherRecordTypes;
import org.apache.poi.ddf.EscherSimpleProperty; import org.apache.poi.ddf.EscherSimpleProperty;
@ -71,7 +71,7 @@ public final class HSLFShapeFactory {
EscherPropertyFactory f = new EscherPropertyFactory(); EscherPropertyFactory f = new EscherPropertyFactory();
List<EscherProperty> props = f.createProperties( opt.serialize(), 8, opt.getInstance() ); List<EscherProperty> props = f.createProperties( opt.serialize(), 8, opt.getInstance() );
for (EscherProperty ep : props) { for (EscherProperty ep : props) {
if (ep.getPropertyNumber() == EscherProperties.GROUPSHAPE__TABLEPROPERTIES if (ep.getPropertyNumber() == EscherPropertyTypes.GROUPSHAPE__TABLEPROPERTIES.propNumber
&& ep instanceof EscherSimpleProperty && ep instanceof EscherSimpleProperty
&& (((EscherSimpleProperty)ep).getPropertyValue() & 1) == 1) { && (((EscherSimpleProperty)ep).getPropertyValue() & 1) == 1) {
isTable = true; isTable = true;
@ -150,7 +150,7 @@ public final class HSLFShapeFactory {
private static HSLFShape createNonPrimitive(EscherContainerRecord spContainer, ShapeContainer<HSLFShape,HSLFTextParagraph> parent) { private static HSLFShape createNonPrimitive(EscherContainerRecord spContainer, ShapeContainer<HSLFShape,HSLFTextParagraph> parent) {
AbstractEscherOptRecord opt = HSLFShape.getEscherChild(spContainer, EscherOptRecord.RECORD_ID); AbstractEscherOptRecord opt = HSLFShape.getEscherChild(spContainer, EscherOptRecord.RECORD_ID);
EscherProperty prop = HSLFShape.getEscherProperty(opt, EscherProperties.GEOMETRY__VERTICES); EscherProperty prop = HSLFShape.getEscherProperty(opt, EscherPropertyTypes.GEOMETRY__VERTICES);
if(prop != null) { if(prop != null) {
return new HSLFFreeformShape(spContainer, parent); return new HSLFFreeformShape(spContainer, parent);
} }

View File

@ -17,7 +17,7 @@
package org.apache.poi.hslf.usermodel; package org.apache.poi.hslf.usermodel;
import org.apache.poi.ddf.EscherProperties; import org.apache.poi.ddf.EscherPropertyTypes;
import org.apache.poi.ddf.EscherSpRecord; import org.apache.poi.ddf.EscherSpRecord;
import org.apache.poi.hslf.exceptions.HSLFException; import org.apache.poi.hslf.exceptions.HSLFException;
import org.apache.poi.hslf.record.HSLFEscherClientDataRecord; import org.apache.poi.hslf.record.HSLFEscherClientDataRecord;
@ -96,7 +96,7 @@ public class HSLFShapePlaceholderDetails extends HSLFPlaceholderDetails {
spRecord.setFlags(flags); spRecord.setFlags(flags);
// Placeholders can't be grouped // Placeholders can't be grouped
shape.setEscherProperty(EscherProperties.PROTECTION__LOCKAGAINSTGROUPING, (placeholder == null ? -1 : 262144)); shape.setEscherProperty(EscherPropertyTypes.PROTECTION__LOCKAGAINSTGROUPING, (placeholder == null ? -1 : 262144));
if (placeholder == null) { if (placeholder == null) {
removePlaceholder(); removePlaceholder();

View File

@ -24,8 +24,8 @@ import org.apache.poi.ddf.EscherChildAnchorRecord;
import org.apache.poi.ddf.EscherClientAnchorRecord; import org.apache.poi.ddf.EscherClientAnchorRecord;
import org.apache.poi.ddf.EscherContainerRecord; import org.apache.poi.ddf.EscherContainerRecord;
import org.apache.poi.ddf.EscherOptRecord; import org.apache.poi.ddf.EscherOptRecord;
import org.apache.poi.ddf.EscherProperties;
import org.apache.poi.ddf.EscherProperty; import org.apache.poi.ddf.EscherProperty;
import org.apache.poi.ddf.EscherPropertyTypes;
import org.apache.poi.ddf.EscherRecord; import org.apache.poi.ddf.EscherRecord;
import org.apache.poi.ddf.EscherSimpleProperty; import org.apache.poi.ddf.EscherSimpleProperty;
import org.apache.poi.ddf.EscherSpRecord; import org.apache.poi.ddf.EscherSpRecord;
@ -62,6 +62,19 @@ public abstract class HSLFSimpleShape extends HSLFShape implements SimpleShape<H
public final static double DEFAULT_LINE_WIDTH = 0.75; public final static double DEFAULT_LINE_WIDTH = 0.75;
private static final EscherPropertyTypes[] ADJUST_VALUES = {
EscherPropertyTypes.GEOMETRY__ADJUSTVALUE,
EscherPropertyTypes.GEOMETRY__ADJUST2VALUE,
EscherPropertyTypes.GEOMETRY__ADJUST3VALUE,
EscherPropertyTypes.GEOMETRY__ADJUST4VALUE,
EscherPropertyTypes.GEOMETRY__ADJUST5VALUE,
EscherPropertyTypes.GEOMETRY__ADJUST6VALUE,
EscherPropertyTypes.GEOMETRY__ADJUST7VALUE,
EscherPropertyTypes.GEOMETRY__ADJUST8VALUE,
EscherPropertyTypes.GEOMETRY__ADJUST9VALUE,
EscherPropertyTypes.GEOMETRY__ADJUST10VALUE
};
/** /**
* Hyperlink * Hyperlink
*/ */
@ -124,7 +137,7 @@ public abstract class HSLFSimpleShape extends HSLFShape implements SimpleShape<H
*/ */
public double getLineWidth(){ public double getLineWidth(){
AbstractEscherOptRecord opt = getEscherOptRecord(); AbstractEscherOptRecord opt = getEscherOptRecord();
EscherSimpleProperty prop = getEscherProperty(opt, EscherProperties.LINESTYLE__LINEWIDTH); EscherSimpleProperty prop = getEscherProperty(opt, EscherPropertyTypes.LINESTYLE__LINEWIDTH);
return (prop == null) ? DEFAULT_LINE_WIDTH : Units.toPoints(prop.getPropertyValue()); return (prop == null) ? DEFAULT_LINE_WIDTH : Units.toPoints(prop.getPropertyValue());
} }
@ -134,7 +147,7 @@ public abstract class HSLFSimpleShape extends HSLFShape implements SimpleShape<H
*/ */
public void setLineWidth(double width){ public void setLineWidth(double width){
AbstractEscherOptRecord opt = getEscherOptRecord(); AbstractEscherOptRecord opt = getEscherOptRecord();
setEscherProperty(opt, EscherProperties.LINESTYLE__LINEWIDTH, Units.toEMU(width)); setEscherProperty(opt, EscherPropertyTypes.LINESTYLE__LINEWIDTH, Units.toEMU(width));
} }
/** /**
@ -145,11 +158,11 @@ public abstract class HSLFSimpleShape extends HSLFShape implements SimpleShape<H
public void setLineColor(Color color){ public void setLineColor(Color color){
AbstractEscherOptRecord opt = getEscherOptRecord(); AbstractEscherOptRecord opt = getEscherOptRecord();
if (color == null) { if (color == null) {
setEscherProperty(opt, EscherProperties.LINESTYLE__NOLINEDRAWDASH, 0x80000); setEscherProperty(opt, EscherPropertyTypes.LINESTYLE__NOLINEDRAWDASH, 0x80000);
} else { } else {
int rgb = new Color(color.getBlue(), color.getGreen(), color.getRed(), 0).getRGB(); int rgb = new Color(color.getBlue(), color.getGreen(), color.getRed(), 0).getRGB();
setEscherProperty(opt, EscherProperties.LINESTYLE__COLOR, rgb); setEscherProperty(opt, EscherPropertyTypes.LINESTYLE__COLOR, rgb);
setEscherProperty(opt, EscherProperties.LINESTYLE__NOLINEDRAWDASH, 0x180018); setEscherProperty(opt, EscherPropertyTypes.LINESTYLE__NOLINEDRAWDASH, 0x180018);
} }
} }
@ -159,13 +172,12 @@ public abstract class HSLFSimpleShape extends HSLFShape implements SimpleShape<H
public Color getLineColor(){ public Color getLineColor(){
AbstractEscherOptRecord opt = getEscherOptRecord(); AbstractEscherOptRecord opt = getEscherOptRecord();
EscherSimpleProperty p = getEscherProperty(opt, EscherProperties.LINESTYLE__NOLINEDRAWDASH); EscherSimpleProperty p = getEscherProperty(opt, EscherPropertyTypes.LINESTYLE__NOLINEDRAWDASH);
if(p != null && (p.getPropertyValue() & 0x8) == 0) { if(p != null && (p.getPropertyValue() & 0x8) == 0) {
return null; return null;
} }
Color clr = getColor(EscherProperties.LINESTYLE__COLOR, EscherProperties.LINESTYLE__OPACITY); return getColor(EscherPropertyTypes.LINESTYLE__COLOR, EscherPropertyTypes.LINESTYLE__OPACITY);
return clr == null ? null : clr;
} }
/** /**
@ -174,13 +186,12 @@ public abstract class HSLFSimpleShape extends HSLFShape implements SimpleShape<H
public Color getLineBackgroundColor(){ public Color getLineBackgroundColor(){
AbstractEscherOptRecord opt = getEscherOptRecord(); AbstractEscherOptRecord opt = getEscherOptRecord();
EscherSimpleProperty p = getEscherProperty(opt, EscherProperties.LINESTYLE__NOLINEDRAWDASH); EscherSimpleProperty p = getEscherProperty(opt, EscherPropertyTypes.LINESTYLE__NOLINEDRAWDASH);
if(p != null && (p.getPropertyValue() & 0x8) == 0) { if(p != null && (p.getPropertyValue() & 0x8) == 0) {
return null; return null;
} }
Color clr = getColor(EscherProperties.LINESTYLE__BACKCOLOR, EscherProperties.LINESTYLE__OPACITY); return getColor(EscherPropertyTypes.LINESTYLE__BACKCOLOR, EscherPropertyTypes.LINESTYLE__OPACITY);
return clr == null ? null : clr;
} }
/** /**
@ -191,12 +202,12 @@ public abstract class HSLFSimpleShape extends HSLFShape implements SimpleShape<H
public void setLineBackgroundColor(Color color){ public void setLineBackgroundColor(Color color){
AbstractEscherOptRecord opt = getEscherOptRecord(); AbstractEscherOptRecord opt = getEscherOptRecord();
if (color == null) { if (color == null) {
setEscherProperty(opt, EscherProperties.LINESTYLE__NOLINEDRAWDASH, 0x80000); setEscherProperty(opt, EscherPropertyTypes.LINESTYLE__NOLINEDRAWDASH, 0x80000);
opt.removeEscherProperty(EscherProperties.LINESTYLE__BACKCOLOR); opt.removeEscherProperty(EscherPropertyTypes.LINESTYLE__BACKCOLOR);
} else { } else {
int rgb = new Color(color.getBlue(), color.getGreen(), color.getRed(), 0).getRGB(); int rgb = new Color(color.getBlue(), color.getGreen(), color.getRed(), 0).getRGB();
setEscherProperty(opt, EscherProperties.LINESTYLE__BACKCOLOR, rgb); setEscherProperty(opt, EscherPropertyTypes.LINESTYLE__BACKCOLOR, rgb);
setEscherProperty(opt, EscherProperties.LINESTYLE__NOLINEDRAWDASH, 0x180018); setEscherProperty(opt, EscherPropertyTypes.LINESTYLE__NOLINEDRAWDASH, 0x180018);
} }
} }
@ -207,7 +218,7 @@ public abstract class HSLFSimpleShape extends HSLFShape implements SimpleShape<H
*/ */
public LineCap getLineCap(){ public LineCap getLineCap(){
AbstractEscherOptRecord opt = getEscherOptRecord(); AbstractEscherOptRecord opt = getEscherOptRecord();
EscherSimpleProperty prop = getEscherProperty(opt, EscherProperties.LINESTYLE__LINEENDCAPSTYLE); EscherSimpleProperty prop = getEscherProperty(opt, EscherPropertyTypes.LINESTYLE__LINEENDCAPSTYLE);
return (prop == null) ? LineCap.FLAT : LineCap.fromNativeId(prop.getPropertyValue()); return (prop == null) ? LineCap.FLAT : LineCap.fromNativeId(prop.getPropertyValue());
} }
@ -218,7 +229,7 @@ public abstract class HSLFSimpleShape extends HSLFShape implements SimpleShape<H
*/ */
public void setLineCap(LineCap pen){ public void setLineCap(LineCap pen){
AbstractEscherOptRecord opt = getEscherOptRecord(); AbstractEscherOptRecord opt = getEscherOptRecord();
setEscherProperty(opt, EscherProperties.LINESTYLE__LINEENDCAPSTYLE, pen == LineCap.FLAT ? -1 : pen.nativeId); setEscherProperty(opt, EscherPropertyTypes.LINESTYLE__LINEENDCAPSTYLE, pen == LineCap.FLAT ? -1 : pen.nativeId);
} }
/** /**
@ -228,7 +239,7 @@ public abstract class HSLFSimpleShape extends HSLFShape implements SimpleShape<H
*/ */
public LineDash getLineDash(){ public LineDash getLineDash(){
AbstractEscherOptRecord opt = getEscherOptRecord(); AbstractEscherOptRecord opt = getEscherOptRecord();
EscherSimpleProperty prop = getEscherProperty(opt, EscherProperties.LINESTYLE__LINEDASHING); EscherSimpleProperty prop = getEscherProperty(opt, EscherPropertyTypes.LINESTYLE__LINEDASHING);
return (prop == null) ? LineDash.SOLID : LineDash.fromNativeId(prop.getPropertyValue()); return (prop == null) ? LineDash.SOLID : LineDash.fromNativeId(prop.getPropertyValue());
} }
@ -239,7 +250,7 @@ public abstract class HSLFSimpleShape extends HSLFShape implements SimpleShape<H
*/ */
public void setLineDash(LineDash pen){ public void setLineDash(LineDash pen){
AbstractEscherOptRecord opt = getEscherOptRecord(); AbstractEscherOptRecord opt = getEscherOptRecord();
setEscherProperty(opt, EscherProperties.LINESTYLE__LINEDASHING, pen == LineDash.SOLID ? -1 : pen.nativeId); setEscherProperty(opt, EscherPropertyTypes.LINESTYLE__LINEDASHING, pen == LineDash.SOLID ? -1 : pen.nativeId);
} }
/** /**
@ -249,7 +260,7 @@ public abstract class HSLFSimpleShape extends HSLFShape implements SimpleShape<H
*/ */
public LineCompound getLineCompound() { public LineCompound getLineCompound() {
AbstractEscherOptRecord opt = getEscherOptRecord(); AbstractEscherOptRecord opt = getEscherOptRecord();
EscherSimpleProperty prop = getEscherProperty(opt, EscherProperties.LINESTYLE__LINESTYLE); EscherSimpleProperty prop = getEscherProperty(opt, EscherPropertyTypes.LINESTYLE__LINESTYLE);
return (prop == null) ? LineCompound.SINGLE : LineCompound.fromNativeId(prop.getPropertyValue()); return (prop == null) ? LineCompound.SINGLE : LineCompound.fromNativeId(prop.getPropertyValue());
} }
@ -260,7 +271,7 @@ public abstract class HSLFSimpleShape extends HSLFShape implements SimpleShape<H
*/ */
public void setLineCompound(LineCompound style){ public void setLineCompound(LineCompound style){
AbstractEscherOptRecord opt = getEscherOptRecord(); AbstractEscherOptRecord opt = getEscherOptRecord();
setEscherProperty(opt, EscherProperties.LINESTYLE__LINESTYLE, style == LineCompound.SINGLE ? -1 : style.nativeId); setEscherProperty(opt, EscherPropertyTypes.LINESTYLE__LINESTYLE, style == LineCompound.SINGLE ? -1 : style.nativeId);
} }
/** /**
@ -295,7 +306,6 @@ public abstract class HSLFSimpleShape extends HSLFShape implements SimpleShape<H
public double getLineWidth() { public double getLineWidth() {
return HSLFSimpleShape.this.getLineWidth(); return HSLFSimpleShape.this.getLineWidth();
} }
}; };
} }
@ -322,22 +332,13 @@ public abstract class HSLFSimpleShape extends HSLFShape implements SimpleShape<H
} }
final int adjInt = Integer.parseInt(name); final int adjInt = Integer.parseInt(name);
if (adjInt < 1 || adjInt > 10) {
short escherProp; throw new HSLFException("invalid adjust value: "+adjInt);
switch (adjInt) {
case 1: escherProp = EscherProperties.GEOMETRY__ADJUSTVALUE; break;
case 2: escherProp = EscherProperties.GEOMETRY__ADJUST2VALUE; break;
case 3: escherProp = EscherProperties.GEOMETRY__ADJUST3VALUE; break;
case 4: escherProp = EscherProperties.GEOMETRY__ADJUST4VALUE; break;
case 5: escherProp = EscherProperties.GEOMETRY__ADJUST5VALUE; break;
case 6: escherProp = EscherProperties.GEOMETRY__ADJUST6VALUE; break;
case 7: escherProp = EscherProperties.GEOMETRY__ADJUST7VALUE; break;
case 8: escherProp = EscherProperties.GEOMETRY__ADJUST8VALUE; break;
case 9: escherProp = EscherProperties.GEOMETRY__ADJUST9VALUE; break;
case 10: escherProp = EscherProperties.GEOMETRY__ADJUST10VALUE; break;
default: throw new HSLFException();
} }
EscherPropertyTypes escherProp = ADJUST_VALUES[adjInt];
int adjval = getEscherProperty(escherProp, -1); int adjval = getEscherProperty(escherProp, -1);
if (adjval == -1) { if (adjval == -1) {
@ -389,18 +390,18 @@ public abstract class HSLFSimpleShape extends HSLFShape implements SimpleShape<H
public double getShadowAngle() { public double getShadowAngle() {
AbstractEscherOptRecord opt = getEscherOptRecord(); AbstractEscherOptRecord opt = getEscherOptRecord();
EscherSimpleProperty prop = getEscherProperty(opt, EscherProperties.SHADOWSTYLE__OFFSETX); EscherSimpleProperty prop = getEscherProperty(opt, EscherPropertyTypes.SHADOWSTYLE__OFFSETX);
int offX = (prop == null) ? 0 : prop.getPropertyValue(); int offX = (prop == null) ? 0 : prop.getPropertyValue();
prop = getEscherProperty(opt, EscherProperties.SHADOWSTYLE__OFFSETY); prop = getEscherProperty(opt, EscherPropertyTypes.SHADOWSTYLE__OFFSETY);
int offY = (prop == null) ? 0 : prop.getPropertyValue(); int offY = (prop == null) ? 0 : prop.getPropertyValue();
return Math.toDegrees(Math.atan2(offY, offX)); return Math.toDegrees(Math.atan2(offY, offX));
} }
public double getShadowDistance() { public double getShadowDistance() {
AbstractEscherOptRecord opt = getEscherOptRecord(); AbstractEscherOptRecord opt = getEscherOptRecord();
EscherSimpleProperty prop = getEscherProperty(opt, EscherProperties.SHADOWSTYLE__OFFSETX); EscherSimpleProperty prop = getEscherProperty(opt, EscherPropertyTypes.SHADOWSTYLE__OFFSETX);
int offX = (prop == null) ? 0 : prop.getPropertyValue(); int offX = (prop == null) ? 0 : prop.getPropertyValue();
prop = getEscherProperty(opt, EscherProperties.SHADOWSTYLE__OFFSETY); prop = getEscherProperty(opt, EscherPropertyTypes.SHADOWSTYLE__OFFSETY);
int offY = (prop == null) ? 0 : prop.getPropertyValue(); int offY = (prop == null) ? 0 : prop.getPropertyValue();
return Units.toPoints((long)Math.hypot(offX, offY)); return Units.toPoints((long)Math.hypot(offX, offY));
} }
@ -409,7 +410,7 @@ public abstract class HSLFSimpleShape extends HSLFShape implements SimpleShape<H
* @return color of the line. If color is not set returns <code>java.awt.Color.black</code> * @return color of the line. If color is not set returns <code>java.awt.Color.black</code>
*/ */
public Color getShadowColor(){ public Color getShadowColor(){
Color clr = getColor(EscherProperties.SHADOWSTYLE__COLOR, EscherProperties.SHADOWSTYLE__OPACITY); Color clr = getColor(EscherPropertyTypes.SHADOWSTYLE__COLOR, EscherPropertyTypes.SHADOWSTYLE__OPACITY);
return clr == null ? Color.black : clr; return clr == null ? Color.black : clr;
} }
@ -419,7 +420,7 @@ public abstract class HSLFSimpleShape extends HSLFShape implements SimpleShape<H
if (opt == null) { if (opt == null) {
return null; return null;
} }
EscherProperty shadowType = opt.lookup(EscherProperties.SHADOWSTYLE__TYPE); EscherProperty shadowType = opt.lookup(EscherPropertyTypes.SHADOWSTYLE__TYPE);
if (shadowType == null) { if (shadowType == null) {
return null; return null;
} }
@ -456,68 +457,68 @@ public abstract class HSLFSimpleShape extends HSLFShape implements SimpleShape<H
public DecorationShape getLineHeadDecoration(){ public DecorationShape getLineHeadDecoration(){
AbstractEscherOptRecord opt = getEscherOptRecord(); AbstractEscherOptRecord opt = getEscherOptRecord();
EscherSimpleProperty prop = getEscherProperty(opt, EscherProperties.LINESTYLE__LINESTARTARROWHEAD); EscherSimpleProperty prop = getEscherProperty(opt, EscherPropertyTypes.LINESTYLE__LINESTARTARROWHEAD);
return (prop == null) ? null : DecorationShape.fromNativeId(prop.getPropertyValue()); return (prop == null) ? null : DecorationShape.fromNativeId(prop.getPropertyValue());
} }
public void setLineHeadDecoration(DecorationShape decoShape){ public void setLineHeadDecoration(DecorationShape decoShape){
AbstractEscherOptRecord opt = getEscherOptRecord(); AbstractEscherOptRecord opt = getEscherOptRecord();
setEscherProperty(opt, EscherProperties.LINESTYLE__LINESTARTARROWHEAD, decoShape == null ? -1 : decoShape.nativeId); setEscherProperty(opt, EscherPropertyTypes.LINESTYLE__LINESTARTARROWHEAD, decoShape == null ? -1 : decoShape.nativeId);
} }
public DecorationSize getLineHeadWidth(){ public DecorationSize getLineHeadWidth(){
AbstractEscherOptRecord opt = getEscherOptRecord(); AbstractEscherOptRecord opt = getEscherOptRecord();
EscherSimpleProperty prop = getEscherProperty(opt, EscherProperties.LINESTYLE__LINESTARTARROWWIDTH); EscherSimpleProperty prop = getEscherProperty(opt, EscherPropertyTypes.LINESTYLE__LINESTARTARROWWIDTH);
return (prop == null) ? null : DecorationSize.fromNativeId(prop.getPropertyValue()); return (prop == null) ? null : DecorationSize.fromNativeId(prop.getPropertyValue());
} }
public void setLineHeadWidth(DecorationSize decoSize){ public void setLineHeadWidth(DecorationSize decoSize){
AbstractEscherOptRecord opt = getEscherOptRecord(); AbstractEscherOptRecord opt = getEscherOptRecord();
setEscherProperty(opt, EscherProperties.LINESTYLE__LINESTARTARROWWIDTH, decoSize == null ? -1 : decoSize.nativeId); setEscherProperty(opt, EscherPropertyTypes.LINESTYLE__LINESTARTARROWWIDTH, decoSize == null ? -1 : decoSize.nativeId);
} }
public DecorationSize getLineHeadLength(){ public DecorationSize getLineHeadLength(){
AbstractEscherOptRecord opt = getEscherOptRecord(); AbstractEscherOptRecord opt = getEscherOptRecord();
EscherSimpleProperty prop = getEscherProperty(opt, EscherProperties.LINESTYLE__LINESTARTARROWLENGTH); EscherSimpleProperty prop = getEscherProperty(opt, EscherPropertyTypes.LINESTYLE__LINESTARTARROWLENGTH);
return (prop == null) ? null : DecorationSize.fromNativeId(prop.getPropertyValue()); return (prop == null) ? null : DecorationSize.fromNativeId(prop.getPropertyValue());
} }
public void setLineHeadLength(DecorationSize decoSize){ public void setLineHeadLength(DecorationSize decoSize){
AbstractEscherOptRecord opt = getEscherOptRecord(); AbstractEscherOptRecord opt = getEscherOptRecord();
setEscherProperty(opt, EscherProperties.LINESTYLE__LINESTARTARROWLENGTH, decoSize == null ? -1 : decoSize.nativeId); setEscherProperty(opt, EscherPropertyTypes.LINESTYLE__LINESTARTARROWLENGTH, decoSize == null ? -1 : decoSize.nativeId);
} }
public DecorationShape getLineTailDecoration(){ public DecorationShape getLineTailDecoration(){
AbstractEscherOptRecord opt = getEscherOptRecord(); AbstractEscherOptRecord opt = getEscherOptRecord();
EscherSimpleProperty prop = getEscherProperty(opt, EscherProperties.LINESTYLE__LINEENDARROWHEAD); EscherSimpleProperty prop = getEscherProperty(opt, EscherPropertyTypes.LINESTYLE__LINEENDARROWHEAD);
return (prop == null) ? null : DecorationShape.fromNativeId(prop.getPropertyValue()); return (prop == null) ? null : DecorationShape.fromNativeId(prop.getPropertyValue());
} }
public void setLineTailDecoration(DecorationShape decoShape){ public void setLineTailDecoration(DecorationShape decoShape){
AbstractEscherOptRecord opt = getEscherOptRecord(); AbstractEscherOptRecord opt = getEscherOptRecord();
setEscherProperty(opt, EscherProperties.LINESTYLE__LINEENDARROWHEAD, decoShape == null ? -1 : decoShape.nativeId); setEscherProperty(opt, EscherPropertyTypes.LINESTYLE__LINEENDARROWHEAD, decoShape == null ? -1 : decoShape.nativeId);
} }
public DecorationSize getLineTailWidth(){ public DecorationSize getLineTailWidth(){
AbstractEscherOptRecord opt = getEscherOptRecord(); AbstractEscherOptRecord opt = getEscherOptRecord();
EscherSimpleProperty prop = getEscherProperty(opt, EscherProperties.LINESTYLE__LINEENDARROWWIDTH); EscherSimpleProperty prop = getEscherProperty(opt, EscherPropertyTypes.LINESTYLE__LINEENDARROWWIDTH);
return (prop == null) ? null : DecorationSize.fromNativeId(prop.getPropertyValue()); return (prop == null) ? null : DecorationSize.fromNativeId(prop.getPropertyValue());
} }
public void setLineTailWidth(DecorationSize decoSize){ public void setLineTailWidth(DecorationSize decoSize){
AbstractEscherOptRecord opt = getEscherOptRecord(); AbstractEscherOptRecord opt = getEscherOptRecord();
setEscherProperty(opt, EscherProperties.LINESTYLE__LINEENDARROWWIDTH, decoSize == null ? -1 : decoSize.nativeId); setEscherProperty(opt, EscherPropertyTypes.LINESTYLE__LINEENDARROWWIDTH, decoSize == null ? -1 : decoSize.nativeId);
} }
public DecorationSize getLineTailLength(){ public DecorationSize getLineTailLength(){
AbstractEscherOptRecord opt = getEscherOptRecord(); AbstractEscherOptRecord opt = getEscherOptRecord();
EscherSimpleProperty prop = getEscherProperty(opt, EscherProperties.LINESTYLE__LINEENDARROWLENGTH); EscherSimpleProperty prop = getEscherProperty(opt, EscherPropertyTypes.LINESTYLE__LINEENDARROWLENGTH);
return (prop == null) ? null : DecorationSize.fromNativeId(prop.getPropertyValue()); return (prop == null) ? null : DecorationSize.fromNativeId(prop.getPropertyValue());
} }
public void setLineTailLength(DecorationSize decoSize){ public void setLineTailLength(DecorationSize decoSize){
AbstractEscherOptRecord opt = getEscherOptRecord(); AbstractEscherOptRecord opt = getEscherOptRecord();
setEscherProperty(opt, EscherProperties.LINESTYLE__LINEENDARROWLENGTH, decoSize == null ? -1 : decoSize.nativeId); setEscherProperty(opt, EscherPropertyTypes.LINESTYLE__LINEENDARROWLENGTH, decoSize == null ? -1 : decoSize.nativeId);
} }

View File

@ -30,7 +30,7 @@ import org.apache.poi.ddf.AbstractEscherOptRecord;
import org.apache.poi.ddf.EscherArrayProperty; import org.apache.poi.ddf.EscherArrayProperty;
import org.apache.poi.ddf.EscherContainerRecord; import org.apache.poi.ddf.EscherContainerRecord;
import org.apache.poi.ddf.EscherOptRecord; import org.apache.poi.ddf.EscherOptRecord;
import org.apache.poi.ddf.EscherProperties; import org.apache.poi.ddf.EscherPropertyTypes;
import org.apache.poi.ddf.EscherRecordTypes; import org.apache.poi.ddf.EscherRecordTypes;
import org.apache.poi.ddf.EscherSimpleProperty; import org.apache.poi.ddf.EscherSimpleProperty;
import org.apache.poi.sl.usermodel.ShapeContainer; import org.apache.poi.sl.usermodel.ShapeContainer;
@ -101,8 +101,8 @@ implements HSLFShapeContainer, TableShape<HSLFShape,HSLFTextParagraph> {
EscherContainerRecord spCont = (EscherContainerRecord) getSpContainer().getChild(0); EscherContainerRecord spCont = (EscherContainerRecord) getSpContainer().getChild(0);
AbstractEscherOptRecord opt = new EscherOptRecord(); AbstractEscherOptRecord opt = new EscherOptRecord();
opt.setRecordId(EscherRecordTypes.USER_DEFINED.typeID); opt.setRecordId(EscherRecordTypes.USER_DEFINED.typeID);
opt.addEscherProperty(new EscherSimpleProperty(EscherProperties.GROUPSHAPE__TABLEPROPERTIES, 1)); opt.addEscherProperty(new EscherSimpleProperty(EscherPropertyTypes.GROUPSHAPE__TABLEPROPERTIES, 1));
EscherArrayProperty p = new EscherArrayProperty((short)(0x4000 | EscherProperties.GROUPSHAPE__TABLEROWPROPERTIES), false, null); EscherArrayProperty p = new EscherArrayProperty(EscherPropertyTypes.GROUPSHAPE__TABLEROWPROPERTIES, true, 0);
p.setSizeOfElements(0x0004); p.setSizeOfElements(0x0004);
p.setNumberOfElementsInArray(numRows); p.setNumberOfElementsInArray(numRows);
p.setNumberOfElementsInMemory(numRows); p.setNumberOfElementsInMemory(numRows);
@ -368,7 +368,7 @@ implements HSLFShapeContainer, TableShape<HSLFShape,HSLFTextParagraph> {
// update row height in the table properties // update row height in the table properties
AbstractEscherOptRecord opt = getEscherChild(EscherRecordTypes.USER_DEFINED); AbstractEscherOptRecord opt = getEscherChild(EscherRecordTypes.USER_DEFINED);
EscherArrayProperty p = opt.lookup(EscherProperties.GROUPSHAPE__TABLEROWPROPERTIES); EscherArrayProperty p = opt.lookup(EscherPropertyTypes.GROUPSHAPE__TABLEROWPROPERTIES);
byte[] masterBytes = p.getElement(row); byte[] masterBytes = p.getElement(row);
double currentHeight = Units.masterToPoints(LittleEndian.getInt(masterBytes, 0)); double currentHeight = Units.masterToPoints(LittleEndian.getInt(masterBytes, 0));
LittleEndian.putInt(masterBytes, 0, Units.pointsToMaster(height)); LittleEndian.putInt(masterBytes, 0, Units.pointsToMaster(height));
@ -461,7 +461,7 @@ implements HSLFShapeContainer, TableShape<HSLFShape,HSLFTextParagraph> {
private void updateRowHeightsProperty() { private void updateRowHeightsProperty() {
AbstractEscherOptRecord opt = getEscherChild(EscherRecordTypes.USER_DEFINED); AbstractEscherOptRecord opt = getEscherChild(EscherRecordTypes.USER_DEFINED);
EscherArrayProperty p = opt.lookup(EscherProperties.GROUPSHAPE__TABLEROWPROPERTIES); EscherArrayProperty p = opt.lookup(EscherPropertyTypes.GROUPSHAPE__TABLEROWPROPERTIES);
byte[] val = new byte[4]; byte[] val = new byte[4];
for (int rowIdx = 0; rowIdx < cells.length; rowIdx++) { for (int rowIdx = 0; rowIdx < cells.length; rowIdx++) {
int rowHeight = Units.pointsToMaster(cells[rowIdx][0].getAnchor().getHeight()); int rowHeight = Units.pointsToMaster(cells[rowIdx][0].getAnchor().getHeight());

View File

@ -22,7 +22,7 @@ import java.awt.geom.Rectangle2D;
import org.apache.poi.ddf.AbstractEscherOptRecord; import org.apache.poi.ddf.AbstractEscherOptRecord;
import org.apache.poi.ddf.EscherContainerRecord; import org.apache.poi.ddf.EscherContainerRecord;
import org.apache.poi.ddf.EscherProperties; import org.apache.poi.ddf.EscherPropertyTypes;
import org.apache.poi.sl.draw.DrawPaint; import org.apache.poi.sl.draw.DrawPaint;
import org.apache.poi.sl.usermodel.PaintStyle; import org.apache.poi.sl.usermodel.PaintStyle;
import org.apache.poi.sl.usermodel.ShapeType; import org.apache.poi.sl.usermodel.ShapeType;
@ -81,11 +81,11 @@ public final class HSLFTableCell extends HSLFTextBox implements TableCell<HSLFSh
protected EscherContainerRecord createSpContainer(boolean isChild){ protected EscherContainerRecord createSpContainer(boolean isChild){
EscherContainerRecord ecr = super.createSpContainer(isChild); EscherContainerRecord ecr = super.createSpContainer(isChild);
AbstractEscherOptRecord opt = getEscherOptRecord(); AbstractEscherOptRecord opt = getEscherOptRecord();
setEscherProperty(opt, EscherProperties.TEXT__TEXTID, 0); setEscherProperty(opt, EscherPropertyTypes.TEXT__TEXTID, 0);
setEscherProperty(opt, EscherProperties.TEXT__SIZE_TEXT_TO_FIT_SHAPE, 0x20000); setEscherProperty(opt, EscherPropertyTypes.TEXT__SIZE_TEXT_TO_FIT_SHAPE, 0x20000);
setEscherProperty(opt, EscherProperties.FILL__NOFILLHITTEST, 0x150001); setEscherProperty(opt, EscherPropertyTypes.FILL__NOFILLHITTEST, 0x150001);
setEscherProperty(opt, EscherProperties.SHADOWSTYLE__SHADOWOBSURED, 0x20000); setEscherProperty(opt, EscherPropertyTypes.SHADOWSTYLE__SHADOWOBSURED, 0x20000);
setEscherProperty(opt, EscherProperties.PROTECTION__LOCKAGAINSTGROUPING, 0x40000); setEscherProperty(opt, EscherPropertyTypes.PROTECTION__LOCKAGAINSTGROUPING, 0x40000);
return ecr; return ecr;
} }
@ -390,10 +390,10 @@ public final class HSLFTableCell extends HSLFTextBox implements TableCell<HSLFSh
table.addShape(line); table.addShape(line);
AbstractEscherOptRecord opt = getEscherOptRecord(); AbstractEscherOptRecord opt = getEscherOptRecord();
setEscherProperty(opt, EscherProperties.GEOMETRY__SHAPEPATH, -1); setEscherProperty(opt, EscherPropertyTypes.GEOMETRY__SHAPEPATH, -1);
setEscherProperty(opt, EscherProperties.GEOMETRY__FILLOK, -1); setEscherProperty(opt, EscherPropertyTypes.GEOMETRY__FILLOK, -1);
setEscherProperty(opt, EscherProperties.SHADOWSTYLE__SHADOWOBSURED, 0x20000); setEscherProperty(opt, EscherPropertyTypes.SHADOWSTYLE__SHADOWOBSURED, 0x20000);
setEscherProperty(opt, EscherProperties.THREED__LIGHTFACE, 0x80000); setEscherProperty(opt, EscherPropertyTypes.THREED__LIGHTFACE, 0x80000);
anchorBorder(edge, line); anchorBorder(edge, line);

View File

@ -18,7 +18,7 @@
package org.apache.poi.hslf.usermodel; package org.apache.poi.hslf.usermodel;
import org.apache.poi.ddf.EscherContainerRecord; import org.apache.poi.ddf.EscherContainerRecord;
import org.apache.poi.ddf.EscherProperties; import org.apache.poi.ddf.EscherPropertyTypes;
import org.apache.poi.sl.usermodel.ShapeContainer; import org.apache.poi.sl.usermodel.ShapeContainer;
import org.apache.poi.sl.usermodel.ShapeType; import org.apache.poi.sl.usermodel.ShapeType;
import org.apache.poi.sl.usermodel.TextBox; import org.apache.poi.sl.usermodel.TextBox;
@ -76,12 +76,12 @@ public class HSLFTextBox extends HSLFTextShape implements TextBox<HSLFShape,HSLF
setShapeType(ShapeType.TEXT_BOX); setShapeType(ShapeType.TEXT_BOX);
//set default properties for a TextBox //set default properties for a TextBox
setEscherProperty(EscherProperties.FILL__FILLCOLOR, 0x8000004); setEscherProperty(EscherPropertyTypes.FILL__FILLCOLOR, 0x8000004);
setEscherProperty(EscherProperties.FILL__FILLBACKCOLOR, 0x8000000); setEscherProperty(EscherPropertyTypes.FILL__FILLBACKCOLOR, 0x8000000);
setEscherProperty(EscherProperties.FILL__NOFILLHITTEST, 0x100000); setEscherProperty(EscherPropertyTypes.FILL__NOFILLHITTEST, 0x100000);
setEscherProperty(EscherProperties.LINESTYLE__COLOR, 0x8000001); setEscherProperty(EscherPropertyTypes.LINESTYLE__COLOR, 0x8000001);
setEscherProperty(EscherProperties.LINESTYLE__NOLINEDRAWDASH, 0x80000); setEscherProperty(EscherPropertyTypes.LINESTYLE__NOLINEDRAWDASH, 0x80000);
setEscherProperty(EscherProperties.SHADOWSTYLE__COLOR, 0x8000002); setEscherProperty(EscherPropertyTypes.SHADOWSTYLE__COLOR, 0x8000002);
// init paragraphs // init paragraphs
getTextParagraphs(); getTextParagraphs();
@ -92,6 +92,6 @@ public class HSLFTextBox extends HSLFTextShape implements TextBox<HSLFShape,HSLF
@Override @Override
protected void setDefaultTextProperties(HSLFTextParagraph _txtrun){ protected void setDefaultTextProperties(HSLFTextParagraph _txtrun){
setVerticalAlignment(VerticalAlignment.TOP); setVerticalAlignment(VerticalAlignment.TOP);
setEscherProperty(EscherProperties.TEXT__SIZE_TEXT_TO_FIT_SHAPE, 0x20002); setEscherProperty(EscherPropertyTypes.TEXT__SIZE_TEXT_TO_FIT_SHAPE, 0x20002);
} }
} }

View File

@ -31,7 +31,7 @@ import java.util.List;
import org.apache.poi.ddf.AbstractEscherOptRecord; import org.apache.poi.ddf.AbstractEscherOptRecord;
import org.apache.poi.ddf.EscherContainerRecord; import org.apache.poi.ddf.EscherContainerRecord;
import org.apache.poi.ddf.EscherProperties; import org.apache.poi.ddf.EscherPropertyTypes;
import org.apache.poi.ddf.EscherSimpleProperty; import org.apache.poi.ddf.EscherSimpleProperty;
import org.apache.poi.ddf.EscherTextboxRecord; import org.apache.poi.ddf.EscherTextboxRecord;
import org.apache.poi.hslf.exceptions.HSLFException; import org.apache.poi.hslf.exceptions.HSLFException;
@ -377,7 +377,7 @@ implements TextShape<HSLFShape,HSLFTextParagraph> {
*/ */
/* package */ HSLFTextAnchor getAlignment(){ /* package */ HSLFTextAnchor getAlignment(){
AbstractEscherOptRecord opt = getEscherOptRecord(); AbstractEscherOptRecord opt = getEscherOptRecord();
EscherSimpleProperty prop = getEscherProperty(opt, EscherProperties.TEXT__ANCHORTEXT); EscherSimpleProperty prop = getEscherProperty(opt, EscherPropertyTypes.TEXT__ANCHORTEXT);
final HSLFTextAnchor align; final HSLFTextAnchor align;
if (prop == null){ if (prop == null){
/** /**
@ -416,7 +416,7 @@ implements TextShape<HSLFShape,HSLFTextParagraph> {
(hta.vAlign == vAlign) && (hta.vAlign == vAlign) &&
(hta.baseline == null || hta.baseline == baseline) (hta.baseline == null || hta.baseline == baseline)
) { ) {
setEscherProperty(EscherProperties.TEXT__ANCHORTEXT, hta.nativeId); setEscherProperty(EscherPropertyTypes.TEXT__ANCHORTEXT, hta.nativeId);
break; break;
} }
} }
@ -467,7 +467,7 @@ implements TextShape<HSLFShape,HSLFTextParagraph> {
* @return the botom margin * @return the botom margin
*/ */
public double getBottomInset(){ public double getBottomInset(){
return getInset(EscherProperties.TEXT__TEXTBOTTOM, .05); return getInset(EscherPropertyTypes.TEXT__TEXTBOTTOM, .05);
} }
/** /**
@ -477,7 +477,7 @@ implements TextShape<HSLFShape,HSLFTextParagraph> {
* @param margin the bottom margin * @param margin the bottom margin
*/ */
public void setBottomInset(double margin){ public void setBottomInset(double margin){
setInset(EscherProperties.TEXT__TEXTBOTTOM, margin); setInset(EscherPropertyTypes.TEXT__TEXTBOTTOM, margin);
} }
/** /**
@ -489,7 +489,7 @@ implements TextShape<HSLFShape,HSLFTextParagraph> {
* @return the left margin * @return the left margin
*/ */
public double getLeftInset(){ public double getLeftInset(){
return getInset(EscherProperties.TEXT__TEXTLEFT, .1); return getInset(EscherPropertyTypes.TEXT__TEXTLEFT, .1);
} }
/** /**
@ -499,7 +499,7 @@ implements TextShape<HSLFShape,HSLFTextParagraph> {
* @param margin the left margin * @param margin the left margin
*/ */
public void setLeftInset(double margin){ public void setLeftInset(double margin){
setInset(EscherProperties.TEXT__TEXTLEFT, margin); setInset(EscherPropertyTypes.TEXT__TEXTLEFT, margin);
} }
/** /**
@ -511,7 +511,7 @@ implements TextShape<HSLFShape,HSLFTextParagraph> {
* @return the right margin * @return the right margin
*/ */
public double getRightInset(){ public double getRightInset(){
return getInset(EscherProperties.TEXT__TEXTRIGHT, .1); return getInset(EscherPropertyTypes.TEXT__TEXTRIGHT, .1);
} }
/** /**
@ -521,7 +521,7 @@ implements TextShape<HSLFShape,HSLFTextParagraph> {
* @param margin the right margin * @param margin the right margin
*/ */
public void setRightInset(double margin){ public void setRightInset(double margin){
setInset(EscherProperties.TEXT__TEXTRIGHT, margin); setInset(EscherPropertyTypes.TEXT__TEXTRIGHT, margin);
} }
/** /**
@ -532,7 +532,7 @@ implements TextShape<HSLFShape,HSLFTextParagraph> {
* @return the top margin * @return the top margin
*/ */
public double getTopInset(){ public double getTopInset(){
return getInset(EscherProperties.TEXT__TEXTTOP, .05); return getInset(EscherPropertyTypes.TEXT__TEXTTOP, .05);
} }
/** /**
@ -542,7 +542,7 @@ implements TextShape<HSLFShape,HSLFTextParagraph> {
* @param margin the top margin * @param margin the top margin
*/ */
public void setTopInset(double margin){ public void setTopInset(double margin){
setInset(EscherProperties.TEXT__TEXTTOP, margin); setInset(EscherPropertyTypes.TEXT__TEXTTOP, margin);
} }
/** /**
@ -550,22 +550,22 @@ implements TextShape<HSLFShape,HSLFTextParagraph> {
* and the edge of the inscribed rectangle of the shape that contains the text. * and the edge of the inscribed rectangle of the shape that contains the text.
* Default value is 1/20 inch. * Default value is 1/20 inch.
* *
* @param propId the id of the inset edge * @param type the type of the inset edge
* @return the inset in points * @return the inset in points
*/ */
private double getInset(short propId, double defaultInch) { private double getInset(EscherPropertyTypes type, double defaultInch) {
AbstractEscherOptRecord opt = getEscherOptRecord(); AbstractEscherOptRecord opt = getEscherOptRecord();
EscherSimpleProperty prop = getEscherProperty(opt, propId); EscherSimpleProperty prop = getEscherProperty(opt, type);
int val = prop == null ? (int)(Units.toEMU(Units.POINT_DPI)*defaultInch) : prop.getPropertyValue(); int val = prop == null ? (int)(Units.toEMU(Units.POINT_DPI)*defaultInch) : prop.getPropertyValue();
return Units.toPoints(val); return Units.toPoints(val);
} }
/** /**
* @param propId the id of the inset edge * @param type the type of the inset edge
* @param margin the inset in points * @param margin the inset in points
*/ */
private void setInset(short propId, double margin){ private void setInset(EscherPropertyTypes type, double margin){
setEscherProperty(propId, Units.toEMU(margin)); setEscherProperty(type, Units.toEMU(margin));
} }
/** /**
@ -578,7 +578,7 @@ implements TextShape<HSLFShape,HSLFTextParagraph> {
*/ */
public int getWordWrapEx() { public int getWordWrapEx() {
AbstractEscherOptRecord opt = getEscherOptRecord(); AbstractEscherOptRecord opt = getEscherOptRecord();
EscherSimpleProperty prop = getEscherProperty(opt, EscherProperties.TEXT__WRAPTEXT); EscherSimpleProperty prop = getEscherProperty(opt, EscherPropertyTypes.TEXT__WRAPTEXT);
return prop == null ? WrapSquare : prop.getPropertyValue(); return prop == null ? WrapSquare : prop.getPropertyValue();
} }
@ -589,7 +589,7 @@ implements TextShape<HSLFShape,HSLFTextParagraph> {
* Must be one of the <code>Wrap*</code> constants defined in this class. * Must be one of the <code>Wrap*</code> constants defined in this class.
*/ */
public void setWordWrapEx(int wrap){ public void setWordWrapEx(int wrap){
setEscherProperty(EscherProperties.TEXT__WRAPTEXT, wrap); setEscherProperty(EscherPropertyTypes.TEXT__WRAPTEXT, wrap);
} }
@Override @Override
@ -608,7 +608,7 @@ implements TextShape<HSLFShape,HSLFTextParagraph> {
*/ */
public int getTextId(){ public int getTextId(){
AbstractEscherOptRecord opt = getEscherOptRecord(); AbstractEscherOptRecord opt = getEscherOptRecord();
EscherSimpleProperty prop = getEscherProperty(opt, EscherProperties.TEXT__TEXTID); EscherSimpleProperty prop = getEscherProperty(opt, EscherPropertyTypes.TEXT__TEXTID);
return prop == null ? 0 : prop.getPropertyValue(); return prop == null ? 0 : prop.getPropertyValue();
} }
@ -618,7 +618,7 @@ implements TextShape<HSLFShape,HSLFTextParagraph> {
* @param id of the text * @param id of the text
*/ */
public void setTextId(int id){ public void setTextId(int id){
setEscherProperty(EscherProperties.TEXT__TEXTID, id); setEscherProperty(EscherPropertyTypes.TEXT__TEXTID, id);
} }
@Override @Override
@ -732,7 +732,7 @@ implements TextShape<HSLFShape,HSLFTextParagraph> {
public TextDirection getTextDirection() { public TextDirection getTextDirection() {
// see 2.4.5 MSOTXFL // see 2.4.5 MSOTXFL
AbstractEscherOptRecord opt = getEscherOptRecord(); AbstractEscherOptRecord opt = getEscherOptRecord();
EscherSimpleProperty prop = getEscherProperty(opt, EscherProperties.TEXT__TEXTFLOW); EscherSimpleProperty prop = getEscherProperty(opt, EscherPropertyTypes.TEXT__TEXTFLOW);
int msotxfl = (prop == null) ? 0 : prop.getPropertyValue(); int msotxfl = (prop == null) ? 0 : prop.getPropertyValue();
switch (msotxfl) { switch (msotxfl) {
default: default:
@ -774,14 +774,14 @@ implements TextShape<HSLFShape,HSLFTextParagraph> {
break; break;
} }
} }
setEscherProperty(opt, EscherProperties.TEXT__TEXTFLOW, msotxfl); setEscherProperty(opt, EscherPropertyTypes.TEXT__TEXTFLOW, msotxfl);
} }
@Override @Override
public Double getTextRotation() { public Double getTextRotation() {
// see 2.4.6 MSOCDIR // see 2.4.6 MSOCDIR
AbstractEscherOptRecord opt = getEscherOptRecord(); AbstractEscherOptRecord opt = getEscherOptRecord();
EscherSimpleProperty prop = getEscherProperty(opt, EscherProperties.TEXT__FONTROTATION); EscherSimpleProperty prop = getEscherProperty(opt, EscherPropertyTypes.TEXT__FONTROTATION);
return (prop == null) ? null : (90. * prop.getPropertyValue()); return (prop == null) ? null : (90. * prop.getPropertyValue());
} }
@ -789,10 +789,10 @@ implements TextShape<HSLFShape,HSLFTextParagraph> {
public void setTextRotation(Double rotation) { public void setTextRotation(Double rotation) {
AbstractEscherOptRecord opt = getEscherOptRecord(); AbstractEscherOptRecord opt = getEscherOptRecord();
if (rotation == null) { if (rotation == null) {
opt.removeEscherProperty(EscherProperties.TEXT__FONTROTATION); opt.removeEscherProperty(EscherPropertyTypes.TEXT__FONTROTATION);
} else { } else {
int rot = (int)(Math.round(rotation / 90.) % 4L); int rot = (int)(Math.round(rotation / 90.) % 4L);
setEscherProperty(EscherProperties.TEXT__FONTROTATION, rot); setEscherProperty(EscherPropertyTypes.TEXT__FONTROTATION, rot);
} }
} }

View File

@ -86,6 +86,6 @@ public class HwmfColorRef implements Cloneable, GenericRecord {
@Override @Override
public Map<String, Supplier<?>> getGenericProperties() { public Map<String, Supplier<?>> getGenericProperties() {
return GenericRecordUtil.getGenericProperties("color", colorRef::getRGB); return GenericRecordUtil.getGenericProperties("color", this::getColor);
} }
} }

View File

@ -21,18 +21,17 @@ import java.util.Collection;
import java.util.Collections; import java.util.Collections;
import java.util.List; import java.util.List;
import org.apache.poi.ddf.EscherTertiaryOptRecord;
import org.apache.poi.ddf.DefaultEscherRecordFactory; import org.apache.poi.ddf.DefaultEscherRecordFactory;
import org.apache.poi.ddf.EscherBSERecord; import org.apache.poi.ddf.EscherBSERecord;
import org.apache.poi.ddf.EscherBlipRecord; import org.apache.poi.ddf.EscherBlipRecord;
import org.apache.poi.ddf.EscherContainerRecord; import org.apache.poi.ddf.EscherContainerRecord;
import org.apache.poi.ddf.EscherOptRecord; import org.apache.poi.ddf.EscherOptRecord;
import org.apache.poi.ddf.EscherProperties; import org.apache.poi.ddf.EscherPropertyTypes;
import org.apache.poi.ddf.EscherRecord; import org.apache.poi.ddf.EscherRecord;
import org.apache.poi.ddf.EscherRecordFactory; import org.apache.poi.ddf.EscherRecordFactory;
import org.apache.poi.ddf.EscherSimpleProperty; import org.apache.poi.ddf.EscherSimpleProperty;
import org.apache.poi.ddf.EscherSpRecord; import org.apache.poi.ddf.EscherSpRecord;
import org.apache.poi.ddf.EscherTertiaryOptRecord;
import org.apache.poi.hwpf.model.EscherRecordHolder; import org.apache.poi.hwpf.model.EscherRecordHolder;
import org.apache.poi.hwpf.model.FSPA; import org.apache.poi.hwpf.model.FSPA;
import org.apache.poi.hwpf.model.FSPATable; import org.apache.poi.hwpf.model.FSPATable;
@ -125,8 +124,7 @@ public class OfficeDrawingsImpl implements OfficeDrawings
{ {
public HorizontalPositioning getHorizontalPositioning() public HorizontalPositioning getHorizontalPositioning()
{ {
int value = getTertiaryPropertyValue( int value = getTertiaryPropertyValue(EscherPropertyTypes.GROUPSHAPE__POSH );
EscherProperties.GROUPSHAPE__POSH, -1 );
switch ( value ) switch ( value )
{ {
@ -149,8 +147,7 @@ public class OfficeDrawingsImpl implements OfficeDrawings
public HorizontalRelativeElement getHorizontalRelative() public HorizontalRelativeElement getHorizontalRelative()
{ {
int value = getTertiaryPropertyValue( int value = getTertiaryPropertyValue( EscherPropertyTypes.GROUPSHAPE__POSRELH );
EscherProperties.GROUPSHAPE__POSRELH, -1 );
switch ( value ) switch ( value )
{ {
@ -184,7 +181,7 @@ public class OfficeDrawingsImpl implements OfficeDrawings
return null; return null;
EscherSimpleProperty escherProperty = escherOptRecord EscherSimpleProperty escherProperty = escherOptRecord
.lookup( EscherProperties.BLIP__BLIPTODISPLAY ); .lookup( EscherPropertyTypes.BLIP__BLIPTODISPLAY );
if ( escherProperty == null ) if ( escherProperty == null )
return null; return null;
@ -221,30 +218,25 @@ public class OfficeDrawingsImpl implements OfficeDrawings
return fspa.getSpid(); return fspa.getSpid();
} }
private int getTertiaryPropertyValue( int propertyId, private int getTertiaryPropertyValue( EscherPropertyTypes type ) {
int defaultValue )
{
EscherContainerRecord shapeDescription = getEscherShapeRecordContainer( getShapeId() ); EscherContainerRecord shapeDescription = getEscherShapeRecordContainer( getShapeId() );
if ( shapeDescription == null ) if ( shapeDescription == null ) {
return defaultValue; return -1;
}
EscherTertiaryOptRecord escherTertiaryOptRecord = shapeDescription EscherTertiaryOptRecord escherTertiaryOptRecord = shapeDescription
.getChildById( EscherTertiaryOptRecord.RECORD_ID ); .getChildById( EscherTertiaryOptRecord.RECORD_ID );
if ( escherTertiaryOptRecord == null ) if ( escherTertiaryOptRecord == null ) {
return defaultValue; return -1;
}
EscherSimpleProperty escherProperty = escherTertiaryOptRecord EscherSimpleProperty escherProperty = escherTertiaryOptRecord.lookup( type );
.lookup( propertyId ); return ( escherProperty == null ) ? -1 : escherProperty.getPropertyValue();
if ( escherProperty == null )
return defaultValue;
return escherProperty.getPropertyValue();
} }
public VerticalPositioning getVerticalPositioning() public VerticalPositioning getVerticalPositioning()
{ {
int value = getTertiaryPropertyValue( int value = getTertiaryPropertyValue( EscherPropertyTypes.GROUPSHAPE__POSV );
EscherProperties.GROUPSHAPE__POSV, -1 );
switch ( value ) switch ( value )
{ {
@ -267,8 +259,7 @@ public class OfficeDrawingsImpl implements OfficeDrawings
public VerticalRelativeElement getVerticalRelativeElement() public VerticalRelativeElement getVerticalRelativeElement()
{ {
int value = getTertiaryPropertyValue( int value = getTertiaryPropertyValue( EscherPropertyTypes.GROUPSHAPE__POSV );
EscherProperties.GROUPSHAPE__POSV, -1 );
switch ( value ) switch ( value )
{ {

View File

@ -29,8 +29,8 @@ import org.apache.poi.ddf.EscherBSERecord;
import org.apache.poi.ddf.EscherBlipRecord; import org.apache.poi.ddf.EscherBlipRecord;
import org.apache.poi.ddf.EscherComplexProperty; import org.apache.poi.ddf.EscherComplexProperty;
import org.apache.poi.ddf.EscherOptRecord; import org.apache.poi.ddf.EscherOptRecord;
import org.apache.poi.ddf.EscherProperties;
import org.apache.poi.ddf.EscherProperty; import org.apache.poi.ddf.EscherProperty;
import org.apache.poi.ddf.EscherPropertyTypes;
import org.apache.poi.ddf.EscherRecord; import org.apache.poi.ddf.EscherRecord;
import org.apache.poi.hwpf.model.PICF; import org.apache.poi.hwpf.model.PICF;
import org.apache.poi.hwpf.model.PICFAndOfficeArtData; import org.apache.poi.hwpf.model.PICFAndOfficeArtData;
@ -468,11 +468,11 @@ public final class Picture {
*/ */
public String getDescription() public String getDescription()
{ {
for(EscherRecord escherRecord : _picfAndOfficeArtData.getShape().getChildRecords()){ for(EscherRecord escherRecord : _picfAndOfficeArtData.getShape()){
if(escherRecord instanceof EscherOptRecord){ if(escherRecord instanceof EscherOptRecord){
EscherOptRecord escherOptRecord = (EscherOptRecord) escherRecord; EscherOptRecord escherOptRecord = (EscherOptRecord) escherRecord;
for(EscherProperty property : escherOptRecord.getEscherProperties()){ for(EscherProperty property : escherOptRecord.getEscherProperties()){
if(EscherProperties.GROUPSHAPE__DESCRIPTION == property.getPropertyNumber()){ if (EscherPropertyTypes.GROUPSHAPE__DESCRIPTION.propNumber == property.getPropertyNumber()){
byte[] complexData = ((EscherComplexProperty)property).getComplexData(); byte[] complexData = ((EscherComplexProperty)property).getComplexData();
return StringUtil.getFromUnicodeLE(complexData,0,complexData.length/2-1); return StringUtil.getFromUnicodeLE(complexData,0,complexData.length/2-1);
} }

View File

@ -38,7 +38,7 @@ import org.apache.poi.POIDataSamples;
import org.apache.poi.ddf.AbstractEscherOptRecord; import org.apache.poi.ddf.AbstractEscherOptRecord;
import org.apache.poi.ddf.EscherDgRecord; import org.apache.poi.ddf.EscherDgRecord;
import org.apache.poi.ddf.EscherDggRecord; import org.apache.poi.ddf.EscherDggRecord;
import org.apache.poi.ddf.EscherProperties; import org.apache.poi.ddf.EscherPropertyTypes;
import org.apache.poi.ddf.EscherSimpleProperty; import org.apache.poi.ddf.EscherSimpleProperty;
import org.apache.poi.hslf.usermodel.HSLFAutoShape; import org.apache.poi.hslf.usermodel.HSLFAutoShape;
import org.apache.poi.hslf.usermodel.HSLFGroupShape; import org.apache.poi.hslf.usermodel.HSLFGroupShape;
@ -407,12 +407,12 @@ public final class TestShapes {
HSLFSimpleShape sh = new HSLFAutoShape(ShapeType.RT_TRIANGLE); HSLFSimpleShape sh = new HSLFAutoShape(ShapeType.RT_TRIANGLE);
AbstractEscherOptRecord opt = sh.getEscherOptRecord(); AbstractEscherOptRecord opt = sh.getEscherOptRecord();
EscherSimpleProperty prop = HSLFSimpleShape.getEscherProperty(opt, EscherProperties.LINESTYLE__LINEWIDTH); EscherSimpleProperty prop = HSLFSimpleShape.getEscherProperty(opt, EscherPropertyTypes.LINESTYLE__LINEWIDTH);
assertNull(prop); assertNull(prop);
assertEquals(HSLFSimpleShape.DEFAULT_LINE_WIDTH, sh.getLineWidth(), 0); assertEquals(HSLFSimpleShape.DEFAULT_LINE_WIDTH, sh.getLineWidth(), 0);
sh.setLineWidth(1.0); sh.setLineWidth(1.0);
prop = HSLFSimpleShape.getEscherProperty(opt, EscherProperties.LINESTYLE__LINEWIDTH); prop = HSLFSimpleShape.getEscherProperty(opt, EscherPropertyTypes.LINESTYLE__LINEWIDTH);
assertNotNull(prop); assertNotNull(prop);
assertEquals(1.0, sh.getLineWidth(), 0); assertEquals(1.0, sh.getLineWidth(), 0);
} }

View File

@ -28,18 +28,11 @@ import org.apache.poi.POIDataSamples;
import org.apache.poi.ddf.AbstractEscherOptRecord; import org.apache.poi.ddf.AbstractEscherOptRecord;
import org.apache.poi.ddf.EscherBSERecord; import org.apache.poi.ddf.EscherBSERecord;
import org.apache.poi.ddf.EscherContainerRecord; import org.apache.poi.ddf.EscherContainerRecord;
import org.apache.poi.ddf.EscherProperties; import org.apache.poi.ddf.EscherPropertyTypes;
import org.apache.poi.ddf.EscherRecord; import org.apache.poi.ddf.EscherRecord;
import org.apache.poi.ddf.EscherSimpleProperty; import org.apache.poi.ddf.EscherSimpleProperty;
import org.apache.poi.hslf.HSLFTestDataSamples; import org.apache.poi.hslf.HSLFTestDataSamples;
import org.apache.poi.hslf.record.Document; import org.apache.poi.hslf.record.Document;
import org.apache.poi.hslf.usermodel.HSLFAutoShape;
import org.apache.poi.hslf.usermodel.HSLFFill;
import org.apache.poi.hslf.usermodel.HSLFPictureData;
import org.apache.poi.hslf.usermodel.HSLFShape;
import org.apache.poi.hslf.usermodel.HSLFSheet;
import org.apache.poi.hslf.usermodel.HSLFSlide;
import org.apache.poi.hslf.usermodel.HSLFSlideShow;
import org.apache.poi.sl.usermodel.PictureData.PictureType; import org.apache.poi.sl.usermodel.PictureData.PictureType;
import org.apache.poi.sl.usermodel.ShapeType; import org.apache.poi.sl.usermodel.ShapeType;
import org.junit.Test; import org.junit.Test;
@ -209,7 +202,7 @@ public final class TestBackground {
private int getFillPictureRefCount(HSLFShape shape, HSLFFill fill) { private int getFillPictureRefCount(HSLFShape shape, HSLFFill fill) {
AbstractEscherOptRecord opt = shape.getEscherOptRecord(); AbstractEscherOptRecord opt = shape.getEscherOptRecord();
EscherSimpleProperty p = HSLFShape.getEscherProperty(opt, EscherProperties.FILL__PATTERNTEXTURE); EscherSimpleProperty p = HSLFShape.getEscherProperty(opt, EscherPropertyTypes.FILL__PATTERNTEXTURE);
if(p != null) { if(p != null) {
int idx = p.getPropertyValue(); int idx = p.getPropertyValue();

View File

@ -53,7 +53,7 @@ import org.apache.poi.common.usermodel.fonts.FontGroup;
import org.apache.poi.ddf.AbstractEscherOptRecord; import org.apache.poi.ddf.AbstractEscherOptRecord;
import org.apache.poi.ddf.EscherArrayProperty; import org.apache.poi.ddf.EscherArrayProperty;
import org.apache.poi.ddf.EscherColorRef; import org.apache.poi.ddf.EscherColorRef;
import org.apache.poi.ddf.EscherProperties; import org.apache.poi.ddf.EscherPropertyTypes;
import org.apache.poi.hslf.HSLFTestDataSamples; import org.apache.poi.hslf.HSLFTestDataSamples;
import org.apache.poi.hslf.exceptions.OldPowerPointFormatException; import org.apache.poi.hslf.exceptions.OldPowerPointFormatException;
import org.apache.poi.hslf.model.HeadersFooters; import org.apache.poi.hslf.model.HeadersFooters;
@ -600,7 +600,7 @@ public final class TestBugs {
HSLFSlideShow ppt = open("bug46441.ppt"); HSLFSlideShow ppt = open("bug46441.ppt");
HSLFAutoShape as = (HSLFAutoShape)ppt.getSlides().get(0).getShapes().get(0); HSLFAutoShape as = (HSLFAutoShape)ppt.getSlides().get(0).getShapes().get(0);
AbstractEscherOptRecord opt = as.getEscherOptRecord(); AbstractEscherOptRecord opt = as.getEscherOptRecord();
EscherArrayProperty ep = HSLFShape.getEscherProperty(opt, EscherProperties.FILL__SHADECOLORS); EscherArrayProperty ep = HSLFShape.getEscherProperty(opt, EscherPropertyTypes.FILL__SHADECOLORS);
double[][] exp = { double[][] exp = {
// r, g, b, position // r, g, b, position
{94, 158, 255, 0}, {94, 158, 255, 0},

View File

@ -23,6 +23,7 @@ import static org.junit.Assert.assertEquals;
import java.io.IOException; import java.io.IOException;
import org.apache.poi.poifs.storage.RawDataUtil; import org.apache.poi.poifs.storage.RawDataUtil;
import org.apache.poi.sl.usermodel.PictureData;
import org.apache.poi.util.HexDump; import org.apache.poi.util.HexDump;
import org.apache.poi.util.HexRead; import org.apache.poi.util.HexRead;
import org.junit.Test; import org.junit.Test;
@ -37,8 +38,8 @@ public final class TestEscherBSERecord {
int bytesWritten = r.fillFields( HexRead.readFromString( data ), 0, new DefaultEscherRecordFactory() ); int bytesWritten = r.fillFields( HexRead.readFromString( data ), 0, new DefaultEscherRecordFactory() );
assertEquals( 44, bytesWritten ); assertEquals( 44, bytesWritten );
assertEquals( (short) 0x0001, r.getOptions() ); assertEquals( (short) 0x0001, r.getOptions() );
assertEquals( EscherBSERecord.BT_JPEG, r.getBlipTypeWin32() ); assertEquals( PictureData.PictureType.JPEG.nativeId, r.getBlipTypeWin32() );
assertEquals( EscherBSERecord.BT_JPEG, r.getBlipTypeMacOS() ); assertEquals( PictureData.PictureType.JPEG.nativeId, r.getBlipTypeMacOS() );
assertEquals( "[01, 02, 03, 04, 05, 06, 07, 08, 09, 0A, 0B, 0C, 0D, 0E, 0F, 00]", HexDump.toHex( r.getUid() ) ); assertEquals( "[01, 02, 03, 04, 05, 06, 07, 08, 09, 0A, 0B, 0C, 0D, 0E, 0F, 00]", HexDump.toHex( r.getUid() ) );
assertEquals( (short) 1, r.getTag() ); assertEquals( (short) 1, r.getTag() );
assertEquals( 2, r.getRef() ); assertEquals( 2, r.getRef() );
@ -65,8 +66,8 @@ public final class TestEscherBSERecord {
private EscherBSERecord createRecord() { private EscherBSERecord createRecord() {
EscherBSERecord r = new EscherBSERecord(); EscherBSERecord r = new EscherBSERecord();
r.setOptions( (short) 0x0001 ); r.setOptions( (short) 0x0001 );
r.setBlipTypeWin32( EscherBSERecord.BT_JPEG ); r.setBlipTypeWin32( (byte)PictureData.PictureType.JPEG.nativeId );
r.setBlipTypeMacOS( EscherBSERecord.BT_JPEG ); r.setBlipTypeMacOS( (byte)PictureData.PictureType.JPEG.nativeId );
r.setUid( HexRead.readFromString( "01 02 03 04 05 06 07 08 09 0A 0B 0C 0D 0E 0F 00" ) ); r.setUid( HexRead.readFromString( "01 02 03 04 05 06 07 08 09 0A 0B 0C 0D 0E 0F 00" ) );
r.setTag( (short) 1 ); r.setTag( (short) 1 );
r.setRef( 2 ); r.setRef( 2 );
@ -82,29 +83,31 @@ public final class TestEscherBSERecord {
@Test @Test
public void testToString() { public void testToString() {
String nl = System.getProperty("line.separator");
EscherBSERecord record = createRecord(); EscherBSERecord record = createRecord();
String expected = String expected =
"org.apache.poi.ddf.EscherBSERecord (BSE):" + nl + "{ /* BSE */\n" +
" RecordId: 0xF007" + nl + "\t recordId: -4089 /* 0xf007 */\n" +
" Version: 0x0001" + nl + "\t, version: 1\n" +
" Instance: 0x0000" + nl + "\t, instance: 0\n" +
" Options: 0x0001" + nl + "\t, options: 1\n" +
" Record Size: 44" + nl + "\t, recordSize: 44 /* 0x0000002c */\n" +
" BlipTypeWin32: 0x05" + nl + "\t, blipTypeWin32: 5\n" +
" BlipTypeMacOS: 0x05" + nl + "\t, pictureTypeWin32: \"JPEG\"\n" +
" SUID: " + nl + "\t, blipTypeMacOS: 5\n" +
" 00: 01, 02, 03, 04, 05, 06, 07, 08, 09, 0A, 0B, 0C, 0D, 0E, 0F, 00" + nl + "\t, pictureTypeMacOS: \"JPEG\"\n" +
" Tag: 0x0001" + nl + "\t, suid: \"AQIDBAUGBwgJCgsMDQ4PAA==\"\n" +
" Size: 0x00000000" + nl + "\t, tag: 1\n" +
" Ref: 0x00000002" + nl + "\t, size: 0\n" +
" Offset: 0x00000003" + nl + "\t, ref: 2\n" +
" Usage: 0x04" + nl + "\t, offset: 3\n" +
" Name: 0x05" + nl + "\t, usage: 4\n" +
" Unused2: 0x06" + nl + "\t, name: 5\n" +
" Unused3: 0x07" + nl + "\t, unused2: 6\n" +
" Extra Data: " + nl + "\t, unused3: 7\n" +
" : 0"; "\t, blipRecord: null\n" +
"\t, remainingData: \"\"\n" +
"}";
String actual = record.toString(); String actual = record.toString();
assertEquals( expected, actual ); assertEquals( expected, actual );
} }

View File

@ -23,6 +23,7 @@ import static org.junit.Assert.assertNotNull;
import static org.junit.Assert.assertTrue; import static org.junit.Assert.assertTrue;
import org.apache.poi.POIDataSamples; import org.apache.poi.POIDataSamples;
import org.apache.poi.sl.usermodel.PictureData;
import org.junit.Test; import org.junit.Test;
/** /**
@ -41,8 +42,8 @@ public final class TestEscherBlipRecord {
record.fillFields(data, 0, new DefaultEscherRecordFactory()); record.fillFields(data, 0, new DefaultEscherRecordFactory());
EscherContainerRecord bstore = (EscherContainerRecord)record.getChild(1); EscherContainerRecord bstore = (EscherContainerRecord)record.getChild(1);
EscherBSERecord bse1 = (EscherBSERecord)bstore.getChild(0); EscherBSERecord bse1 = (EscherBSERecord)bstore.getChild(0);
assertEquals(EscherBSERecord.BT_PNG, bse1.getBlipTypeWin32()); assertEquals(PictureData.PictureType.PNG.nativeId, bse1.getBlipTypeWin32());
assertEquals(EscherBSERecord.BT_PNG, bse1.getBlipTypeMacOS()); assertEquals(PictureData.PictureType.PNG.nativeId, bse1.getBlipTypeMacOS());
assertArrayEquals(new byte[]{ assertArrayEquals(new byte[]{
0x65, 0x07, 0x4A, (byte)0x8D, 0x3E, 0x42, (byte)0x8B, (byte)0xAC, 0x65, 0x07, 0x4A, (byte)0x8D, 0x3E, 0x42, (byte)0x8B, (byte)0xAC,
0x1D, (byte)0x89, 0x35, 0x4F, 0x48, (byte)0xFA, 0x37, (byte)0xC2 0x1D, (byte)0x89, 0x35, 0x4F, 0x48, (byte)0xFA, 0x37, (byte)0xC2
@ -88,8 +89,8 @@ public final class TestEscherBlipRecord {
EscherContainerRecord bstore = (EscherContainerRecord)record.getChild(1); EscherContainerRecord bstore = (EscherContainerRecord)record.getChild(1);
EscherBSERecord bse1 = (EscherBSERecord)bstore.getChild(1); EscherBSERecord bse1 = (EscherBSERecord)bstore.getChild(1);
//System.out.println(bse1); //System.out.println(bse1);
assertEquals(EscherBSERecord.BT_WMF, bse1.getBlipTypeWin32()); assertEquals(PictureData.PictureType.WMF.nativeId, bse1.getBlipTypeWin32());
assertEquals(EscherBSERecord.BT_PICT, bse1.getBlipTypeMacOS()); assertEquals(PictureData.PictureType.PICT.nativeId, bse1.getBlipTypeMacOS());
assertArrayEquals(new byte[]{ assertArrayEquals(new byte[]{
(byte)0xC7, 0x15, 0x69, 0x2D, (byte)0xE5, (byte)0x89, (byte)0xA3, 0x6F, (byte)0xC7, 0x15, 0x69, 0x2D, (byte)0xE5, (byte)0x89, (byte)0xA3, 0x6F,
0x66, 0x03, (byte)0xD6, 0x24, (byte)0xF7, (byte)0xDB, 0x1D, 0x13 0x66, 0x03, (byte)0xD6, 0x24, (byte)0xF7, (byte)0xDB, 0x1D, 0x13

View File

@ -24,7 +24,16 @@ import org.junit.Test;
public final class TestEscherBoolProperty { public final class TestEscherBoolProperty {
@Test @Test
public void testToString() { public void testToString() {
EscherBoolProperty p = new EscherBoolProperty((short)1, 1); EscherBoolProperty p = new EscherBoolProperty(EscherPropertyTypes.GEOMETRY__FILLOK, 1);
assertEquals("propNum: 1, RAW: 0x0001, propName: unknown, complex: false, blipId: false, value: 1 (0x00000001)", p.toString()); String expected =
"{ /* GEOMETRY__FILLOK */\n" +
"\t id: 383 /* 0x017f */\n" +
"\t, name: \"geometry.fillok\"\n" +
"\t, propertyNumber: 383 /* 0x017f */\n" +
"\t, propertySize: 6\n" +
"\t, flags: 0x17f /* */ \n" +
"\t, value: 1\n" +
"}";
assertEquals(expected, p.toString());
} }
} }

View File

@ -64,19 +64,18 @@ public final class TestEscherChildAnchorRecord {
@Test @Test
public void testToString(){ public void testToString(){
String nl = System.getProperty( "line.separator" );
String expected = String expected =
"org.apache.poi.ddf.EscherChildAnchorRecord (ChildAnchor):" + nl + "{ /* CHILD_ANCHOR */\n" +
" RecordId: 0xF00F" + nl + "\t recordId: -4081 /* 0xf00f */\n" +
" Version: 0x0001" + nl + "\t, version: 1\n" +
" Instance: 0x0000" + nl + "\t, instance: 0\n" +
" Options: 0x0001" + nl + "\t, options: 1\n" +
" Record Size: 24" + nl + "\t, recordSize: 24 /* 0x00000018 */\n" +
" X1: 0x00000001" + nl + "\t, x1: 1\n" +
" Y1: 0x00000002" + nl + "\t, y1: 2\n" +
" X2: 0x00000003" + nl + "\t, x2: 3\n" +
" Y2: 0x00000004"; "\t, y2: 4\n" +
"}";
assertEquals( expected, createRecord().toString() ); assertEquals( expected, createRecord().toString() );
} }

View File

@ -70,25 +70,24 @@ public class TestEscherClientAnchorRecord {
@Test @Test
public void testToString() { public void testToString() {
String nl = System.getProperty("line.separator");
String expected = String expected =
"org.apache.poi.ddf.EscherClientAnchorRecord (ClientAnchor):" + nl + "{ /* CLIENT_ANCHOR */\n" +
" RecordId: 0xF010" + nl + "\t recordId: -4080 /* 0xf010 */\n" +
" Version: 0x0001" + nl + "\t, version: 1\n" +
" Instance: 0x0000" + nl + "\t, instance: 0\n" +
" Options: 0x0001" + nl + "\t, options: 1\n" +
" Record Size: 28" + nl + "\t, recordSize: 28 /* 0x0000001c */\n" +
" Flag: 0x004D" + nl + "\t, flag: 77 /* 0x004d */\n" +
" Col1: 0x0037" + nl + "\t, col1: 55 /* 0x0037 */\n" +
" DX1: 0x0021" + nl + "\t, dx1: 33 /* 0x0021 */\n" +
" Row1: 0x0058" + nl + "\t, row1: 88 /* 0x0058 */\n" +
" DY1: 0x000B" + nl + "\t, dy1: 11 /* 0x000b */\n" +
" Col2: 0x002C" + nl + "\t, col2: 44 /* 0x002c */\n" +
" DX2: 0x0016" + nl + "\t, dx2: 22 /* 0x0016 */\n" +
" Row2: 0x0063" + nl + "\t, row2: 99 /* 0x0063 */\n" +
" DY2: 0x0042" + nl + "\t, dy2: 66 /* 0x0042 */\n" +
" Extra Data: " + nl + "\t, remainingData: \"/90=\"\n" +
" 0: FF, DD"; "}";
assertEquals( expected, createRecord().toString() ); assertEquals( expected, createRecord().toString() );
} }

View File

@ -53,17 +53,15 @@ public class TestEscherClientDataRecord {
@Test @Test
public void testToString() { public void testToString() {
String nl = System.getProperty("line.separator");
String expected = String expected =
"org.apache.poi.ddf.EscherClientDataRecord (ClientData):" + nl + "{ /* CLIENT_DATA */\n" +
" RecordId: 0xF011" + nl + "\t recordId: -4079 /* 0xf011 */\n" +
" Version: 0x0002" + nl + "\t, version: 2\n" +
" Instance: 0x0000" + nl + "\t, instance: 0\n" +
" Options: 0x0002" + nl + "\t, options: 2\n" +
" Record Size: 8" + nl + "\t, recordSize: 8\n" +
" Extra Data: " + nl + "\t, remainingData: \"\"\n" +
" : 0"; "}";
assertEquals( expected, createRecord().toString() ); assertEquals( expected, createRecord().toString() );
} }

View File

@ -19,6 +19,7 @@ package org.apache.poi.ddf;
import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertFalse; import static org.junit.Assert.assertFalse;
import static org.junit.Assert.assertNotSame;
import static org.junit.Assert.assertTrue; import static org.junit.Assert.assertTrue;
import java.util.List; import java.util.List;
@ -80,16 +81,15 @@ public final class TestEscherContainerRecord {
EscherContainerRecord r = new EscherContainerRecord(); EscherContainerRecord r = new EscherContainerRecord();
r.setRecordId(EscherContainerRecord.SP_CONTAINER); r.setRecordId(EscherContainerRecord.SP_CONTAINER);
r.setOptions((short) 0x000F); r.setOptions((short) 0x000F);
String nl = System.getProperty("line.separator");
String expected = String expected =
"org.apache.poi.ddf.EscherContainerRecord (SpContainer):" + nl + "{ /* SP_CONTAINER */\n" +
" RecordId: 0xF004" + nl + "\t recordId: -4092 /* 0xf004 */\n" +
" Version: 0x000F" + nl + "\t, version: 15 /* 0x000f */\n" +
" Instance: 0x0000" + nl + "\t, instance: 0\n" +
" Options: 0x000F" + nl + "\t, options: 15 /* 0x000f */\n" +
" Record Size: 8" + nl + "\t, recordSize: 8\n" +
" isContainer: true" + nl + "\t, isContainer: true\n" +
" children: 0x00000000"; "}";
assertEquals(expected, r.toString()); assertEquals(expected, r.toString());
EscherOptRecord r2 = new EscherOptRecord(); EscherOptRecord r2 = new EscherOptRecord();
@ -99,53 +99,61 @@ public final class TestEscherContainerRecord {
r.addChildRecord(r2); r.addChildRecord(r2);
expected = expected =
"org.apache.poi.ddf.EscherContainerRecord (SpContainer):" + nl + "{ /* SP_CONTAINER */\n" +
" RecordId: 0xF004" + nl + "\t recordId: -4092 /* 0xf004 */\n" +
" Version: 0x000F" + nl + "\t, version: 15 /* 0x000f */\n" +
" Instance: 0x0000" + nl + "\t, instance: 0\n" +
" Options: 0x000F" + nl + "\t, options: 15 /* 0x000f */\n" +
" Record Size: 16" + nl + "\t, recordSize: 16 /* 0x00000010 */\n" +
" isContainer: true" + nl + "\t, isContainer: true\n" +
" children: 0x00000001" + nl + "\t, children: [\n" +
" Child 0: org.apache.poi.ddf.EscherOptRecord (Opt):" + nl + "\t\t{ /* OPT */\n" +
" RecordId: 0xF00B" + nl + "\t\t\t recordId: -4085 /* 0xf00b */\n" +
" Version: 0x0003" + nl + "\t\t\t, version: 3\n" +
" Instance: 0x0000" + nl + "\t\t\t, instance: 0\n" +
" Options: 0x0003" + nl + "\t\t\t, options: 3\n" +
" Record Size: 8" + nl + "\t\t\t, recordSize: 8\n" +
" isContainer: false" + nl + "\t\t\t, isContainer: false\n" +
" numchildren: 0x00000000" + nl + "\t\t\t, properties: [\n" +
" properties: 0x00000000"; "]\n" +
"\t\t}\n" +
"\t]\n" +
"}";
assertEquals(expected, r.toString()); assertEquals(expected, r.toString());
r.addChildRecord(r2); r.addChildRecord(r2);
expected = expected =
"org.apache.poi.ddf.EscherContainerRecord (SpContainer):" + nl + "{ /* SP_CONTAINER */\n" +
" RecordId: 0xF004" + nl + "\t recordId: -4092 /* 0xf004 */\n" +
" Version: 0x000F" + nl + "\t, version: 15 /* 0x000f */\n" +
" Instance: 0x0000" + nl + "\t, instance: 0\n" +
" Options: 0x000F" + nl + "\t, options: 15 /* 0x000f */\n" +
" Record Size: 24" + nl + "\t, recordSize: 24 /* 0x00000018 */\n" +
" isContainer: true" + nl + "\t, isContainer: true\n" +
" children: 0x00000002" + nl + "\t, children: [\n" +
" Child 0: org.apache.poi.ddf.EscherOptRecord (Opt):" + nl + "\t\t{ /* OPT */\n" +
" RecordId: 0xF00B" + nl + "\t\t\t recordId: -4085 /* 0xf00b */\n" +
" Version: 0x0003" + nl + "\t\t\t, version: 3\n" +
" Instance: 0x0000" + nl + "\t\t\t, instance: 0\n" +
" Options: 0x0003" + nl + "\t\t\t, options: 3\n" +
" Record Size: 8" + nl + "\t\t\t, recordSize: 8\n" +
" isContainer: false" + nl + "\t\t\t, isContainer: false\n" +
" numchildren: 0x00000000" + nl + "\t\t\t, properties: [\n" +
" properties: 0x00000000" + nl + "]\n" +
" Child 1: org.apache.poi.ddf.EscherOptRecord (Opt):" + nl + "\t\t},\n" +
" RecordId: 0xF00B" + nl + "\n" +
" Version: 0x0003" + nl + "\t\t{ /* OPT - index: 1 */\n" +
" Instance: 0x0000" + nl + "\t\t\t recordId: -4085 /* 0xf00b */\n" +
" Options: 0x0003" + nl + "\t\t\t, version: 3\n" +
" Record Size: 8" + nl + "\t\t\t, instance: 0\n" +
" isContainer: false" + nl + "\t\t\t, options: 3\n" +
" numchildren: 0x00000000" + nl + "\t\t\t, recordSize: 8\n" +
" properties: 0x00000000"; "\t\t\t, isContainer: false\n" +
"\t\t\t, properties: [\n" +
"]\n" +
"\t\t}\n" +
"\t]\n" +
"}";
assertEquals(expected, r.toString()); assertEquals(expected, r.toString());
} }
@ -159,8 +167,6 @@ public final class TestEscherContainerRecord {
public int getRecordSize() { return 10; } public int getRecordSize() { return 10; }
@Override @Override
public String getRecordName() { return ""; } public String getRecordName() { return ""; }
@Override
protected Object[][] getAttributeMap() { return null; }
@Override @Override
public Enum getGenericRecordType() { return EscherRecordTypes.UNKNOWN; } public Enum getGenericRecordType() { return EscherRecordTypes.UNKNOWN; }
} }
@ -203,7 +209,7 @@ public final class TestEscherContainerRecord {
children0.add(chC); children0.add(chC);
List<EscherRecord> children1 = ecr.getChildRecords(); List<EscherRecord> children1 = ecr.getChildRecords();
assertTrue(children0 != children1); assertNotSame(children0, children1);
assertEquals(2, children1.size()); assertEquals(2, children1.size());
assertEquals(chA, children1.get(0)); assertEquals(chA, children1.get(0));
assertEquals(chB, children1.get(1)); assertEquals(chB, children1.get(1));

View File

@ -57,16 +57,17 @@ public final class TestEscherDgRecord {
@Test @Test
public void testToString() { public void testToString() {
String nl = System.getProperty("line.separator");
String expected = String expected =
"org.apache.poi.ddf.EscherDgRecord (Dg):" + nl + "{ /* DG */\n" +
" RecordId: 0xF008" + nl + "\t recordId: -4088 /* 0xf008 */\n" +
" Version: 0x0000" + nl + "\t, version: 0\n" +
" Instance: 0x0001" + nl + "\t, instance: 1\n" +
" Options: 0x0010" + nl + "\t, options: 16 /* 0x0010 */\n" +
" Record Size: 16" + nl + "\t, recordSize: 16 /* 0x00000010 */\n" +
" NumShapes: 0x00000002" + nl + "\t, numShapes: 2\n" +
" LastMSOSPID: 0x00000401"; "\t, lastMSOSPID: 1025 /* 0x00000401 */\n" +
"\t, drawingGroupId: 1\n" +
"}";
assertEquals( expected, createRecord().toString() ); assertEquals( expected, createRecord().toString() );
} }

View File

@ -68,20 +68,24 @@ public final class TestEscherDggRecord {
@Test @Test
public void testToString() { public void testToString() {
String nl = System.getProperty("line.separator");
String expected = String expected =
"org.apache.poi.ddf.EscherDggRecord (Dgg):" + nl + "{ /* DGG */\n" +
" RecordId: 0xF006" + nl + "\t recordId: -4090 /* 0xf006 */\n" +
" Version: 0x0000" + nl + "\t, version: 0\n" +
" Instance: 0x0000" + nl + "\t, instance: 0\n" +
" Options: 0x0000" + nl + "\t, options: 0\n" +
" Record Size: 32" + nl + "\t, recordSize: 32 /* 0x00000020 */\n" +
" ShapeIdMax: 0x00000402" + nl + "\t, fileIdClusters: [\n" +
" NumIdClusters: 0x00000002" + nl + "\n" +
" NumShapesSaved: 0x00000002" + nl + "\t{ /* FileIdCluster */\n" +
" DrawingsSaved: 0x00000001" + nl + "\t\t drawingGroupId: 1\n" +
" FileId Clusters: 0x00000001" + nl + "\t\t, numShapeIdUsed: 2\n" +
" Group1: 0x00000002"; "\t}]\n" +
"\t, shapeIdMax: 1026 /* 0x00000402 */\n" +
"\t, numIdClusters: 2\n" +
"\t, numShapesSaved: 2\n" +
"\t, drawingsSaved: 1\n" +
"}";
assertEquals( expected, createRecord().toString() ); assertEquals( expected, createRecord().toString() );
} }

View File

@ -19,13 +19,13 @@ package org.apache.poi.ddf;
import static org.junit.Assert.assertTrue; import static org.junit.Assert.assertTrue;
import java.io.ByteArrayInputStream;
import java.io.InputStream; import java.io.InputStream;
import java.io.PrintStream; import java.io.PrintStream;
import java.io.UnsupportedEncodingException; import java.io.UnsupportedEncodingException;
import org.apache.poi.POIDataSamples; import org.apache.poi.POIDataSamples;
import org.apache.poi.hssf.HSSFTestDataSamples; import org.apache.poi.hssf.HSSFTestDataSamples;
import org.apache.poi.poifs.storage.RawDataUtil;
import org.apache.poi.util.IOUtils; import org.apache.poi.util.IOUtils;
import org.apache.poi.util.LocaleUtil; import org.apache.poi.util.LocaleUtil;
import org.apache.poi.util.NullOutputStream; import org.apache.poi.util.NullOutputStream;
@ -40,19 +40,50 @@ public class TestEscherDump {
nullPS = new NullPrinterStream(); nullPS = new NullPrinterStream();
} }
// simple test to at least cover some parts of the class
@Test @Test
public void testSimple() throws Exception { public void testSimple() throws Exception {
// simple test to at least cover some parts of the class final String recordData =
EscherDump.main(new String[] {}, nullPS); "H4sIAAAAAAAAAL2UaVCSWxjHX0SBChABLRXM1FxSEzXTzHK7dpVIcMmwxXCP9KaGTaWlGYLrtGmGmYEmYmqF2qIt4ppmjNG+" +
"2dWulUtOUdq1NHjva8v90HT7eM+Z5znP/M9/zpk5v3mONgAoc5AANBDKeVDW0gQAjZkVCti3mKnpAExpB/m8AKTyEiTCNd2J" +
"Z+O0o6W+srDCyH3DhzkgUAD76v86QNA4mKTMg4QfnUew/5qA29CZz6ALqGcSgNzOICB05gD1rhODJR2AZu3Ox3YOKAfVUPhH" +
"ULtbpdVJ0ccdijw0pY1A56M3Jup7U15jp7X4PPTTecx92/MT9eZwtUICrLJvsB6z0fHG5qbw7mRpFRaOnPYJ6SqXd5AQMSKM" +
"jceyMD4NsULkj1OwHncz5cO3pPvCXXPTMNdNa+kDfwku4q0RnFL8YGBI6N+oXHlgzCkGWGRdONJPK1PbusJrhBltylPBMm3e" +
"G0kw6DGdLhoU3pmgJ6n1maC1fXrs0uUL6cWG/kGVm3MWHh3pALq4+PH55k7Uu3d+x85u9zxwIzfQuU+3TIG5SkOgrS1tCJb3" +
"3nqHrxcx3XlJA6vZJ6Oi1ctaXppQyBQLbLLrPJaKKq+zIexFLrVdZM+r34pJJpNN1hSrWbM/lIyRmKpYRIi7CybTTUzBWt49" +
"11HRM/VbCiZ6Gyt9TZmhGXPS75xYjpH366vhgLJu4ZoZfM+/4FvGaBZIE9aZ2SduMrUT4mJA4NpP8F2AhB+dT+D/jY/7DZ84" +
"ULbaK4C4crJvZ4qej2+em2+Vni4mPluh2e5xyoGUWYRaoFnWubHcaX+L09Ya0ta4KrP13C2ozMyicr4ovY0fNhT2wfMF7ip8" +
"/tD0u96myXcn92gtTnEuGfBJxY0lFG0mJxPWpknjNxmzWvzKj18rpjO4hhQXAtaRVSmJu+D8egI3RdQVXYxzRhs1+HE2iNvM" +
"fVe2DsSjqJQbBdUajcaECC3/58MP97Q0Eo+GNTdKbhk1r7UJadrVj0rLplmAqU/BlGeXDObGLtl69vITp9tD25vVY9vUT17u" +
"WTGW8idcxUDMMX2PHa8X6xzG0C5cGJcVth40m3ycwCpcfuP4OClu6IpysV/9QuvrdW/Yb3Qj6Ul7e3nybqemdkvLXsXG2N3v" +
"qeVE0woXb06pLduuFWUv7NxY8jq1k63fcD5jvG/w/IE8eUNh0Pohz0WRx6tdOlf4XhlbF5pgfYYzn8w6cjYx/8rBXvtWNz8L" +
"6uu+ig35t+dgOc4jOpLirmFPtjQdKHovGZ4Bff4LaIPLnx6cbnKFo8JHDoGpJ1+BwKGfgM6GhB+d+F/0acj3PiVEABoProzN" +
"1dcsVo9TPoPIF+r9EQI0qtveV4WEI1YhFjfmLxDsyFJptHvx/0BD3bfKJY/XqlFTReyIko4tQSzFFRyGRbkyg7MyuCqTmsiA" +
"mAgs3FGB0BOR7LzNuUYMC9QWaXyUTcxELLOFQvaRIQZ1HlgkJtE25Ohym/xzkqxqbFI1fWKsGgKq0m/q9kwkVDJAvdKM+7c8" +
"wj8GVPdneU0GVaeLVO6Kd3T2lMQFRNeCRwUyx5LSIxI5RmIFNc2RnuSIfYOeOZ+0CwzE7BFTJO+5cVeUz2nDN7mMYUSYOZyv" +
"SyyaRRydLKPYMmqFbS5K8RJ6vQNIGtiuI8AKCEgXsqV9Vz1tgvzovKiD2FPtpNgRlb0keoprdS+hnsP6ICwLBrE9dz26g2YP" +
"DszibWNE7zW5xndwlsoqFRh87XTFw8BXiFdv0SDsGBnfNcOu/Qu7y7SLppfzLJq714byzYQ590BA+BN2xyDhR+fZX7CL/s5u" +
"Q9f/8ccWX28U3BaGw9qTiSqDfOtHmXXZq8XiHXAYoz901c5V2lVulTXZEMqwnLq8+8ds95s0FFrdl73saRntr/UuUxFHY0WU" +
"z5b333qXTe/NagSRrmqkqypoNG12Oz3nE5Yzyt7d05eY66Ci2oTR+rNS3K4OiClGK+07HWtFFLvAqv6sNkpFsLs4Wp8XfRp/" +
"11oPk3uTQB0ftHg1C16KRTBl+AbCzVaYfx6VFlJ7GL7Jme8bVOku8FKZL0eGgMVk4qhEnpZogNrtFU5yEyswJ+LbHOKsOPCn" +
"cT19LR+PfTgjN4CKCS5Es4LS+7nLt9hQ7ejwGQnEyxebOgJzlHjotWUACpoZsFkAgGqBeUDZAzB6h4N2MFCNhmIuFJMAgPsH" +
"eJr+iZEHAAA=";
new EscherDump().dump(0, new byte[] {}, nullPS); // Create a new instance of the escher dumper
new EscherDump().dump(new byte[] {}, 0, 0, nullPS); EscherDump dumper = new EscherDump();
new EscherDump().dumpOld(0, new ByteArrayInputStream(new byte[] {}), nullPS);
// Decode the stream to bytes
byte[] bytes = RawDataUtil.decompress(recordData);
// Dump the contents of scher to screen.
dumper.dump(bytes, 0, bytes.length, nullPS);
dumper.dump(0, new byte[] {}, nullPS);
dumper.dump(new byte[] {}, 0, 0, nullPS);
} }
@Test @Test
public void testWithData() throws Exception { public void testWithData() throws Exception {
new EscherDump().dumpOld(8, new ByteArrayInputStream(new byte[] {0, 0, 0, 0, 0, 0, 0, 0}), nullPS); new EscherDump().dump(8, new byte[] {0, 0, 0, 0, 0, 0, 0, 0}, nullPS);
} }
@Test @Test

View File

@ -49,9 +49,10 @@ public final class TestEscherOptRecord {
assertEquals( (short) 0x0033, r.getOptions() ); assertEquals( (short) 0x0033, r.getOptions() );
assertEquals( (short) 0xF00B, r.getRecordId() ); assertEquals( (short) 0xF00B, r.getRecordId() );
assertEquals( 3, r.getEscherProperties().size() ); assertEquals( 3, r.getEscherProperties().size() );
EscherBoolProperty prop1 = new EscherBoolProperty( EscherProperties.TEXT__SIZE_TEXT_TO_FIT_SHAPE, 1 ); EscherBoolProperty prop1 = new EscherBoolProperty( EscherPropertyTypes.TEXT__SIZE_TEXT_TO_FIT_SHAPE, 1 );
EscherComplexProperty prop2 = new EscherComplexProperty( (short) 1, false, new byte[] { 0x01, 0x02 } ); EscherComplexProperty prop2 = new EscherComplexProperty( EscherPropertyTypes.TEXT__SIZE_TEXT_TO_FIT_SHAPE, false, 2);
EscherBoolProperty prop3 = new EscherBoolProperty( EscherProperties.TEXT__SIZE_TEXT_TO_FIT_SHAPE, 1 ); prop2.setComplexData(new byte[] { 0x01, 0x02 });
EscherBoolProperty prop3 = new EscherBoolProperty( EscherPropertyTypes.TEXT__SIZE_TEXT_TO_FIT_SHAPE, 1 );
assertEquals( prop1, r.getEscherProperty( 0 ) ); assertEquals( prop1, r.getEscherProperty( 0 ) );
assertEquals( prop2, r.getEscherProperty( 1 ) ); assertEquals( prop2, r.getEscherProperty( 1 ) );
assertEquals( prop3, r.getEscherProperty( 2 ) ); assertEquals( prop3, r.getEscherProperty( 2 ) );
@ -71,9 +72,9 @@ public final class TestEscherOptRecord {
assertEquals( (short) 0x0033, r.getOptions() ); assertEquals( (short) 0x0033, r.getOptions() );
assertEquals( (short) 0xF00B, r.getRecordId() ); assertEquals( (short) 0xF00B, r.getRecordId() );
assertEquals( 3, r.getEscherProperties().size() ); assertEquals( 3, r.getEscherProperties().size() );
EscherBoolProperty prop1 = new EscherBoolProperty( EscherProperties.TEXT__SIZE_TEXT_TO_FIT_SHAPE, 524296 ); EscherBoolProperty prop1 = new EscherBoolProperty( EscherPropertyTypes.TEXT__SIZE_TEXT_TO_FIT_SHAPE, 524296 );
EscherRGBProperty prop2 = new EscherRGBProperty( EscherProperties.FILL__FILLCOLOR, 0x08000009 ); EscherRGBProperty prop2 = new EscherRGBProperty( EscherPropertyTypes.FILL__FILLCOLOR, 0x08000009 );
EscherRGBProperty prop3 = new EscherRGBProperty( EscherProperties.LINESTYLE__COLOR, 0x08000040 ); EscherRGBProperty prop3 = new EscherRGBProperty( EscherPropertyTypes.LINESTYLE__COLOR, 0x08000040 );
assertEquals( prop1, r.getEscherProperty( 0 ) ); assertEquals( prop1, r.getEscherProperty( 0 ) );
assertEquals( prop2, r.getEscherProperty( 1 ) ); assertEquals( prop2, r.getEscherProperty( 1 ) );
assertEquals( prop3, r.getEscherProperty( 2 ) ); assertEquals( prop3, r.getEscherProperty( 2 ) );
@ -91,9 +92,10 @@ public final class TestEscherOptRecord {
EscherOptRecord r = new EscherOptRecord(); EscherOptRecord r = new EscherOptRecord();
r.setOptions( (short) 0x0033 ); r.setOptions( (short) 0x0033 );
r.setRecordId( (short) 0xF00B ); r.setRecordId( (short) 0xF00B );
EscherBoolProperty prop1 = new EscherBoolProperty( EscherProperties.TEXT__SIZE_TEXT_TO_FIT_SHAPE, 1 ); EscherBoolProperty prop1 = new EscherBoolProperty( EscherPropertyTypes.TEXT__SIZE_TEXT_TO_FIT_SHAPE, 1 );
EscherComplexProperty prop2 = new EscherComplexProperty( (short) 1, false, new byte[] { 0x01, 0x02 } ); EscherComplexProperty prop2 = new EscherComplexProperty( EscherPropertyTypes.TEXT__SIZE_TEXT_TO_FIT_SHAPE, false, 2);
EscherBoolProperty prop3 = new EscherBoolProperty( EscherProperties.TEXT__SIZE_TEXT_TO_FIT_SHAPE, 1 ); prop2.setComplexData(new byte[] { 0x01, 0x02 });
EscherBoolProperty prop3 = new EscherBoolProperty( EscherPropertyTypes.TEXT__SIZE_TEXT_TO_FIT_SHAPE, 1 );
r.addEscherProperty( prop1 ); r.addEscherProperty( prop1 );
r.addEscherProperty( prop2 ); r.addEscherProperty( prop2 );
r.addEscherProperty( prop3 ); r.addEscherProperty( prop3 );
@ -105,7 +107,7 @@ public final class TestEscherOptRecord {
"0B, F0, " + "0B, F0, " +
"14, 00, 00, 00, " + "14, 00, 00, 00, " +
"BF, 00, 01, 00, 00, 00, " + "BF, 00, 01, 00, 00, 00, " +
"01, 80, 02, 00, 00, 00, " + "BF, 80, 02, 00, 00, 00, " +
"BF, 00, 01, 00, 00, 00, " + "BF, 00, 01, 00, 00, 00, " +
"01, 02]"; "01, 02]";
assertEquals( dataStr, HexDump.toHex(data) ); assertEquals( dataStr, HexDump.toHex(data) );
@ -117,9 +119,9 @@ public final class TestEscherOptRecord {
EscherOptRecord r = new EscherOptRecord(); EscherOptRecord r = new EscherOptRecord();
r.setOptions( (short) 0x0033 ); r.setOptions( (short) 0x0033 );
r.setRecordId( (short) 0xF00B ); r.setRecordId( (short) 0xF00B );
EscherBoolProperty prop1 = new EscherBoolProperty( EscherProperties.TEXT__SIZE_TEXT_TO_FIT_SHAPE, 1 ); EscherBoolProperty prop1 = new EscherBoolProperty( EscherPropertyTypes.TEXT__SIZE_TEXT_TO_FIT_SHAPE, 1 );
EscherRGBProperty prop2 = new EscherRGBProperty( EscherProperties.FILL__FILLCOLOR, 0x08000009 ); EscherRGBProperty prop2 = new EscherRGBProperty( EscherPropertyTypes.FILL__FILLCOLOR, 0x08000009 );
EscherRGBProperty prop3 = new EscherRGBProperty( EscherProperties.LINESTYLE__COLOR, 0x08000040 ); EscherRGBProperty prop3 = new EscherRGBProperty( EscherPropertyTypes.LINESTYLE__COLOR, 0x08000040 );
r.addEscherProperty( prop1 ); r.addEscherProperty( prop1 );
r.addEscherProperty( prop2 ); r.addEscherProperty( prop2 );
r.addEscherProperty( prop3 ); r.addEscherProperty( prop3 );
@ -138,24 +140,31 @@ public final class TestEscherOptRecord {
@Test @Test
public void testToString() { public void testToString() {
String nl = System.getProperty("line.separator");
EscherOptRecord r = new EscherOptRecord(); EscherOptRecord r = new EscherOptRecord();
// don't try to shoot in foot, please -- vlsergey // don't try to shoot in foot, please -- vlsergey
// r.setOptions((short)0x000F); // r.setOptions((short)0x000F);
r.setRecordId(EscherOptRecord.RECORD_ID); r.setRecordId(EscherOptRecord.RECORD_ID);
EscherProperty prop1 = new EscherBoolProperty((short)1, 1); EscherProperty prop1 = new EscherBoolProperty(EscherPropertyTypes.GEOMETRY__FILLOK, 1);
r.addEscherProperty(prop1); r.addEscherProperty(prop1);
String expected = String expected =
"org.apache.poi.ddf.EscherOptRecord (Opt):" + nl + "{ /* OPT */\n" +
" RecordId: 0xF00B" + nl + "\t recordId: -4085 /* 0xf00b */\n" +
" Version: 0x0003" + nl + "\t, version: 3\n" +
" Instance: 0x0001" + nl + "\t, instance: 1\n" +
" Options: 0x0013" + nl + "\t, options: 19 /* 0x0013 */\n" +
" Record Size: 14" + nl + "\t, recordSize: 14 /* 0x0000000e */\n" +
" isContainer: false" + nl + "\t, isContainer: false\n" +
" numchildren: 0x00000000" + nl + "\t, properties: [\n" +
" properties: 0x00000001" + nl + "\n" +
" unknown: propNum: 1, RAW: 0x0001, propName: unknown, complex: false, blipId: false, value: 1 (0x00000001)"; "\t{ /* GEOMETRY__FILLOK */\n" +
"\t\t id: 383 /* 0x017f */\n" +
"\t\t, name: \"geometry.fillok\"\n" +
"\t\t, propertyNumber: 383 /* 0x017f */\n" +
"\t\t, propertySize: 6\n" +
"\t\t, flags: 0x17f /* */ \n" +
"\t\t, value: 1\n" +
"\t}]\n" +
"}";
assertEquals( expected, r.toString()); assertEquals( expected, r.toString());
} }
@ -255,7 +264,7 @@ public final class TestEscherOptRecord {
/** /**
* Test read/write against an OPT record from a real ppt file. * Test read/write against an OPT record from a real ppt file.
* In PowerPoint is is legal to have array properties with empty complex part. * In PowerPoint it is legal to have array properties with empty complex part.
* In Glen's original implementation complex part is always 6 bytes which resulted * In Glen's original implementation complex part is always 6 bytes which resulted
* in +6 extra bytes when writing back out. As the result the ppt becomes unreadable. * in +6 extra bytes when writing back out. As the result the ppt becomes unreadable.
* *
@ -295,7 +304,7 @@ public final class TestEscherOptRecord {
@Test @Test
public void testEmptyArrayProperty() { public void testEmptyArrayProperty() {
EscherOptRecord r = new EscherOptRecord(); EscherOptRecord r = new EscherOptRecord();
EscherArrayProperty p = new EscherArrayProperty((short)(EscherProperties.FILL__SHADECOLORS + 0x8000), new byte[0] ); EscherArrayProperty p = new EscherArrayProperty(EscherPropertyTypes.FILL__SHADECOLORS, false, 0);
assertEquals(0, p.getNumberOfElementsInArray()); assertEquals(0, p.getNumberOfElementsInArray());
r.addEscherProperty(p); r.addEscherProperty(p);

View File

@ -31,22 +31,24 @@ public class TestEscherProperty {
*/ */
@Test @Test
public void testPropertyNames() throws Exception { public void testPropertyNames() throws Exception {
EscherProperty p1 = new EscherSimpleProperty( EscherProperties.GROUPSHAPE__SHAPENAME, 0); EscherProperty p1 = new EscherSimpleProperty( EscherPropertyTypes.GROUPSHAPE__SHAPENAME, 0);
assertEquals("groupshape.shapename", p1.getName()); assertEquals("groupshape.shapename", p1.getName());
assertEquals(EscherProperties.GROUPSHAPE__SHAPENAME, p1.getPropertyNumber()); assertEquals(EscherPropertyTypes.GROUPSHAPE__SHAPENAME.propNumber, p1.getPropertyNumber());
assertFalse(p1.isComplex()); assertFalse(p1.isComplex());
EscherProperty p2 = new EscherComplexProperty( EscherComplexProperty p2 = new EscherComplexProperty(
EscherProperties.GROUPSHAPE__SHAPENAME, false, new byte[10]); EscherPropertyTypes.GROUPSHAPE__SHAPENAME, false, 10);
p2.setComplexData(new byte[10]);
assertEquals("groupshape.shapename", p2.getName()); assertEquals("groupshape.shapename", p2.getName());
assertEquals(EscherProperties.GROUPSHAPE__SHAPENAME, p2.getPropertyNumber()); assertEquals(EscherPropertyTypes.GROUPSHAPE__SHAPENAME.propNumber, p2.getPropertyNumber());
assertTrue(p2.isComplex()); assertTrue(p2.isComplex());
assertFalse(p2.isBlipId()); assertFalse(p2.isBlipId());
EscherProperty p3 = new EscherComplexProperty( EscherComplexProperty p3 = new EscherComplexProperty(
EscherProperties.GROUPSHAPE__SHAPENAME, true, new byte[10]); EscherPropertyTypes.GROUPSHAPE__SHAPENAME, true, 10);
p2.setComplexData(new byte[10]);
assertEquals("groupshape.shapename", p3.getName()); assertEquals("groupshape.shapename", p3.getName());
assertEquals(EscherProperties.GROUPSHAPE__SHAPENAME, p3.getPropertyNumber()); assertEquals(EscherPropertyTypes.GROUPSHAPE__SHAPENAME.propNumber, p3.getPropertyNumber());
assertTrue(p3.isComplex()); assertTrue(p3.isComplex());
assertTrue(p3.isBlipId()); assertTrue(p3.isBlipId());
} }

View File

@ -57,18 +57,17 @@ public class TestEscherSpRecord {
@Test @Test
public void testToString() { public void testToString() {
String nl = System.getProperty("line.separator");
String expected = String expected =
"org.apache.poi.ddf.EscherSpRecord (Sp):" + nl + "{ /* SP */\n" +
" RecordId: 0xF00A" + nl + "\t recordId: -4086 /* 0xf00a */\n" +
" Version: 0x0002" + nl + "\t, version: 2\n" +
" Instance: 0x0000" + nl + "\t, instance: 0\n" +
" Options: 0x0002" + nl + "\t, options: 2\n" +
" Record Size: 16" + nl + "\t, recordSize: 16 /* 0x00000010 */\n" +
" ShapeType: 0x0000" + nl + "\t, shapeType: 0\n" +
" ShapeId: 0x00000400" + nl + "\t, shapeId: 1024 /* 0x00000400 */\n" +
" Flags: GROUP|PATRIARCH (0x00000005)"; "\t, flags: 0x5 /* GROUP | PATRIARCH */ \n" +
"}";
assertEquals( expected, createRecord().toString() ); assertEquals( expected, createRecord().toString() );
} }

View File

@ -63,18 +63,18 @@ public final class TestEscherSpgrRecord {
@Test @Test
public void testToString() { public void testToString() {
String nl = System.getProperty("line.separator");
String expected = String expected =
"org.apache.poi.ddf.EscherSpgrRecord (Spgr):" + nl + "{ /* SPGR */\n" +
" RecordId: 0xF009" + nl + "\t recordId: -4087 /* 0xf009 */\n" +
" Version: 0x0000" + nl + "\t, version: 0\n" +
" Instance: 0x0001" + nl + "\t, instance: 1\n" +
" Options: 0x0010" + nl + "\t, options: 16 /* 0x0010 */\n" +
" Record Size: 24" + nl + "\t, recordSize: 24 /* 0x00000018 */\n" +
" RectX: 0x00000001" + nl + "\t, rectX1: 1\n" +
" RectY: 0x00000002" + nl + "\t, rectY1: 2\n" +
" RectWidth: 0x00000003" + nl + "\t, rectX2: 3\n" +
" RectHeight: 0x00000004"; "\t, rectY2: 4\n" +
"}";
assertEquals( expected, createRecord().toString() ); assertEquals( expected, createRecord().toString() );
} }

View File

@ -63,18 +63,18 @@ public final class TestEscherSplitMenuColorsRecord {
@Test @Test
public void testToString() { public void testToString() {
String nl = System.getProperty("line.separator");
String expected = String expected =
"org.apache.poi.ddf.EscherSplitMenuColorsRecord (SplitMenuColors):" + nl + "{ /* SPLIT_MENU_COLORS */\n" +
" RecordId: 0xF11E" + nl + "\t recordId: -3810 /* 0xf11e */\n" +
" Version: 0x0000" + nl + "\t, version: 0\n" +
" Instance: 0x0004" + nl + "\t, instance: 4\n" +
" Options: 0x0040" + nl + "\t, options: 64 /* 0x0040 */\n" +
" Record Size: 24" + nl + "\t, recordSize: 24 /* 0x00000018 */\n" +
" Color1: 0x00000402" + nl + "\t, color1: 1026 /* 0x00000402 */\n" +
" Color2: 0x00000002" + nl + "\t, color2: 2\n" +
" Color3: 0x00000002" + nl + "\t, color3: 2\n" +
" Color4: 0x00000001"; "\t, color4: 1\n" +
"}";
assertEquals( expected, createRecord().toString() ); assertEquals( expected, createRecord().toString() );
} }

View File

@ -150,20 +150,15 @@ public final class TestUnknownEscherRecord {
r.setRecordId( (short) 0xF112 ); r.setRecordId( (short) 0xF112 );
byte[] data = new byte[8]; byte[] data = new byte[8];
r.serialize( 0, data, new NullEscherSerializationListener() ); r.serialize( 0, data, new NullEscherSerializationListener() );
String nl = System.getProperty("line.separator");
String expected = String expected =
"org.apache.poi.ddf.UnknownEscherRecord (Unknown 0xF112):" + nl + "{ /* UNKNOWN */\n" +
" RecordId: 0xF112" + nl + "\t recordId: -3822 /* 0xf112 */\n" +
" Version: 0x0004" + nl + "\t, version: 4\n" +
" Instance: 0x0123" + nl + "\t, instance: 291 /* 0x0123 */\n" +
" Options: 0x1234" + nl + "\t, options: 4660 /* 0x1234 */\n" +
" Record Size: 8" + nl + "\t, recordSize: 8\n" +
" isContainer: false" + nl + "\t, data: \"\"\n" +
" children: 0x00000000" + nl + "}";
" Extra Data: " + nl +
" : 0";
assertEquals(expected, r.toString() ); assertEquals(expected, r.toString() );
} }
} }

View File

@ -19,6 +19,7 @@ package org.apache.poi.hssf.model;
import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertFalse; import static org.junit.Assert.assertFalse;
import static org.junit.Assert.assertNotEquals;
import static org.junit.Assert.assertNotNull; import static org.junit.Assert.assertNotNull;
import static org.junit.Assert.assertNull; import static org.junit.Assert.assertNull;
import static org.junit.Assert.assertSame; import static org.junit.Assert.assertSame;
@ -27,7 +28,16 @@ import static org.junit.Assert.assertTrue;
import java.io.IOException; import java.io.IOException;
import java.util.List; import java.util.List;
import org.apache.poi.ddf.*; import org.apache.poi.ddf.EscherBoolProperty;
import org.apache.poi.ddf.EscherContainerRecord;
import org.apache.poi.ddf.EscherDgRecord;
import org.apache.poi.ddf.EscherOptRecord;
import org.apache.poi.ddf.EscherProperty;
import org.apache.poi.ddf.EscherPropertyTypes;
import org.apache.poi.ddf.EscherRecord;
import org.apache.poi.ddf.EscherSimpleProperty;
import org.apache.poi.ddf.EscherSpRecord;
import org.apache.poi.ddf.EscherTextboxRecord;
import org.apache.poi.hssf.HSSFTestDataSamples; import org.apache.poi.hssf.HSSFTestDataSamples;
import org.apache.poi.hssf.record.CommonObjectDataSubRecord; import org.apache.poi.hssf.record.CommonObjectDataSubRecord;
import org.apache.poi.hssf.record.EscherAggregate; import org.apache.poi.hssf.record.EscherAggregate;
@ -101,10 +111,10 @@ public class TestDrawingShapes {
EscherOptRecord opt = shape.getOptRecord(); EscherOptRecord opt = shape.getOptRecord();
assertEquals(7, opt.getEscherProperties().size()); assertEquals(7, opt.getEscherProperties().size());
assertTrue(((EscherBoolProperty) opt.lookup(EscherProperties.GROUPSHAPE__PRINT)).isTrue()); assertNotEquals(((EscherSimpleProperty) opt.lookup(EscherPropertyTypes.GROUPSHAPE__FLAGS)).getPropertyValue(), 0);
assertTrue(((EscherBoolProperty) opt.lookup(EscherProperties.LINESTYLE__NOLINEDRAWDASH)).isTrue()); assertTrue(((EscherBoolProperty) opt.lookup(EscherPropertyTypes.LINESTYLE__NOLINEDRAWDASH)).isTrue());
assertEquals(0x00000004, ((EscherSimpleProperty) opt.lookup(EscherProperties.GEOMETRY__SHAPEPATH)).getPropertyValue()); assertEquals(0x00000004, ((EscherSimpleProperty) opt.lookup(EscherPropertyTypes.GEOMETRY__SHAPEPATH)).getPropertyValue());
assertNull(opt.lookup(EscherProperties.TEXT__SIZE_TEXT_TO_FIT_SHAPE)); assertNull(opt.lookup(EscherPropertyTypes.TEXT__SIZE_TEXT_TO_FIT_SHAPE));
} }
@Test @Test
@ -153,7 +163,6 @@ public class TestDrawingShapes {
HSSFClientAnchor anchor = new HSSFClientAnchor(10, 10, 50, 50, (short) 2, 2, (short) 4, 4); HSSFClientAnchor anchor = new HSSFClientAnchor(10, 10, 50, 50, (short) 2, 2, (short) 4, 4);
anchor.setAnchorType(AnchorType.MOVE_DONT_RESIZE); anchor.setAnchorType(AnchorType.MOVE_DONT_RESIZE);
assertEquals(AnchorType.MOVE_DONT_RESIZE, anchor.getAnchorType()); assertEquals(AnchorType.MOVE_DONT_RESIZE, anchor.getAnchorType());
//noinspection deprecation
anchor.setAnchorType(AnchorType.MOVE_DONT_RESIZE); anchor.setAnchorType(AnchorType.MOVE_DONT_RESIZE);
assertEquals(AnchorType.MOVE_DONT_RESIZE, anchor.getAnchorType()); assertEquals(AnchorType.MOVE_DONT_RESIZE, anchor.getAnchorType());
@ -175,10 +184,10 @@ public class TestDrawingShapes {
assertNotNull(escherContainer); assertNotNull(escherContainer);
EscherRecord childById = escherContainer.getChildById(EscherOptRecord.RECORD_ID); EscherRecord childById = escherContainer.getChildById(EscherOptRecord.RECORD_ID);
assertNotNull(childById); assertNotNull(childById);
EscherProperty lookup = ((EscherOptRecord) childById).lookup(EscherProperties.TEXT__TEXTID); EscherProperty lookup = ((EscherOptRecord) childById).lookup(EscherPropertyTypes.TEXT__TEXTID);
assertNotNull(lookup); assertNotNull(lookup);
assertEquals(((EscherSimpleProperty) lookup).getPropertyValue(), "teeeest".hashCode()); assertEquals(((EscherSimpleProperty) lookup).getPropertyValue(), "teeeest".hashCode());
assertEquals(rectangle.isNoFill(), true); assertTrue(rectangle.isNoFill());
assertEquals(rectangle.getWrapText(), HSSFSimpleShape.WRAP_NONE); assertEquals(rectangle.getWrapText(), HSSFSimpleShape.WRAP_NONE);
assertEquals(rectangle.getString().getString(), "teeeest"); assertEquals(rectangle.getString().getString(), "teeeest");
@ -197,7 +206,7 @@ public class TestDrawingShapes {
assertEquals(anchor, rectangle2.getAnchor()); assertEquals(anchor, rectangle2.getAnchor());
assertEquals(rectangle2.getLineStyleColor(), 1111); assertEquals(rectangle2.getLineStyleColor(), 1111);
assertEquals(rectangle2.getFillColor(), 777); assertEquals(rectangle2.getFillColor(), 777);
assertEquals(rectangle2.isNoFill(), true); assertTrue(rectangle2.isNoFill());
assertEquals(rectangle2.getString().getString(), "teeeest"); assertEquals(rectangle2.getString().getString(), "teeeest");
assertEquals(rectangle.getWrapText(), HSSFSimpleShape.WRAP_NONE); assertEquals(rectangle.getWrapText(), HSSFSimpleShape.WRAP_NONE);
@ -229,7 +238,7 @@ public class TestDrawingShapes {
assertEquals(rectangle2.getAnchor().getDx2(), 3); assertEquals(rectangle2.getAnchor().getDx2(), 3);
assertEquals(rectangle2.getAnchor().getDy1(), 4); assertEquals(rectangle2.getAnchor().getDy1(), 4);
assertEquals(rectangle2.getAnchor().getDy2(), 5); assertEquals(rectangle2.getAnchor().getDy2(), 5);
assertEquals(rectangle2.isNoFill(), false); assertFalse(rectangle2.isNoFill());
assertEquals(rectangle2.getString().getString(), "test22"); assertEquals(rectangle2.getString().getString(), "test22");
HSSFSimpleShape rect3 = drawing.createSimpleShape(new HSSFClientAnchor()); HSSFSimpleShape rect3 = drawing.createSimpleShape(new HSSFClientAnchor());
@ -255,7 +264,7 @@ public class TestDrawingShapes {
assertEquals(picture.getFillColor(), 0x5DC943); assertEquals(picture.getFillColor(), 0x5DC943);
assertEquals(picture.getLineWidth(), HSSFShape.LINEWIDTH_DEFAULT); assertEquals(picture.getLineWidth(), HSSFShape.LINEWIDTH_DEFAULT);
assertEquals(picture.getLineStyle(), HSSFShape.LINESTYLE_DEFAULT); assertEquals(picture.getLineStyle(), HSSFShape.LINESTYLE_DEFAULT);
assertEquals(picture.isNoFill(), false); assertFalse(picture.isNoFill());
picture.setPictureIndex(2); picture.setPictureIndex(2);
assertEquals(picture.getPictureIndex(), 2); assertEquals(picture.getPictureIndex(), 2);
@ -272,7 +281,7 @@ public class TestDrawingShapes {
assertEquals(1, drawing.getChildren().size()); assertEquals(1, drawing.getChildren().size());
HSSFSimpleShape shape = (HSSFSimpleShape) drawing.getChildren().get(0); HSSFSimpleShape shape = (HSSFSimpleShape) drawing.getChildren().get(0);
assertEquals(shape.isNoFill(), false); assertFalse(shape.isNoFill());
assertEquals(shape.getLineStyle(), HSSFShape.LINESTYLE_DASHDOTGEL); assertEquals(shape.getLineStyle(), HSSFShape.LINESTYLE_DASHDOTGEL);
assertEquals(shape.getLineStyleColor(), 0x616161); assertEquals(shape.getLineStyleColor(), 0x616161);
assertEquals(HexDump.toHex(shape.getFillColor()), shape.getFillColor(), 0x2CE03D); assertEquals(HexDump.toHex(shape.getFillColor()), shape.getFillColor(), 0x2CE03D);
@ -332,10 +341,8 @@ public class TestDrawingShapes {
HSSFSheet sheet = wb.getSheetAt(0); HSSFSheet sheet = wb.getSheetAt(0);
HSSFPatriarch patriarch = sheet.getDrawingPatriarch(); HSSFPatriarch patriarch = sheet.getDrawingPatriarch();
/** // 2048 - main SpContainer id
* 2048 - main SpContainer id // 2049 - existing shape id
* 2049 - existing shape id
*/
assertEquals(HSSFTestHelper.allocateNewShapeId(patriarch), 2050); assertEquals(HSSFTestHelper.allocateNewShapeId(patriarch), 2050);
assertEquals(HSSFTestHelper.allocateNewShapeId(patriarch), 2051); assertEquals(HSSFTestHelper.allocateNewShapeId(patriarch), 2051);
assertEquals(HSSFTestHelper.allocateNewShapeId(patriarch), 2052); assertEquals(HSSFTestHelper.allocateNewShapeId(patriarch), 2052);
@ -343,10 +350,8 @@ public class TestDrawingShapes {
sheet = wb.getSheetAt(1); sheet = wb.getSheetAt(1);
patriarch = sheet.getDrawingPatriarch(); patriarch = sheet.getDrawingPatriarch();
/** // 3072 - main SpContainer id
* 3072 - main SpContainer id // 3073 - existing shape id
* 3073 - existing shape id
*/
assertEquals(HSSFTestHelper.allocateNewShapeId(patriarch), 3074); assertEquals(HSSFTestHelper.allocateNewShapeId(patriarch), 3074);
assertEquals(HSSFTestHelper.allocateNewShapeId(patriarch), 3075); assertEquals(HSSFTestHelper.allocateNewShapeId(patriarch), 3075);
assertEquals(HSSFTestHelper.allocateNewShapeId(patriarch), 3076); assertEquals(HSSFTestHelper.allocateNewShapeId(patriarch), 3076);
@ -617,13 +622,13 @@ public class TestDrawingShapes {
HSSFSimpleShape rectangle = patriarch.createSimpleShape(new HSSFClientAnchor()); HSSFSimpleShape rectangle = patriarch.createSimpleShape(new HSSFClientAnchor());
rectangle.setShapeType(HSSFSimpleShape.OBJECT_TYPE_RECTANGLE); rectangle.setShapeType(HSSFSimpleShape.OBJECT_TYPE_RECTANGLE);
assertEquals(rectangle.isFlipVertical(), false); assertFalse(rectangle.isFlipVertical());
assertEquals(rectangle.isFlipHorizontal(), false); assertFalse(rectangle.isFlipHorizontal());
rectangle.setFlipVertical(true); rectangle.setFlipVertical(true);
assertEquals(rectangle.isFlipVertical(), true); assertTrue(rectangle.isFlipVertical());
rectangle.setFlipHorizontal(true); rectangle.setFlipHorizontal(true);
assertEquals(rectangle.isFlipHorizontal(), true); assertTrue(rectangle.isFlipHorizontal());
HSSFWorkbook wb2 = HSSFTestDataSamples.writeOutAndReadBack(wb1); HSSFWorkbook wb2 = HSSFTestDataSamples.writeOutAndReadBack(wb1);
wb1.close(); wb1.close();
@ -632,13 +637,13 @@ public class TestDrawingShapes {
rectangle = (HSSFSimpleShape) patriarch.getChildren().get(0); rectangle = (HSSFSimpleShape) patriarch.getChildren().get(0);
assertEquals(rectangle.isFlipHorizontal(), true); assertTrue(rectangle.isFlipHorizontal());
rectangle.setFlipHorizontal(false); rectangle.setFlipHorizontal(false);
assertEquals(rectangle.isFlipHorizontal(), false); assertFalse(rectangle.isFlipHorizontal());
assertEquals(rectangle.isFlipVertical(), true); assertTrue(rectangle.isFlipVertical());
rectangle.setFlipVertical(false); rectangle.setFlipVertical(false);
assertEquals(rectangle.isFlipVertical(), false); assertFalse(rectangle.isFlipVertical());
HSSFWorkbook wb3 = HSSFTestDataSamples.writeOutAndReadBack(wb2); HSSFWorkbook wb3 = HSSFTestDataSamples.writeOutAndReadBack(wb2);
wb2.close(); wb2.close();
@ -647,8 +652,8 @@ public class TestDrawingShapes {
rectangle = (HSSFSimpleShape) patriarch.getChildren().get(0); rectangle = (HSSFSimpleShape) patriarch.getChildren().get(0);
assertEquals(rectangle.isFlipVertical(), false); assertFalse(rectangle.isFlipVertical());
assertEquals(rectangle.isFlipHorizontal(), false); assertFalse(rectangle.isFlipHorizontal());
wb3.close(); wb3.close();
} }
@ -735,8 +740,7 @@ public class TestDrawingShapes {
@Test @Test
public void testBug45312() throws Exception { public void testBug45312() throws Exception {
HSSFWorkbook wb = new HSSFWorkbook(); try (HSSFWorkbook wb = new HSSFWorkbook()) {
try {
HSSFSheet sheet = wb.createSheet(); HSSFSheet sheet = wb.createSheet();
HSSFPatriarch patriarch = sheet.createDrawingPatriarch(); HSSFPatriarch patriarch = sheet.createDrawingPatriarch();
@ -768,16 +772,7 @@ public class TestDrawingShapes {
shape1.setShapeType(HSSFSimpleShape.OBJECT_TYPE_LINE); shape1.setShapeType(HSSFSimpleShape.OBJECT_TYPE_LINE);
} }
/*OutputStream stream = new FileOutputStream("/tmp/45312.xls");
try {
wb.write(stream);
} finally {
stream.close();
}*/
checkWorkbookBack(wb); checkWorkbookBack(wb);
} finally {
wb.close();
} }
} }

View File

@ -25,7 +25,7 @@ import static org.junit.Assert.assertTrue;
import java.io.IOException; import java.io.IOException;
import org.apache.poi.ddf.EscherArrayProperty; import org.apache.poi.ddf.EscherArrayProperty;
import org.apache.poi.ddf.EscherProperties; import org.apache.poi.ddf.EscherPropertyTypes;
import org.apache.poi.ddf.EscherSpRecord; import org.apache.poi.ddf.EscherSpRecord;
import org.apache.poi.hssf.HSSFTestDataSamples; import org.apache.poi.hssf.HSSFTestDataSamples;
import org.apache.poi.hssf.record.ObjRecord; import org.apache.poi.hssf.record.ObjRecord;
@ -85,16 +85,20 @@ public class TestPolygon {
polygon.setPolygonDrawArea( 100, 100 ); polygon.setPolygonDrawArea( 100, 100 );
polygon.setPoints( new int[]{0, 90, 50, 90}, new int[]{5, 5, 44, 88} ); polygon.setPoints( new int[]{0, 90, 50, 90}, new int[]{5, 5, 44, 88} );
EscherArrayProperty verticesProp1 = polygon.getOptRecord().lookup(EscherProperties.GEOMETRY__VERTICES); EscherArrayProperty verticesProp1 = polygon.getOptRecord().lookup(EscherPropertyTypes.GEOMETRY__VERTICES);
String expected = String expected =
"<EscherArrayProperty id=\"0x8145\" name=\"geometry.vertices\" blipId=\"false\">"+ "<record type=\"GEOMETRY__VERTICES\" id=\"-32443\" name=\"geometry.vertices\" propertyNumber=\"325\" propertySize=\"32\" numElements=\"5\" numElementsInMemory=\"5\" sizeOfElements=\"-16\">" +
"<Element>[00, 00, 05, 00]</Element>"+ "<flags flag=\"0x8145\" description=\"IS_COMPLEX\"/>" +
"<Element>[5A, 00, 05, 00]</Element>"+ "<data>BQAFAPD/AAAFAFoABQAyACwAWgBYAAAABQA=</data>" +
"<Element>[32, 00, 2C, 00]</Element>"+ "<elements>" +
"<Element>[5A, 00, 58, 00]</Element>"+ "<item>>AAAFAA==</item>" +
"<Element>[00, 00, 05, 00]</Element>"+ "<item>>WgAFAA==</item>" +
"</EscherArrayProperty>"; "<item>>MgAsAA==</item>" +
"<item>>WgBYAA==</item>" +
"<item>>AAAFAA==</item>" +
"</elements>" +
"</record>";
String actual = verticesProp1.toXml("").replaceAll("[\r\n\t]",""); String actual = verticesProp1.toXml("").replaceAll("[\r\n\t]","");
assertEquals(verticesProp1.getNumberOfElementsInArray(), 5); assertEquals(verticesProp1.getNumberOfElementsInArray(), 5);
@ -104,15 +108,18 @@ public class TestPolygon {
assertArrayEquals(polygon.getXPoints(), new int[]{1, 2, 3}); assertArrayEquals(polygon.getXPoints(), new int[]{1, 2, 3});
assertArrayEquals(polygon.getYPoints(), new int[]{4, 5, 6}); assertArrayEquals(polygon.getYPoints(), new int[]{4, 5, 6});
verticesProp1 = polygon.getOptRecord().lookup(EscherProperties.GEOMETRY__VERTICES); verticesProp1 = polygon.getOptRecord().lookup(EscherPropertyTypes.GEOMETRY__VERTICES);
expected = expected =
"<EscherArrayProperty id=\"0x8145\" name=\"geometry.vertices\" blipId=\"false\">" + "<record type=\"GEOMETRY__VERTICES\" id=\"-32443\" name=\"geometry.vertices\" propertyNumber=\"325\" propertySize=\"28\" numElements=\"4\" numElementsInMemory=\"4\" sizeOfElements=\"-16\">" +
"<Element>[01, 00, 04, 00]</Element>" + "<flags flag=\"0x8145\" description=\"IS_COMPLEX\"/>" +
"<Element>[02, 00, 05, 00]</Element>" + "<data>BAAEAPD/AQAEAAIABQADAAYAAQAEAA==</data>" +
"<Element>[03, 00, 06, 00]</Element>" + "<elements>" +
"<Element>[01, 00, 04, 00]</Element>" + "<item>>AQAEAA==</item>" +
"</EscherArrayProperty>"; "<item>>AgAFAA==</item>" +
"<item>>AwAGAA==</item>" +
"<item>>AQAEAA==</item>" +
"</elements></record>";
actual = verticesProp1.toXml("").replaceAll("[\r\n\t]",""); actual = verticesProp1.toXml("").replaceAll("[\r\n\t]","");
assertEquals(verticesProp1.getNumberOfElementsInArray(), 4); assertEquals(verticesProp1.getNumberOfElementsInArray(), 4);
@ -261,7 +268,7 @@ public class TestPolygon {
EscherSpRecord spRecord = polygon1.getEscherContainer().getChildById(EscherSpRecord.RECORD_ID); EscherSpRecord spRecord = polygon1.getEscherContainer().getChildById(EscherSpRecord.RECORD_ID);
spRecord.setShapeType((short)77/**RANDOM**/); spRecord.setShapeType((short)77/*RANDOM*/);
HSSFWorkbook wb3 = HSSFTestDataSamples.writeOutAndReadBack(wb2); HSSFWorkbook wb3 = HSSFTestDataSamples.writeOutAndReadBack(wb2);
wb2.close(); wb2.close();