Logo Search packages:      
Sourcecode: java3ds-fileloader version File versions  Download package

Chunk.java

/**
 * Make a donation http://sourceforge.net/donate/index.php?group_id=98797
 * Microcrowd.com
 *
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2.1 of the License, or (at your option) any later version.
 * 
 * This library is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * Lesser General Public License for more details.
 * 
 * You should have received a copy of the GNU Lesser General Public
 * License along with this library; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 * 
 * Contact Josh DeFord jdeford@microcrowd.com
 */

package com.microcrowd.loader.java3d.max3ds.chunks;

import java.util.HashMap;
import com.microcrowd.loader.java3d.max3ds.ChunkChopper;

/**
 * The base class for all chunks. Chunks are  flyweights and should be managed
 * by  {@link ChunkChopper}  Every chunk should know how many bytes of data(or
 * be able figure out)  to read before its subchunks are found. Chunks that only have
 * subchunks need not overrided loadData.
 * Chunks may store data for later use in loadData with {@link pushData}
 * If a chunk needs to initialize components with from subchunks, that data
 * can be retrieved with  {@link ChunkChopper#popData} inside the  {@link
 * #initialize} method.  {@link #loadData} is called at the beginning of the
 * loading process, before any data or subchunks have been loaded(the chunk
 * itself must load its data).
 * <p>
 * During loadData, if the length of data before subchunks is unknown,
 * {@link ChunkChopper#getChunkBytes} may be called and all the data
 * for the chunk(including subchunks) will be read and returned.
 */
00043 public class Chunk 
{
    private HashMap subChunkMap = new HashMap();
    private String name;
    private String description;

    /**
     * default no-arg constructror.
     */
00052     public Chunk(String chunkName)
    {
        name = chunkName;
    }

    /**
     * default no-arg constructror.
     */
00060     public Chunk()
    {
    }

    public void addSubChunk(Integer id, Chunk subChunk)
    {
        subChunkMap.put(id, subChunk);
    }

    public Chunk getSubChunk(Integer id)
    {
        return (Chunk)subChunkMap.get(id);
    }

    /**
     * This method is called after all the  current chunks subchunks are
     * loaded. Any data stored by those subchunks may be retrieved via {@link
     * ChunkChopper#popData}
     * The default implementation does nothing.
     *
     * @param chopper may contain data loaded by subchunks. 
     */
00082     public void initialize(ChunkChopper chopper) 
    {
    }

    /**
     * This is called by the chunk chopper before any of the chunk's 
     * subchunks  are loaded.  Any data loaded that may need to be 
     * used later by superchunks should be stored in
     * the chunk chopper via {@link ChunkChopper#popData}
     * The default implementation does nothing.
     * @param chopper may contain data loaded by subchunks. 
     */
00094     public void loadData(ChunkChopper chopper)
    {
    }

    /**
     * Sets  nice human readable name for the chunk.
     * @param name to use for display of this chunk.
     */
00102     public final void setName(String name)
    {
        this.name = name;
    }

    /**
     * Gets a human readable name for the chunk.
     * @return name used to display the chunk.
     */
00111     public final String getName()
    {
        return name;
    }

    public final String getDescription()
    {
        return description;
    }

    public final void setDescription(String desc)
    {
        description = desc;
    }

    /**
     * Returns the name of this chunk.
     * If the name is null then it just
     * returns the unqualified class name.
     */
00131     public String toString()
    {
        if (getName() != null)
            return getName();
        String className = getClass().getName();
        return className.substring(className.lastIndexOf('.') + 1, 
            className.length()); 
    }
}

Generated by  Doxygen 1.6.0   Back to index