Skip to content
Merged
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
95 changes: 46 additions & 49 deletions jme3-lwjgl3/src/main/java/com/jme3/system/lwjgl/LwjglWindow.java
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
* Copyright (c) 2009-2021 jMonkeyEngine
* Copyright (c) 2009-2022 jMonkeyEngine
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
Expand Down Expand Up @@ -151,7 +151,11 @@ public abstract class LwjglWindow extends LwjglContext implements Runnable {
// temp variables used for glfw calls
private int width[] = new int[1];
private int height[] = new int[1];
private final Vector2f currentScale = new Vector2f(1, 1);

// state maintained by updateSizes()
private int oldFramebufferWidth;
private int oldFramebufferHeight;
private final Vector2f oldScale = new Vector2f(1, 1);

public LwjglWindow(final JmeContext.Type type) {

Expand Down Expand Up @@ -281,18 +285,13 @@ public void invoke(int error, long description) {
}

final GLFWVidMode videoMode = glfwGetVideoMode(glfwGetPrimaryMonitor());

if (settings.getWindowWidth() <= 0 || settings.getWindowHeight() <= 0) {
settings.setWindowSize(videoMode.width(), videoMode.height());
} else {
settings.setWindowSize(settings.getWindowWidth(), settings.getWindowHeight());
int requestWidth = settings.getWindowWidth();
int requestHeight = settings.getWindowHeight();
if (requestWidth <= 0 || requestWidth <= 0) {
requestWidth = videoMode.width();
requestHeight = videoMode.height();
}

// Assume default framebuffer size == window size
settings.setResolution(settings.getWindowWidth(), settings.getWindowHeight());

window = glfwCreateWindow(settings.getWindowWidth(), settings.getWindowHeight(), settings.getTitle(), monitor, NULL);

window = glfwCreateWindow(requestWidth, requestHeight, settings.getTitle(), monitor, NULL);
if (window == NULL) {
throw new RuntimeException("Failed to create the GLFW window");
}
Expand All @@ -317,8 +316,8 @@ public void invoke(final long window, final boolean focus) {
if (settings.getCenterWindow()) {
// Center the window
glfwSetWindowPos(window,
(videoMode.width() - settings.getWidth()) / 2,
(videoMode.height() - settings.getHeight()) / 2);
(videoMode.width() - requestWidth) / 2,
(videoMode.height() - requestHeight) / 2);
} else {
glfwSetWindowPos(window,
settings.getWindowXPosition(),
Expand Down Expand Up @@ -348,16 +347,7 @@ public void invoke(final long window, final boolean focus) {

@Override
public void invoke(final long window, final int width, final int height) {

// This is the window size, never to passed to any pixel based stuff!
// https://www.glfw.org/docs/latest/window_guide.html#window_size
onWindowSizeChanged(width, height);

// Notify listeners
for (WindowSizeListener listener : windowSizeListeners.getArray()) {
listener.onWindowSizeChanged(width, height);
}
updateDefaultFramebufferSize(true);
updateSizes();
}
});

Expand All @@ -366,7 +356,7 @@ public void invoke(final long window, final int width, final int height) {

@Override
public void invoke(final long window, final int width, final int height) {
updateDefaultFramebufferSize(true);
updateSizes();
}
});

Expand All @@ -377,35 +367,42 @@ public void invoke(final long window, final int width, final int height) {
initOpenCL(window);
}

updateSizes();
}

updateDefaultFramebufferSize(false);
private void updateSizes() {
// framebuffer size (resolution) may differ from window size (e.g. HiDPI)

}
glfwGetWindowSize(window, width, height);
int windowWidth = width[0];
int windowHeight = height[0];
if (settings.getWindowWidth() != windowWidth
|| settings.getWindowHeight() != windowHeight) {
settings.setWindowSize(windowWidth, windowHeight);
for (WindowSizeListener wsListener : windowSizeListeners.getArray()) {
wsListener.onWindowSizeChanged(windowWidth, windowHeight);
}
}


private void updateDefaultFramebufferSize(boolean updateListener) {
// If default framebuffer size is different than window size (e.g. HiDPI)
int[] width = new int[1];
int[] height = new int[1];
glfwGetFramebufferSize(window, width, height);
int framebufferWidth = width[0];
int framebufferHeight = height[0];
if (framebufferWidth != oldFramebufferWidth
|| framebufferHeight != oldFramebufferHeight) {
settings.setResolution(framebufferWidth, framebufferHeight);
listener.reshape(framebufferWidth, framebufferHeight);

Vector2f scale = getWindowContentScale(null);

if (updateListener) {
if (settings.getWidth() != width[0] || settings.getHeight() != height[0]) {
listener.reshape(width[0], height[0]);
}
if(!scale.equals(currentScale)){
listener.rescale(scale.x, scale.y);
currentScale.set(scale);
}
oldFramebufferWidth = framebufferWidth;
oldFramebufferHeight = framebufferHeight;
}

}
settings.setResolution(width[0], height[0]);
}
float xScale = framebufferWidth / windowWidth;
float yScale = framebufferHeight / windowHeight;
if (oldScale.x != xScale || oldScale.y != yScale) {
listener.rescale(xScale, yScale);

private void onWindowSizeChanged(final int width, final int height) {
settings.setResolution(width, height);
oldScale.set(xScale, yScale);
}
}

protected void showWindow() {
Expand Down Expand Up @@ -602,7 +599,7 @@ protected boolean initInThread() {
}

listener.initialize();
updateDefaultFramebufferSize(true);
updateSizes();

return true;
}
Expand Down