Class LwjglWindow

java.lang.Object
com.jme3.system.lwjgl.LwjglContext
com.jme3.system.lwjgl.LwjglWindow
All Implemented Interfaces:
JmeContext, Runnable
Direct Known Subclasses:
LwjglOffscreenBufferVR

public abstract class LwjglWindow extends LwjglContext implements Runnable
A wrapper class over the GLFW framework in LWJGL 3.
  • Field Details

    • needClose

      protected final AtomicBoolean needClose
    • needRestart

      protected final AtomicBoolean needRestart
    • wasActive

      protected boolean wasActive
    • autoFlush

      protected boolean autoFlush
    • allowSwapBuffers

      protected boolean allowSwapBuffers
  • Constructor Details

  • Method Details

    • registerWindowSizeListener

      public void registerWindowSizeListener(WindowSizeListener listener)
      Registers the specified listener to get notified when window size changes.
      Parameters:
      listener - The WindowSizeListener to register.
    • removeWindowSizeListener

      public void removeWindowSizeListener(WindowSizeListener listener)
      Removes the specified listener from the listeners list.
      Parameters:
      listener - The WindowSizeListener to remove.
    • getType

      public JmeContext.Type getType()
      Specified by:
      getType in interface JmeContext
      Returns:
      Type.Display or Type.Canvas
    • setTitle

      public void setTitle(String title)
      Set the title if it's a windowed display
      Specified by:
      setTitle in interface JmeContext
      Parameters:
      title - the title to set
    • restart

      public void restart()
      Restart if it's a windowed or full-screen display.
      Specified by:
      restart in interface JmeContext
    • createContext

      protected void createContext(AppSettings settings)
      Apply the settings, changing resolution, etc.
      Parameters:
      settings - the settings to apply when creating the context.
    • showWindow

      protected void showWindow()
    • setWindowIcon

      protected void setWindowIcon(AppSettings settings)
      Set custom icons to the window of this application.
      Parameters:
      settings - settings for getting the icons
    • destroyContext

      protected void destroyContext()
      Destroy the context.
    • create

      public void create(boolean waitFor)
      Description copied from interface: JmeContext
      Creates the context and makes it active.
      Specified by:
      create in interface JmeContext
      Parameters:
      waitFor - If true, will wait until context has initialized.
    • initInThread

      protected boolean initInThread()
      Does LWJGL display initialization in the OpenGL thread
      Returns:
      returns true if the context initialization was successful
    • runLoop

      protected void runLoop()
      execute one iteration of the render loop in the OpenGL thread
    • deinitInThread

      protected void deinitInThread()
      De-initialize in the OpenGL thread.
    • run

      public void run()
      Specified by:
      run in interface Runnable
    • getJoyInput

      public JoyInput getJoyInput()
      Specified by:
      getJoyInput in interface JmeContext
      Returns:
      Joystick input implementation. May be null if not available.
    • getMouseInput

      public MouseInput getMouseInput()
      Specified by:
      getMouseInput in interface JmeContext
      Returns:
      Mouse input implementation. May be null if not available.
    • getKeyInput

      public KeyInput getKeyInput()
      Specified by:
      getKeyInput in interface JmeContext
      Returns:
      Keyboard input implementation. May be null if not available.
    • getTouchInput

      public TouchInput getTouchInput()
      Specified by:
      getTouchInput in interface JmeContext
      Returns:
      Touch device input implementation. May be null if not available.
    • setAutoFlushFrames

      public void setAutoFlushFrames(boolean enabled)
      Specified by:
      setAutoFlushFrames in interface JmeContext
      Parameters:
      enabled - If enabled, the context will automatically flush frames to the video card (swap buffers) after an update cycle.
    • destroy

      public void destroy(boolean waitFor)
      Description copied from interface: JmeContext
      Destroys the context completely, making it inactive.
      Specified by:
      destroy in interface JmeContext
      Parameters:
      waitFor - If true, will wait until the context is destroyed fully.
    • getWindowHandle

      public long getWindowHandle()
    • getWindowContentScale

      public Vector2f getWindowContentScale(Vector2f store)
      Get the window content scale, for HiDPI support. The content scale is the ratio between the current DPI and the platform's default DPI. This is especially important for text and any UI elements. If the pixel dimensions of your UI scaled by this look appropriate on your machine then it should appear at a reasonable size on other machines regardless of their DPI and scaling settings. This relies on the system DPI and scaling settings being somewhat correct.
      Parameters:
      store - A vector2f to store the result
      Returns:
      The window content scale
      See Also:
    • getFramebufferHeight

      public int getFramebufferHeight()
      Returns the height of the framebuffer.
      Specified by:
      getFramebufferHeight in interface JmeContext
      Overrides:
      getFramebufferHeight in class LwjglContext
      Returns:
      the height (in pixels)
    • getFramebufferWidth

      public int getFramebufferWidth()
      Returns the width of the framebuffer.
      Specified by:
      getFramebufferWidth in interface JmeContext
      Overrides:
      getFramebufferWidth in class LwjglContext
      Returns:
      the width (in pixels)
    • getWindowXPosition

      public int getWindowXPosition()
      Returns the screen X coordinate of the left edge of the content area.
      Specified by:
      getWindowXPosition in interface JmeContext
      Overrides:
      getWindowXPosition in class LwjglContext
      Returns:
      the screen X coordinate
    • getWindowYPosition

      public int getWindowYPosition()
      Returns the screen Y coordinate of the top edge of the content area.
      Specified by:
      getWindowYPosition in interface JmeContext
      Overrides:
      getWindowYPosition in class LwjglContext
      Returns:
      the screen Y coordinate
    • getPrimaryDisplay

      public int getPrimaryDisplay()
      Returns the Primary Monitor position number from the list of monitors returned by glfwGetPrimaryMonitor(). If primary monitor not found it will return -1 and report the error.
      Specified by:
      getPrimaryDisplay in interface JmeContext
      Returns:
      returns the Primary Monitor Position.
    • getDisplays

      public Displays getDisplays()
      This returns an arraylist of all the Display returned by OpenGL get Monitor call. It will also has some limited information about each display, like: width, height and refresh rate.
      Specified by:
      getDisplays in interface JmeContext
      Returns:
      returns an ArrayList of all Display returned by glfwGetMonitors()