org.apache.poi.hssf.record
Class AbstractEscherHolderRecord

java.lang.Object
  extended by org.apache.poi.hssf.record.Record
      extended by org.apache.poi.hssf.record.AbstractEscherHolderRecord
Direct Known Subclasses:
DrawingGroupRecord, DrawingRecordForBiffViewer, DrawingSelectionRecord, EscherAggregate

public abstract class AbstractEscherHolderRecord
extends Record

The escher container record is used to hold escher records. It is abstract and must be subclassed for maximum benefit.

Author:
Glen Stampoultzis (glens at apache.org), Michael Zalewski (zalewski at optonline.net)

Constructor Summary
AbstractEscherHolderRecord()
           
AbstractEscherHolderRecord(RecordInputStream in)
          Constructs a Bar record and sets its fields appropriately.
 
Method Summary
 boolean addEscherRecord(EscherRecord element)
           
 void addEscherRecord(int index, EscherRecord element)
           
 void clearEscherRecords()
           
 java.lang.Object clone()
           
protected  void convertRawBytesToEscherRecords()
           
 void decode()
          Convert raw data to escher records.
protected  void fillFields(RecordInputStream in)
          called by the constructor, should set class level fields.
 EscherRecord findFirstWithId(short id)
          Descends into all our children, returning the first EscherRecord with the given id, or null if none found
 EscherContainerRecord getEscherContainer()
          If we have a EscherContainerRecord as one of our children (and most top level escher holders do), then return that.
 EscherRecord getEscherRecord(int index)
           
 java.util.List getEscherRecords()
           
 byte[] getRawData()
           
protected abstract  java.lang.String getRecordName()
           
 int getRecordSize()
          Size of record (including 4 byte header)
abstract  short getSid()
          return the non static version of the id for this record.
 void join(AbstractEscherHolderRecord record)
          Big drawing group records are split but it's easier to deal with them as a whole group so we need to join them together.
 void processContinueRecord(byte[] record)
           
 int serialize(int offset, byte[] data)
          called by the class that is responsible for writing this sucker.
 void setRawData(byte[] rawData)
           
 java.lang.String toString()
          get a string representation of the record (for biffview/debugging)
protected  void validateSid(short id)
          Checks the sid matches the expected side for this record
 
Methods inherited from class org.apache.poi.hssf.record.Record
cloneViaReserialise, isInValueSection, isValue, serialize
 
Methods inherited from class java.lang.Object
equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
 

Constructor Detail

AbstractEscherHolderRecord

public AbstractEscherHolderRecord()

AbstractEscherHolderRecord

public AbstractEscherHolderRecord(RecordInputStream in)
Constructs a Bar record and sets its fields appropriately.

Parameters:
in - the RecordInputstream to read the record from
Method Detail

validateSid

protected void validateSid(short id)
Checks the sid matches the expected side for this record

Specified by:
validateSid in class Record
Parameters:
id - the expected sid.

fillFields

protected void fillFields(RecordInputStream in)
Description copied from class: Record
called by the constructor, should set class level fields. Should throw runtime exception for bad/icomplete data.

Specified by:
fillFields in class Record
Parameters:
in - the RecordInputstream to read the record from

convertRawBytesToEscherRecords

protected void convertRawBytesToEscherRecords()

toString

public java.lang.String toString()
Description copied from class: Record
get a string representation of the record (for biffview/debugging)

Overrides:
toString in class Record

getRecordName

protected abstract java.lang.String getRecordName()

serialize

public int serialize(int offset,
                     byte[] data)
Description copied from class: Record
called by the class that is responsible for writing this sucker. Subclasses should implement this so that their data is passed back in a byte array.

Specified by:
serialize in class Record
Parameters:
offset - to begin writing at
data - byte array containing instance data
Returns:
number of bytes written

getRecordSize

public int getRecordSize()
Size of record (including 4 byte header)

Overrides:
getRecordSize in class Record

getSid

public abstract short getSid()
Description copied from class: Record
return the non static version of the id for this record.

Specified by:
getSid in class Record

clone

public java.lang.Object clone()
Overrides:
clone in class Record

addEscherRecord

public void addEscherRecord(int index,
                            EscherRecord element)

addEscherRecord

public boolean addEscherRecord(EscherRecord element)

getEscherRecords

public java.util.List getEscherRecords()

clearEscherRecords

public void clearEscherRecords()

getEscherContainer

public EscherContainerRecord getEscherContainer()
If we have a EscherContainerRecord as one of our children (and most top level escher holders do), then return that.


findFirstWithId

public EscherRecord findFirstWithId(short id)
Descends into all our children, returning the first EscherRecord with the given id, or null if none found


getEscherRecord

public EscherRecord getEscherRecord(int index)

join

public void join(AbstractEscherHolderRecord record)
Big drawing group records are split but it's easier to deal with them as a whole group so we need to join them together.


processContinueRecord

public void processContinueRecord(byte[] record)

getRawData

public byte[] getRawData()

setRawData

public void setRawData(byte[] rawData)

decode

public void decode()
Convert raw data to escher records.



Copyright 2008 The Apache Software Foundation or its licensors, as applicable.