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

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

/* ====================================================================
   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 java.util.Arrays;

import org.apache.poi.util.LittleEndian;

import static org.apache.logging.log4j.util.Unbox.box;

/**
 * A container record that specifies information about animation information for a shape.
 */
public final class AnimationInfo extends RecordContainer {
    private byte[] _header;

    // Links to our more interesting children
    private AnimationInfoAtom animationAtom;

    /**
     * Set things up, and find our more interesting children
     */
    protected AnimationInfo(byte[] source, int start, int len) {
        // Grab the header
        _header = Arrays.copyOfRange(source, start, start+8);

        // Find our children
        _children = Record.findChildRecords(source,start+8,len-8);
        findInterestingChildren();
    }

    /**
     * Go through our child records, picking out the ones that are
     *  interesting, and saving those for use by the easy helper
     *  methods.
     */
    private void findInterestingChildren() {

        // First child should be the ExMediaAtom
        final Record child = _children[0];
        if(child instanceof AnimationInfoAtom) {
            animationAtom = (AnimationInfoAtom) child;
        } else {
            LOG.atError().log("First child record wasn't a AnimationInfoAtom, was of type {}", box(child.getRecordType()));
        }
    }

    /**
     * Create a new AnimationInfo, with blank fields
     */
    public AnimationInfo() {
        // Setup our header block
        _header = new byte[8];
        _header[0] = 0x0f; // We are a container record
        LittleEndian.putShort(_header, 2, (short)getRecordType());

        _children = new org.apache.poi.hslf.record.Record[1];
        _children[0] = animationAtom = new AnimationInfoAtom();
    }

    /**
     * We are of type 4103
     */
    public long getRecordType() { return RecordTypes.AnimationInfo.typeID; }

    /**
     * Write the contents of the record back, so it can be written
     *  to disk
     */
    public void writeOut(OutputStream out) throws IOException {
        writeOut(_header[0],_header[1],getRecordType(),_children,out);
    }

    /**
     * Returns the AnimationInfo
     */
    public AnimationInfoAtom getAnimationInfoAtom() {
        return animationAtom;
    }

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy