|  | package org.newdawn.spaceinvaders;
import org.newdawn.spaceinvaders.java2d.Java2DGameWindow;
import org.newdawn.spaceinvaders.java2d.Java2DSpriteStore;
import org.newdawn.spaceinvaders.jogl.JoglGameWindow;
import org.newdawn.spaceinvaders.jogl.JoglSprite;
/**
 * A central reference point for creating resources for use in the game. The resources
 * return may be implemented in several different rendering contexts but will also 
 * work within the GameWindow supplied from this class. For instance, a Sprite retrieved
 * as a resource will draw happily in the GameWindow supplied from this factory
 *
 * @author Kevin Glass
 */
public class ResourceFactory {
	/** The single instance of this class to ever exist <singleton> */
	private static final ResourceFactory single = new ResourceFactory();
	
	/**
 	 * Retrieve the single instance of this class 
	 *
 	 * @return The single instance of this class 
	 */
	public static ResourceFactory get() {
		return single;
	}
	/** A value to indicate that we should use Java 2D to render our game */
	public static final int JAVA2D = 1;
	/** A value to indicate that we should use OpenGL (JOGL) to render our game */
	public static final int OPENGL_JOGL = 2;
	/** The type of rendering that we are currently using */
	private int renderingType = JAVA2D;
	/** The window the game should use to render */
	private GameWindow window;
	/** 
       * The default contructor has been made private to prevent construction of 
	 * this class anywhere externally. This is used to enforce the singleton 
	 * pattern that this class attempts to follow
	 */
	private ResourceFactory() {
	}
	/** 
	 * Set the rendering method that should be used. Note: This can only be done
	 * before the first resource is accessed.
	 *
 	 * @param renderingType The type of rendering to use
	 */
	public void setRenderingType(int renderingType) {
		
		if ((renderingType != JAVA2D) && (renderingType != OPENGL_JOGL)) {
			
			
			
			throw new RuntimeException("Unknown rendering type specified: "+renderingType);
		}
		
		
		if (window != null) {
			throw new RuntimeException("Attempt to change rendering method at game runtime");
		}
		this.renderingType = renderingType;
	}
	/**
 	 * Retrieve the game window that should be used to render the game
	 *
	 * @return The game window in which the game should be rendered
	 */
	public GameWindow getGameWindow() {
		
		
		if (window == null) {
			switch (renderingType) {
				case JAVA2D:
				{
					window = new Java2DGameWindow();
					break;
 				}
				case OPENGL_JOGL:
				{
					window = new JoglGameWindow();
					break;
				}
			}
		}
		return window;
	}
	/**
	 * Create or get a sprite which displays the image that is pointed
	 * to in the classpath by "ref"
	 * 
	 * @param ref A reference to the image to load
	 * @return A sprite that can be drawn onto the current graphics context.
	 */
	public Sprite getSprite(String ref) {
		if (window == null) {
			throw new RuntimeException("Attempt to retrieve sprite before game window was created");
		}
		
		switch (renderingType) {
			case JAVA2D:
			{
				return Java2DSpriteStore.get().getSprite((Java2DGameWindow) window,ref);
			}
			case OPENGL_JOGL:
			{
				return new JoglSprite((JoglGameWindow) window,ref);
			}
		}
		
		throw new RuntimeException("Unknown rendering type: "+renderingType);
	}
} |