/* ====================================================================
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.
==================================================================== */
namespace HH.WMS.Utils.NPOI.DDF
{
using System;
using System.Text;
using System.Collections;
using HH.WMS.Utils.NPOI.Util;
///
/// ToGether the the EscherOptRecord this record defines some of the basic
/// properties of a shape.
/// @author Glen Stampoultzis (glens at apache.org)
///
public class EscherSpRecord : EscherRecord
{
public const short RECORD_ID = unchecked((short)0xF00A);
public const String RECORD_DESCRIPTION = "MsofbtSp";
public const int FLAG_GROUP = 0x0001;
public const int FLAG_CHILD = 0x0002;
public const int FLAG_PATRIARCH = 0x0004;
public const int FLAG_DELETED = 0x0008;
public const int FLAG_OLESHAPE = 0x0010;
public const int FLAG_HAVEMASTER = 0x0020;
public const int FLAG_FLIPHORIZ = 0x0040;
public const int FLAG_FLIPVERT = 0x0080;
public const int FLAG_CONNECTOR = 0x0100;
public const int FLAG_HAVEANCHOR = 0x0200;
public const int FLAG_BACKGROUND = 0x0400;
public const int FLAG_HASSHAPETYPE = 0x0800;
private int field_1_shapeId;
private int field_2_flags;
///
/// The contract of this method is to deSerialize an escher record including
/// it's children.
///
/// The byte array containing the Serialized escher
/// records.
/// The offset into the byte array.
/// A factory for creating new escher records
/// The number of bytes written.
public override int FillFields(byte[] data, int offset, EscherRecordFactory recordFactory)
{
int bytesRemaining = ReadHeader(data, offset);
int pos = offset + 8;
int size = 0;
field_1_shapeId = LittleEndian.GetInt(data, pos + size); size += 4;
field_2_flags = LittleEndian.GetInt(data, pos + size); size += 4;
// bytesRemaining -= size;
// remainingData = new byte[bytesRemaining];
// Array.Copy( data, pos + size, remainingData, 0, bytesRemaining );
return RecordSize;
}
///
/// Serializes to an existing byte array without serialization listener.
/// This is done by delegating to Serialize(int, byte[], EscherSerializationListener).
///
/// the offset within the data byte array.
/// the data array to Serialize to.
/// a listener for begin and end serialization events.
/// The number of bytes written.
public override int Serialize(int offset, byte[] data, EscherSerializationListener listener)
{
listener.BeforeRecordSerialize(offset, RecordId, this);
LittleEndian.PutShort(data, offset, Options);
LittleEndian.PutShort(data, offset + 2, RecordId);
int remainingBytes = 8;
LittleEndian.PutInt(data, offset + 4, remainingBytes);
LittleEndian.PutInt(data, offset + 8, field_1_shapeId);
LittleEndian.PutInt(data, offset + 12, field_2_flags);
listener.AfterRecordSerialize(offset + RecordSize, RecordId, RecordSize, this);
return 8 + 8;
}
///
/// Returns the number of bytes that are required to Serialize this record.
///
/// Number of bytes
public override int RecordSize
{
get{return 8 + 8;}
}
///
/// @return the 16 bit identifier for this record.
///
///
public override short RecordId
{
get { return RECORD_ID; }
}
///
/// The short name for this record
///
///
public override String RecordName
{
get { return "Sp"; }
}
///
/// Returns a that represents the current .
///
///
/// A that represents the current .
///
public override String ToString()
{
String nl = Environment.NewLine;
return this.GetType().Name + ":" + nl +
" RecordId: 0x" + HexDump.ToHex(RECORD_ID) + nl +
" Options: 0x" + HexDump.ToHex(Options) + nl +
" ShapeId: " + field_1_shapeId + nl +
" Flags: " + DecodeFlags(field_2_flags) + " (0x" + HexDump.ToHex(field_2_flags) + ")" + nl;
}
///
/// Converts the shape flags into a more descriptive name.
///
/// The flags.
///
private String DecodeFlags(int flags)
{
StringBuilder result = new StringBuilder();
result.Append((flags & FLAG_GROUP) != 0 ? "|GROUP" : "");
result.Append((flags & FLAG_CHILD) != 0 ? "|CHILD" : "");
result.Append((flags & FLAG_PATRIARCH) != 0 ? "|PATRIARCH" : "");
result.Append((flags & FLAG_DELETED) != 0 ? "|DELETED" : "");
result.Append((flags & FLAG_OLESHAPE) != 0 ? "|OLESHAPE" : "");
result.Append((flags & FLAG_HAVEMASTER) != 0 ? "|HAVEMASTER" : "");
result.Append((flags & FLAG_FLIPHORIZ) != 0 ? "|FLIPHORIZ" : "");
result.Append((flags & FLAG_FLIPVERT) != 0 ? "|FLIPVERT" : "");
result.Append((flags & FLAG_CONNECTOR) != 0 ? "|CONNECTOR" : "");
result.Append((flags & FLAG_HAVEANCHOR) != 0 ? "|HAVEANCHOR" : "");
result.Append((flags & FLAG_BACKGROUND) != 0 ? "|BACKGROUND" : "");
result.Append((flags & FLAG_HASSHAPETYPE) != 0 ? "|HASSHAPETYPE" : "");
//need to check, else blows up on some records - bug 34435
if (result.Length > 0)
{
result.Remove(0,1);
}
return result.ToString();
}
///
/// Gets or sets A number that identifies this shape
///
/// The shape id.
public int ShapeId
{
get { return field_1_shapeId; }
set { this.field_1_shapeId = value; }
}
///
/// The flags that apply to this shape.
///
/// The flags.
public int Flags
{
get { return field_2_flags; }
set { this.field_2_flags = value; }
}
}
}