/*
* 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.IO;
using System.Collections;
using HH.WMS.Utils.NPOI.Util;
///
/// @author Glen Stampoultzis
/// @version $Id: EscherBitmapBlip.java 569827 2007-08-26 15:26:29Z yegor $
///
public class EscherBitmapBlip : EscherBlipRecord
{
public const short RECORD_ID_JPEG = unchecked((short)0xF018) + 5;
public const short RECORD_ID_PNG = unchecked((short)0xF018) + 6;
public const short RECORD_ID_DIB = unchecked((short)0xF018) + 7;
private const int HEADER_SIZE = 8;
private byte[] field_1_UID;
private byte field_2_marker = (byte)0xFF;
///
/// This method deSerializes the record from a byte array.
///
/// The byte array containing the escher record information
/// The starting offset into
/// May be null since this is not a container record.
/// The number of bytes Read from the byte array.
public override int FillFields(byte[] data, int offset, EscherRecordFactory recordFactory)
{
int bytesAfterHeader = ReadHeader(data, offset);
int pos = offset + HEADER_SIZE;
field_1_UID = new byte[16];
Array.Copy(data, pos, field_1_UID, 0, 16); pos += 16;
field_2_marker = data[pos]; pos++;
field_pictureData = new byte[bytesAfterHeader - 17];
Array.Copy(data, pos, field_pictureData, 0, field_pictureData.Length);
return bytesAfterHeader + HEADER_SIZE;
}
///
/// Serializes the record to an existing byte array.
///
/// the offset within the 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);
LittleEndian.PutInt(data, offset + 4, RecordSize - HEADER_SIZE);
int pos = offset + HEADER_SIZE;
Array.Copy(field_1_UID, 0, data, pos, 16);
data[pos + 16] = field_2_marker;
Array.Copy(field_pictureData, 0, data, pos + 17, field_pictureData.Length);
listener.AfterRecordSerialize(offset + RecordSize, RecordId, RecordSize, this);
return HEADER_SIZE + 16 + 1 + field_pictureData.Length;
}
///
/// Returns the number of bytes that are required to Serialize this record.
///
/// Number of bytes
public override int RecordSize
{
get { return 8 + 16 + 1 + field_pictureData.Length; }
}
///
/// Gets or sets the UID.
///
/// The UID.
public byte[] UID
{
get { return field_1_UID; }
set { this.field_1_UID = value; }
}
///
/// Gets or sets the marker.
///
/// The marker.
public byte Marker
{
get { return field_2_marker; }
set { this.field_2_marker = value; }
}
///
/// Toes the string.
///
///
public override String ToString()
{
String nl = Environment.NewLine;
String extraData;
using (MemoryStream b = new MemoryStream())
{
try
{
HexDump.Dump(this.field_pictureData, 0, b, 0);
extraData = b.ToString();
}
catch (Exception e)
{
extraData = e.ToString();
}
return this.GetType().Name + ":" + nl +
" RecordId: 0x" + HexDump.ToHex(RecordId) + nl +
" Options: 0x" + HexDump.ToHex(Options) + nl +
" UID: 0x" + HexDump.ToHex(field_1_UID) + nl +
" Marker: 0x" + HexDump.ToHex(field_2_marker) + nl +
" Extra Data:" + nl + extraData;
}
}
}
}