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

src.gov.nasa.worldwind.util.BufferFactory Maven / Gradle / Ivy

Go to download

World Wind is a collection of components that interactively display 3D geographic information within Java applications or applets.

There is a newer version: 2.0.0-986
Show newest version
/*
 * Copyright (C) 2012 United States Government as represented by the Administrator of the
 * National Aeronautics and Space Administration.
 * All Rights Reserved.
 */
package gov.nasa.worldwind.util;

/**
 * BufferFactory provides a general factory interface for creating instances of {@link
 * gov.nasa.worldwind.util.BufferWrapper}, without having to know the underlying data type. Once created, a
 * BufferWrapper abstracts reading and writing buffer data from the underlying data type. When BufferWrapper is combined
 * with BufferFactory, a component may create and work with buffer data in a type agnostic manner.
 * 

* BufferFactory is itself abstract and defines the factory interface. It defines several implementations as static * inner classes, which serve the most common data types: {@link gov.nasa.worldwind.util.BufferFactory.ByteBufferFactory}, * {@link gov.nasa.worldwind.util.BufferFactory.ShortBufferFactory}, {@link gov.nasa.worldwind.util.BufferFactory.IntBufferFactory}, * {@link gov.nasa.worldwind.util.BufferFactory.FloatBufferFactory}, and {@link gov.nasa.worldwind.util.BufferFactory.DoubleBufferFactory}. * * @author dcollins * @version $Id: BufferFactory.java 1171 2013-02-11 21:45:02Z dcollins $ * @see BufferWrapper */ public abstract class BufferFactory { private final boolean allocateDirect; /** * Constructs a new BufferFactory with the specified buffer allocation policy. * * @param allocateDirect true to allocate and return BufferWrappers backed by direct buffers, false to allocate and * return BufferWrappers backed by non-direct buffers. */ protected BufferFactory(boolean allocateDirect) { this.allocateDirect = allocateDirect; } /** * Constructs a new BufferFactory with the default buffer allocation policy. This factory allocates and returns * BufferWrappers backed by direct buffers. */ protected BufferFactory() { this(true); } /** * @return true if this factory allocates and returns BufferWrappers backed by direct buffers, and false if it * allocates and return BufferWrappers backed by non-direct buffers. */ public boolean isAllocateDirect() { return this.allocateDirect; } /** * Constructs a new BufferWrapper of the specified size. * * @param size the new buffer's size, in number of underlying data type units (bytes, shorts, ints, floats, or * doubles). * * @return the new buffer. * * @throws IllegalArgumentException if size is negative. */ public abstract BufferWrapper newBuffer(int size); /** Implementation of BufferFactory which constructs instances of {@link gov.nasa.worldwind.util.BufferWrapper.ByteBufferWrapper} */ public static class ByteBufferFactory extends BufferFactory { /** * Constructs a new ByteBufferFactory with the specified buffer allocation policy. * * @param allocateDirect true to allocate and return ByteBufferWrappers backed by direct buffers, false to * allocate and return ByteufferWrappers backed by non-direct buffers. */ public ByteBufferFactory(boolean allocateDirect) { super(allocateDirect); } /** * Constructs a new ByteBufferFactory with the default buffer allocation policy. This factory allocates and * returns ByteBufferWrappers backed by direct buffers. */ public ByteBufferFactory() { } /** * Constructs a new ByteBufferWrapper of the specified size, backed by a {@link java.nio.ByteBuffer}. * * @param size the new buffer's size, int bytes. * * @return the new buffer. * * @throws IllegalArgumentException if size is negative. */ public BufferWrapper newBuffer(int size) { if (size < 0) { String message = Logging.getMessage("generic.SizeOutOfRange", size); Logging.logger().severe(message); throw new IllegalArgumentException(message); } return WWBufferUtil.newByteBufferWrapper(size, this.isAllocateDirect()); } } /** Implementation of BufferFactory which constructs instances of {@link gov.nasa.worldwind.util.BufferWrapper.ShortBufferWrapper} */ public static class ShortBufferFactory extends BufferFactory { /** * Constructs a new ShortBufferFactory with the specified buffer allocation policy. * * @param allocateDirect true to allocate and return ShortBufferWrappers backed by direct buffers, false to * allocate and return ShortBufferWrappers backed by non-direct buffers. */ public ShortBufferFactory(boolean allocateDirect) { super(allocateDirect); } /** * Constructs a new ShortBufferFactory with the default buffer allocation policy. This factory allocates and * returns ShortBufferWrappers backed by direct buffers. */ public ShortBufferFactory() { } /** * Constructs a new ShortBufferWrapper of the specified size, backed by a {@link java.nio.ShortBuffer}. * * @param size the new buffer's size, int shorts. * * @return the new buffer. * * @throws IllegalArgumentException if size is negative. */ public BufferWrapper newBuffer(int size) { if (size < 0) { String message = Logging.getMessage("generic.SizeOutOfRange", size); Logging.logger().severe(message); throw new IllegalArgumentException(message); } return WWBufferUtil.newShortBufferWrapper(size, this.isAllocateDirect()); } } /** Implementation of BufferFactory which constructs instances of {@link gov.nasa.worldwind.util.BufferWrapper.IntBufferWrapper} */ public static class IntBufferFactory extends BufferFactory { /** * Constructs a new IntBufferFactory with the specified buffer allocation policy. * * @param allocateDirect true to allocate and return IntBufferWrappers backed by direct buffers, false to * allocate and return IntBufferWrappers backed by non-direct buffers. */ public IntBufferFactory(boolean allocateDirect) { super(allocateDirect); } /** * Constructs a new IntBufferFactory with the default buffer allocation policy. This factory allocates and * returns IntBufferWrappers backed by direct buffers. */ public IntBufferFactory() { } /** * Constructs a new IntBufferWrapper of the specified size, backed by a {@link java.nio.IntBuffer}. * * @param size the new buffer's size, int ints. * * @return the new buffer. * * @throws IllegalArgumentException if size is negative. */ public BufferWrapper newBuffer(int size) { if (size < 0) { String message = Logging.getMessage("generic.SizeOutOfRange", size); Logging.logger().severe(message); throw new IllegalArgumentException(message); } return WWBufferUtil.newIntBufferWrapper(size, this.isAllocateDirect()); } } /** Implementation of BufferFactory which constructs instances of {@link gov.nasa.worldwind.util.BufferWrapper.FloatBufferWrapper} */ public static class FloatBufferFactory extends BufferFactory { /** * Constructs a new FloatBufferFactory with the specified buffer allocation policy. * * @param allocateDirect true to allocate and return FloatBufferWrappers backed by direct buffers, false to * allocate and return FloatBufferWrappers backed by non-direct buffers. */ public FloatBufferFactory(boolean allocateDirect) { super(allocateDirect); } /** * Constructs a new FloatBufferFactory with the default buffer allocation policy. This factory allocates and * returns FloatBufferWrappers backed by direct buffers. */ public FloatBufferFactory() { } /** * Constructs a new FloatBufferWrapper of the specified size, backed by a {@link java.nio.FloatBuffer}. * * @param size the new buffer's size, int floats. * * @return the new buffer. * * @throws IllegalArgumentException if size is negative. */ public BufferWrapper newBuffer(int size) { if (size < 0) { String message = Logging.getMessage("generic.SizeOutOfRange", size); Logging.logger().severe(message); throw new IllegalArgumentException(message); } return WWBufferUtil.newFloatBufferWrapper(size, this.isAllocateDirect()); } } /** Implementation of BufferFactory which constructs instances of {@link gov.nasa.worldwind.util.BufferWrapper.DoubleBufferWrapper} */ public static class DoubleBufferFactory extends BufferFactory { /** * Constructs a new DoubleBufferFactory with the specified buffer allocation policy. * * @param allocateDirect true to allocate and return DoubleBufferWrappers backed by direct buffers, false to * allocate and return DoubleBufferWrappers backed by non-direct buffers. */ public DoubleBufferFactory(boolean allocateDirect) { super(allocateDirect); } /** * Constructs a new DoubleBufferFactory with the default buffer allocation policy. This factory allocates and * returns DoubleBufferWrappers backed by direct buffers. */ public DoubleBufferFactory() { } /** * Constructs a new DoubleBufferWrapper of the specified size, backed by a {@link java.nio.DoubleBuffer}. * * @param size the new buffer's size, int doubles. * * @return the new buffer. * * @throws IllegalArgumentException if size is negative. */ public BufferWrapper newBuffer(int size) { if (size < 0) { String message = Logging.getMessage("generic.SizeOutOfRange", size); Logging.logger().severe(message); throw new IllegalArgumentException(message); } return WWBufferUtil.newDoubleBufferWrapper(size, this.isAllocateDirect()); } } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy