All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.poi.hslf.record.OEPlaceholderAtom Maven / Gradle / Ivy

There is a newer version: 5.2.5
Show newest version
/* ====================================================================
   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.hslf.record;

import java.io.IOException;
import java.io.OutputStream;

import org.apache.poi.sl.usermodel.Placeholder;
import org.apache.poi.util.LittleEndian;

/**
 * OEPlaceholderAtom (3011).

* * An atom record that specifies whether a shape is a placeholder shape. * * @see Placeholder */ public final class OEPlaceholderAtom extends RecordAtom{ /** * The full size of the master body text placeholder shape. */ public static final int PLACEHOLDER_FULLSIZE = 0; /** * Half of the size of the master body text placeholder shape. */ public static final int PLACEHOLDER_HALFSIZE = 1; /** * A quarter of the size of the master body text placeholder shape. */ public static final int PLACEHOLDER_QUARTSIZE = 2; private byte[] _header; private int placementId; private int placeholderId; private int placeholderSize; private short unusedShort; /** * Create a new instance of {@code OEPlaceholderAtom} */ public OEPlaceholderAtom(){ _header = new byte[8]; LittleEndian.putUShort(_header, 0, 0); LittleEndian.putUShort(_header, 2, (int)getRecordType()); LittleEndian.putInt(_header, 4, 8); placementId = 0; placeholderId = 0; placeholderSize = 0; } /** * Build an instance of {@code OEPlaceholderAtom} from on-disk data */ protected OEPlaceholderAtom(byte[] source, int start, int len) { _header = new byte[8]; int offset = start; System.arraycopy(source,start,_header,0,8); offset += _header.length; placementId = LittleEndian.getInt(source, offset); offset += 4; placeholderId = LittleEndian.getUByte(source, offset); offset++; placeholderSize = LittleEndian.getUByte(source, offset); offset++; unusedShort = LittleEndian.getShort(source, offset); } /** * @return type of this record {@link RecordTypes#OEPlaceholderAtom}. */ @Override public long getRecordType() { return RecordTypes.OEPlaceholderAtom.typeID; } /** * Returns the placement Id.

* * The placement Id is a number assigned to the placeholder. It goes from -1 to the number of placeholders. * It SHOULD be unique among all PlacholderAtom records contained in the corresponding slide. * The value 0xFFFFFFFF specifies that the corresponding shape is not a placeholder shape. * * @return the placement Id. */ public int getPlacementId(){ return placementId; } /** * Sets the placement Id.

* * The placement Id is a number assigned to the placeholder. It goes from -1 to the number of placeholders. * It SHOULD be unique among all PlacholderAtom records contained in the corresponding slide. * The value 0xFFFFFFFF specifies that the corresponding shape is not a placeholder shape. * * @param id the placement Id. */ public void setPlacementId(int id){ placementId = id; } /** * Returns the placeholder Id.

* * placeholder Id specifies the type of the placeholder shape. * The value MUST be one of the static constants defined in this class * * @return the placeholder Id. */ public int getPlaceholderId(){ return placeholderId; } /** * Sets the placeholder Id.

* * placeholder Id specifies the type of the placeholder shape. * The value MUST be one of the static constants defined in this class * * @param id the placeholder Id. */ public void setPlaceholderId(byte id){ placeholderId = id; } /** * Returns the placeholder size. * Must be one of the PLACEHOLDER_* static constants defined in this class. * * @return the placeholder size. */ public int getPlaceholderSize(){ return placeholderSize; } /** * Sets the placeholder size. * Must be one of the PLACEHOLDER_* static constants defined in this class. * * @param size the placeholder size. */ public void setPlaceholderSize(byte size){ placeholderSize = size; } /** * Write the contents of the record back, so it can be written to disk */ @Override public void writeOut(OutputStream out) throws IOException { out.write(_header); byte[] recdata = new byte[8]; LittleEndian.putInt(recdata, 0, placementId); recdata[4] = (byte)placeholderId; recdata[5] = (byte)placeholderSize; LittleEndian.putShort(recdata, 6, unusedShort); out.write(recdata); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy