mirror of
https://github.com/glfw/glfw.git
synced 2025-10-04 21:56:36 +00:00
Merge branch 'master' into android
This commit is contained in:
commit
cbb01b6346
@ -152,15 +152,13 @@ void _glfwInputError(int code, const char* format, ...)
|
||||
|
||||
if (format)
|
||||
{
|
||||
int count;
|
||||
va_list vl;
|
||||
|
||||
va_start(vl, format);
|
||||
count = vsnprintf(description, sizeof(description), format, vl);
|
||||
vsnprintf(description, sizeof(description), format, vl);
|
||||
va_end(vl);
|
||||
|
||||
if (count < 0)
|
||||
description[sizeof(description) - 1] = '\0';
|
||||
description[sizeof(description) - 1] = '\0';
|
||||
}
|
||||
else
|
||||
strcpy(description, getErrorString(code));
|
||||
|
@ -306,7 +306,6 @@ GLFWbool _glfwInitJoysticksLinux(void)
|
||||
|
||||
closedir(dir);
|
||||
}
|
||||
else
|
||||
|
||||
// Continue with no joysticks if enumeration fails
|
||||
|
||||
|
@ -76,6 +76,7 @@ typedef struct _GLFWwindowWayland
|
||||
int width, height;
|
||||
GLFWbool visible;
|
||||
GLFWbool maximized;
|
||||
GLFWbool transparent;
|
||||
struct wl_surface* surface;
|
||||
struct wl_egl_window* native;
|
||||
struct wl_shell_surface* shellSurface;
|
||||
|
@ -212,8 +212,8 @@ static GLFWbool createSurface(_GLFWwindow* window,
|
||||
window->wl.height = wndconfig->height;
|
||||
window->wl.scale = 1;
|
||||
|
||||
// TODO: make this optional once issue #197 is fixed.
|
||||
setOpaqueRegion(window);
|
||||
if (!window->wl.transparent)
|
||||
setOpaqueRegion(window);
|
||||
|
||||
return GLFW_TRUE;
|
||||
}
|
||||
@ -390,6 +390,8 @@ int _glfwPlatformCreateWindow(_GLFWwindow* window,
|
||||
const _GLFWctxconfig* ctxconfig,
|
||||
const _GLFWfbconfig* fbconfig)
|
||||
{
|
||||
window->wl.transparent = fbconfig->transparent;
|
||||
|
||||
if (!createSurface(window, wndconfig))
|
||||
return GLFW_FALSE;
|
||||
|
||||
@ -514,7 +516,8 @@ void _glfwPlatformSetWindowSize(_GLFWwindow* window, int width, int height)
|
||||
window->wl.width = width;
|
||||
window->wl.height = height;
|
||||
wl_egl_window_resize(window->wl.native, scaledWidth, scaledHeight, 0, 0);
|
||||
setOpaqueRegion(window);
|
||||
if (!window->wl.transparent)
|
||||
setOpaqueRegion(window);
|
||||
_glfwInputFramebufferSize(window, scaledWidth, scaledHeight);
|
||||
}
|
||||
|
||||
@ -656,9 +659,7 @@ int _glfwPlatformWindowMaximized(_GLFWwindow* window)
|
||||
|
||||
int _glfwPlatformFramebufferTransparent(_GLFWwindow* window)
|
||||
{
|
||||
_glfwInputError(GLFW_PLATFORM_ERROR,
|
||||
"Wayland: Framebuffer transparency attribute not implemented yet");
|
||||
return GLFW_FALSE;
|
||||
return window->wl.transparent;
|
||||
}
|
||||
|
||||
void _glfwPlatformSetWindowResizable(_GLFWwindow* window, GLFWbool enabled)
|
||||
|
@ -98,7 +98,7 @@ static void hat_widget(struct nk_context* nk, unsigned char state)
|
||||
struct nk_rect area;
|
||||
struct nk_vec2 center;
|
||||
|
||||
if (nk_widget(&area, nk) != NK_WIDGET_VALID)
|
||||
if (nk_widget(&area, nk) == NK_WIDGET_INVALID)
|
||||
return;
|
||||
|
||||
center = nk_vec2(area.x + area.w / 2.f, area.y + area.h / 2.f);
|
||||
@ -269,7 +269,9 @@ int main(void)
|
||||
"LT", "RT",
|
||||
};
|
||||
|
||||
nk_label(nk, "Gamepad state", NK_TEXT_LEFT);
|
||||
nk_labelf(nk, NK_TEXT_LEFT,
|
||||
"Gamepad state: %s",
|
||||
glfwGetGamepadName(joysticks[i]));
|
||||
|
||||
nk_layout_row_dynamic(nk, 30, 2);
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user