/* * Copyright (c) 2003 Sun Microsystems, Inc. All Rights Reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are * met: * * - Redistribution of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * - Redistribution 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 Sun Microsystems, Inc. or the names of * contributors may be used to endorse or promote products derived from * this software without specific prior written permission. * * This software is provided "AS IS," without a warranty of any kind. ALL * EXPRESS OR IMPLIED CONDITIONS, REPRESENTATIONS AND WARRANTIES, * INCLUDING ANY IMPLIED WARRANTY OF MERCHANTABILITY, FITNESS FOR A * PARTICULAR PURPOSE OR NON-INFRINGEMENT, ARE HEREBY EXCLUDED. SUN * MICROSYSTEMS, INC. ("SUN") AND ITS LICENSORS SHALL NOT BE LIABLE FOR * ANY DAMAGES SUFFERED BY LICENSEE AS A RESULT OF USING, MODIFYING OR * DISTRIBUTING THIS SOFTWARE OR ITS DERIVATIVES. IN NO EVENT WILL SUN OR * ITS LICENSORS BE LIABLE FOR ANY LOST REVENUE, PROFIT OR DATA, OR FOR * DIRECT, INDIRECT, SPECIAL, CONSEQUENTIAL, INCIDENTAL OR PUNITIVE * DAMAGES, HOWEVER CAUSED AND REGARDLESS OF THE THEORY OF LIABILITY, * ARISING OUT OF THE USE OF OR INABILITY TO USE THIS SOFTWARE, EVEN IF * SUN HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. * * You acknowledge that this software is not designed or intended for use * in the design, construction, operation or maintenance of any nuclear * facility. * * Sun gratefully acknowledges that this software was originally authored * and developed by Kenneth Bradley Russell and Christopher John Kline. */ package javax.media.opengl; /** Interface for a native window object. This can be a representation of a fully functional native window, i.e. a terminal object, where {@link NativeWindow#isTerminalObject()} returns true. Otherwise it is a a proxy for a wrapped Java-level window toolkit window object (e.g. java.awt.Component), which can be retrieved with {@link NativeWindow#getWrappedWindow()}. In case the NativeWindow is a terminal object, where the NativeWindow implementation took care of exposing all necessary native windowing information, the utilizing toolkit (e.g. JOGL) will use a generic implementation and use the native information directly. In case the NativeWindow is a proxy object, where no native windowing information is available yet, the utilizing toolkit (e.g. JOGL) is expected to have a specific implementation path to handle the wrapped Java-level window toolkit window object. */ public interface NativeWindow { public static final int LOCK_NOT_SUPPORTED = 0; public static final int LOCK_SURFACE_NOT_READY = 1; public static final int LOCK_SURFACE_CHANGED = 2; public static final int LOCK_SUCCESS = 3; /** * Lock this surface */ public int lockSurface() throws NativeWindowException ; /** * Unlock this surface */ public void unlockSurface(); public boolean isSurfaceLocked(); /** * render all native window information invalid, * as if the native window was destroyed */ public void invalidate(); /** * Lifetime: locked state */ public long getDisplayHandle(); public long getScreenHandle(); /** * Returns the window handle for this NativeWindow.

* * The window handle shall reflect the platform one * for all window related operations, e.g. open, close, resize.

* * On X11 this returns an entity of type Window.
* On Microsoft Windows this returns an entity of type HWND. */ public long getWindowHandle(); /** * Returns the handle to the surface for this NativeWindow.

* * The surface handle shall reflect the platform one * for all drawable surface operations, e.g. opengl, swap-buffer.

* * On X11 this returns an entity of type Window, * since there is no differentiation of surface and window there.
* On Microsoft Windows this returns an entity of type HDC. */ public long getSurfaceHandle(); /** * Lifetime: after 1st lock, until invalidation */ public long getVisualID(); public int getScreenIndex(); /** * If this NativeWindow actually wraps a window from a Java-level * window toolkit, return the underlying window object. */ public Object getWrappedWindow(); /** * @return True, if this NativeWindow is a terminal object, * i.e. all native windowing information is available. * False otherwise, ie. it holds a wrapped window object, * from which native handles must be derived by the utilizing tookit. */ public boolean isTerminalObject(); public void setSize(int width, int height); public void setPosition(int x, int y); public int getWidth(); public int getHeight(); public int getX(); public int getY(); public void setVisible(boolean visible); public boolean setFullscreen(boolean fullscreen); public boolean isVisible(); public boolean isFullscreen(); }