lwjgl2-arm64/src/java/org/lwjgl/opengl/BaseGL.java

193 lines
5.2 KiB
Java
Raw Normal View History

2002-08-15 18:19:01 +02:00
/*
2002-12-21 13:37:20 +01:00
* Copyright (c) 2002 Lightweight Java Game Library Project
2002-08-15 18:19:01 +02:00
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are
* met:
2002-08-09 12:56:30 +02:00
*
2002-08-15 18:19:01 +02:00
* * Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
*
* * Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
*
* * Neither the name of 'Light Weight Java Game Library' nor the names of
* its contributors may be used to endorse or promote products derived
* from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
* TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
2002-08-09 12:56:30 +02:00
*/
2002-08-15 18:19:01 +02:00
2002-08-09 12:56:30 +02:00
package org.lwjgl.opengl;
import org.lwjgl.Sys;
/**
2002-08-15 18:19:01 +02:00
* $Id$
*
2002-08-09 12:56:30 +02:00
* The base GL functionality (no actual GL methods).
*
* Each instance of GL is only valid in the thread that creates it.
* In addition, only one instance may be the current GL context in any one
* thread. To make a GL instance the current context, use makeCurrent().
*
* This has been provided as a base class that we can use for either the
* full GL1.4 specification or as a cut-down OpenGL embedded spec. (aka
* a mini-driver).
*
2002-08-15 18:19:01 +02:00
* @author cix_foo <cix_foo@users.sourceforge.net>
* @version $Revision$
2002-08-09 12:56:30 +02:00
*/
abstract class BaseGL {
static {
2002-08-19 16:01:23 +02:00
System.loadLibrary(Sys.getLibraryName());
2002-08-09 12:56:30 +02:00
}
/** The current rendering context */
private static BaseGL currentContext;
/** Has the GL been created yet? */
private boolean created;
/** Handle to the native context */
protected int handle;
/** This GL will be valid for use in only one thread */
protected Thread renderThread;
/**
* Constructor for BaseGL. The context is not created at this point;
* to create the GL you must call create().
*
2002-08-23 18:14:38 +02:00
* @see #create()
2002-08-09 12:56:30 +02:00
*/
public BaseGL() {
2002-08-09 12:56:30 +02:00
}
/**
* Creates the GL, with the best match it can get for the specified
* parameters. The display must first have been created.
*
* @throws Exception if the GL could not be created for some reason
*/
public final void create() throws Exception{
if (created)
return;
if (!nCreate())
2002-08-09 12:56:30 +02:00
throw new Exception("GL could not be created.");
created = true;
makeCurrent();
init();
}
/**
* Override to provide any initialization code after creation.
*/
protected void init() {
}
/**
* Native method to create the GL. If successful then the native handle will
* be set. The GL is created on the current display, which must have been
* created by calling its setDisplayMode() method.
*
* @return true if the GL was created successfully
2002-08-23 18:14:38 +02:00
* @see org.lwjgl.Display#create(org.lwjgl.DisplayMode, boolean)
2002-08-09 12:56:30 +02:00
*/
private native boolean nCreate();
2002-08-09 12:56:30 +02:00
/**
* Destroy the GL context. Does nothing if the GL has not yet been created.
*/
public final void destroy() {
2002-08-09 12:56:30 +02:00
if (!created)
return;
cleanup();
created = false;
renderThread = null;
nDestroy();
}
/**
* Native method to destroy the GL context
*/
private native void nDestroy();
/**
* Provide any cleanup in derived classes here. This method is called
* just before the native context is destroyed.
*/
public void cleanup() {
}
/**
* Finalizer, marked final. To perform specialized cleanup override the
* cleanup() method.
*
2002-08-23 18:14:38 +02:00
* @see #cleanup()
2002-08-09 12:56:30 +02:00
*/
public final void finalize() throws Throwable {
super.finalize();
destroy();
}
/**
* Free the context from the current thread.
*/
public final void releaseContext() {
assert created : "GL has not been created yet.";
renderThread = null;
currentContext = null;
nReleaseContext();
}
2002-08-09 12:56:30 +02:00
/**
* Make this the current context for the current thread.
*/
public final void makeCurrent() {
assert created : "GL has not been created yet.";
renderThread = Thread.currentThread();
currentContext = this;
nMakeCurrent();
}
/**
* Swap the buffers
*/
public native void swapBuffers();
/**
* Native method to free the context
*/
private native void nReleaseContext();
2002-08-09 12:56:30 +02:00
/**
* Native method to make this the current thread
*/
private native void nMakeCurrent();
/**
* @return true if this is the current rendering context and the correct
* thread
*/
public final boolean isValid() {
return created
&& currentContext == this
&& Thread.currentThread() == renderThread;
}
}