mirror of
https://github.com/glfw/glfw.git
synced 2024-11-22 13:04:35 +00:00
Merge remote-tracking branch 'adrian/multi-display-support' into multi-monitor
This commit is contained in:
commit
fb465377e3
@ -65,6 +65,13 @@
|
|||||||
// extensions and not all operating systems come with an up-to-date version
|
// extensions and not all operating systems come with an up-to-date version
|
||||||
#include "../support/GL/glext.h"
|
#include "../support/GL/glext.h"
|
||||||
|
|
||||||
|
typedef struct _GLFWhints _GLFWhints;
|
||||||
|
typedef struct _GLFWwndconfig _GLFWwndconfig;
|
||||||
|
typedef struct _GLFWfbconfig _GLFWfbconfig;
|
||||||
|
typedef struct _GLFWwindow _GLFWwindow;
|
||||||
|
typedef struct _GLFWlibrary _GLFWlibrary;
|
||||||
|
typedef struct _GLFWmonitor _GLFWmonitor;
|
||||||
|
|
||||||
#if defined(_GLFW_COCOA_NSGL)
|
#if defined(_GLFW_COCOA_NSGL)
|
||||||
#include "cocoa_platform.h"
|
#include "cocoa_platform.h"
|
||||||
#elif defined(_GLFW_WIN32_WGL)
|
#elif defined(_GLFW_WIN32_WGL)
|
||||||
@ -75,14 +82,6 @@
|
|||||||
#error "No supported platform selected"
|
#error "No supported platform selected"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
typedef struct _GLFWhints _GLFWhints;
|
|
||||||
typedef struct _GLFWwndconfig _GLFWwndconfig;
|
|
||||||
typedef struct _GLFWfbconfig _GLFWfbconfig;
|
|
||||||
typedef struct _GLFWwindow _GLFWwindow;
|
|
||||||
typedef struct _GLFWlibrary _GLFWlibrary;
|
|
||||||
typedef struct _GLFWmonitor _GLFWmonitor;
|
|
||||||
|
|
||||||
|
|
||||||
//------------------------------------------------------------------------
|
//------------------------------------------------------------------------
|
||||||
// Window hints, set by glfwOpenWindowHint and consumed by glfwOpenWindow
|
// Window hints, set by glfwOpenWindowHint and consumed by glfwOpenWindow
|
||||||
// A bucket of semi-random stuff lumped together for historical reasons
|
// A bucket of semi-random stuff lumped together for historical reasons
|
||||||
@ -386,5 +385,9 @@ const _GLFWfbconfig* _glfwChooseFBConfig(const _GLFWfbconfig* desired,
|
|||||||
GLboolean _glfwIsValidContextConfig(_GLFWwndconfig* wndconfig);
|
GLboolean _glfwIsValidContextConfig(_GLFWwndconfig* wndconfig);
|
||||||
GLboolean _glfwIsValidContext(_GLFWwindow* window, _GLFWwndconfig* wndconfig);
|
GLboolean _glfwIsValidContext(_GLFWwindow* window, _GLFWwndconfig* wndconfig);
|
||||||
|
|
||||||
|
// Monitor management (monitor.c)
|
||||||
|
void _glfwInitMonitors(void);
|
||||||
|
void _glfwRefreshMonitors(void);
|
||||||
|
void _glfwTerminateMonitors(void);
|
||||||
|
|
||||||
#endif // _internal_h_
|
#endif // _internal_h_
|
||||||
|
103
src/monitor.c
103
src/monitor.c
@ -145,3 +145,106 @@ GLFWAPI void glfwSetMonitorDeviceCallback(GLFWmonitordevicefun cbfun)
|
|||||||
_glfwLibrary.monitorCallback= cbfun;
|
_glfwLibrary.monitorCallback= cbfun;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//========================================================================
|
||||||
|
// Initialize the monitor list.
|
||||||
|
//========================================================================
|
||||||
|
|
||||||
|
void _glfwInitMonitors(void)
|
||||||
|
{
|
||||||
|
_glfwLibrary.monitorListHead = _glfwCreateMonitors();
|
||||||
|
}
|
||||||
|
|
||||||
|
//========================================================================
|
||||||
|
// Refresh monitor list and notify callback.
|
||||||
|
//========================================================================
|
||||||
|
|
||||||
|
void _glfwRefreshMonitors(void)
|
||||||
|
{
|
||||||
|
_GLFWmonitor* newMonitorList;
|
||||||
|
_GLFWmonitor* curNewMonitor;
|
||||||
|
_GLFWmonitor* curOldMonitor;
|
||||||
|
|
||||||
|
newMonitorList = _glfwCreateMonitors();
|
||||||
|
curNewMonitor = newMonitorList;
|
||||||
|
curOldMonitor = _glfwLibrary.monitorListHead;
|
||||||
|
|
||||||
|
while (_glfwLibrary.monitorCallback && (curNewMonitor || curOldMonitor))
|
||||||
|
{
|
||||||
|
_GLFWmonitor* lookAheadOldMonitor;
|
||||||
|
_GLFWmonitor* lookAheadNewMonitor;
|
||||||
|
|
||||||
|
if (curOldMonitor && curNewMonitor && !strcmp(curOldMonitor->name, curOldMonitor->name))
|
||||||
|
{
|
||||||
|
curNewMonitor = curNewMonitor->next;
|
||||||
|
curOldMonitor = curOldMonitor->next;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (curNewMonitor && !curOldMonitor)
|
||||||
|
{
|
||||||
|
_glfwLibrary.monitorCallback(curNewMonitor, GLFW_MONITOR_CONNECTED);
|
||||||
|
curNewMonitor = curNewMonitor->next;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!curNewMonitor && curOldMonitor)
|
||||||
|
{
|
||||||
|
_glfwLibrary.monitorCallback(curOldMonitor, GLFW_MONITOR_DISCONNECTED);
|
||||||
|
curOldMonitor = curOldMonitor->next;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
lookAheadOldMonitor = curOldMonitor->next;
|
||||||
|
lookAheadNewMonitor = curNewMonitor->next;
|
||||||
|
|
||||||
|
while (lookAheadOldMonitor && !strcmp(curNewMonitor->name, lookAheadOldMonitor->name))
|
||||||
|
lookAheadOldMonitor = lookAheadOldMonitor->next;
|
||||||
|
|
||||||
|
while (lookAheadNewMonitor && !strcmp(curOldMonitor->name, lookAheadNewMonitor->name))
|
||||||
|
lookAheadNewMonitor = lookAheadNewMonitor->next;
|
||||||
|
|
||||||
|
if (!lookAheadOldMonitor)
|
||||||
|
{
|
||||||
|
// nothing found in the old monitor list, that matches the current new monitor.
|
||||||
|
_glfwLibrary.monitorCallback(curNewMonitor, GLFW_MONITOR_CONNECTED);
|
||||||
|
curNewMonitor = curNewMonitor->next;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
while (strcmp(curOldMonitor->name, lookAheadOldMonitor->name))
|
||||||
|
{
|
||||||
|
_glfwLibrary.monitorCallback(curOldMonitor, GLFW_MONITOR_DISCONNECTED);
|
||||||
|
curOldMonitor = curOldMonitor->next;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!lookAheadNewMonitor)
|
||||||
|
{
|
||||||
|
// nothing found in the new monitor list, that matches the current old monitor.
|
||||||
|
_glfwLibrary.monitorCallback(curOldMonitor, GLFW_MONITOR_DISCONNECTED);
|
||||||
|
curOldMonitor = curOldMonitor->next;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
while (strcmp(curNewMonitor->name, lookAheadNewMonitor->name))
|
||||||
|
{
|
||||||
|
_glfwLibrary.monitorCallback(curNewMonitor, GLFW_MONITOR_CONNECTED);
|
||||||
|
curNewMonitor = curNewMonitor->next;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
_glfwTerminateMonitors();
|
||||||
|
_glfwLibrary.monitorListHead = newMonitorList;
|
||||||
|
}
|
||||||
|
|
||||||
|
//========================================================================
|
||||||
|
// Delete the monitor list.
|
||||||
|
//========================================================================
|
||||||
|
|
||||||
|
void _glfwTerminateMonitors(void)
|
||||||
|
{
|
||||||
|
while (_glfwLibrary.monitorListHead)
|
||||||
|
_glfwLibrary.monitorListHead = _glfwDestroyMonitor(_glfwLibrary.monitorListHead);
|
||||||
|
}
|
||||||
|
|
||||||
|
@ -229,7 +229,7 @@ int _glfwPlatformGetVideoModes(_GLFWmonitor* monitor, GLFWvidmode* list, int ma
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (list && maxcount)
|
if (list && maxcount)
|
||||||
memcpy(list, vidModes, sizeof(GLFWvidmode) * min(vidModesCount, maxcount));
|
memcpy(list, vidModes, sizeof(GLFWvidmode) * ((vidModesCount < maxcount) ? vidModesCount : maxcount));
|
||||||
|
|
||||||
free(vidModes);
|
free(vidModes);
|
||||||
|
|
||||||
|
@ -38,6 +38,11 @@
|
|||||||
#define EDS_ROTATEDMODE 0x00000004
|
#define EDS_ROTATEDMODE 0x00000004
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
// The MinGW upstream lacks this
|
||||||
|
#ifndef DISPLAY_DEVICE_ACTIVE
|
||||||
|
#define DISPLAY_DEVICE_ACTIVE 0x00000001
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////////
|
||||||
////// GLFW platform API //////
|
////// GLFW platform API //////
|
||||||
@ -83,29 +88,21 @@ _GLFWmonitor* _glfwDestroyMonitor(_GLFWmonitor* monitor)
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
// todo: This is ugly. The platform should only allocate a list of the current devices.
|
_GLFWmonitor* _glfwCreateMonitors(void)
|
||||||
// The platform independent code should be in charge of the handling for the initial
|
|
||||||
// setup, refreshing and freeing the list.
|
|
||||||
void _glfwInitMonitors(void)
|
|
||||||
{
|
{
|
||||||
_GLFWmonitor** curMonitor;
|
|
||||||
|
|
||||||
DISPLAY_DEVICE adapter;
|
DISPLAY_DEVICE adapter;
|
||||||
DWORD adapterNum;
|
DWORD adapterNum;
|
||||||
|
|
||||||
DISPLAY_DEVICE monitor;
|
DISPLAY_DEVICE monitor;
|
||||||
|
|
||||||
DEVMODE setting;
|
DEVMODE setting;
|
||||||
DWORD settingNum;
|
_GLFWmonitor* monitorList;
|
||||||
|
_GLFWmonitor** curMonitor;
|
||||||
curMonitor = &_glfwLibrary.monitorListHead;
|
|
||||||
|
|
||||||
adapter.cb = sizeof(DISPLAY_DEVICE);
|
adapter.cb = sizeof(DISPLAY_DEVICE);
|
||||||
adapterNum = 0;
|
adapterNum = 0;
|
||||||
|
|
||||||
monitor.cb = sizeof(DISPLAY_DEVICE);
|
monitor.cb = sizeof(DISPLAY_DEVICE);
|
||||||
setting.dmSize = sizeof(DEVMODE);
|
setting.dmSize = sizeof(DEVMODE);
|
||||||
settingNum = 0;
|
monitorList = NULL;
|
||||||
|
curMonitor = &monitorList;
|
||||||
|
|
||||||
while (EnumDisplayDevices(NULL, adapterNum++, &adapter, 0))
|
while (EnumDisplayDevices(NULL, adapterNum++, &adapter, 0))
|
||||||
{
|
{
|
||||||
@ -121,111 +118,7 @@ void _glfwInitMonitors(void)
|
|||||||
|
|
||||||
curMonitor = _glfwCreateMonitor(curMonitor, &adapter, &monitor, &setting);
|
curMonitor = _glfwCreateMonitor(curMonitor, &adapter, &monitor, &setting);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
return monitorList;
|
||||||
void _glfwRefreshMonitors(void)
|
|
||||||
{
|
|
||||||
DISPLAY_DEVICE adapter;
|
|
||||||
DWORD adapterNum = 0;
|
|
||||||
|
|
||||||
DISPLAY_DEVICE monitor;
|
|
||||||
|
|
||||||
DEVMODE setting;
|
|
||||||
|
|
||||||
_GLFWmonitor* newMonitorList = NULL;
|
|
||||||
_GLFWmonitor** curMonitor = &newMonitorList;
|
|
||||||
|
|
||||||
_GLFWmonitor* curNewMonitor;
|
|
||||||
_GLFWmonitor* curOldMonitor;
|
|
||||||
|
|
||||||
while (EnumDisplayDevices(NULL, adapterNum++, &adapter, 0))
|
|
||||||
{
|
|
||||||
if (adapter.StateFlags & DISPLAY_DEVICE_MIRRORING_DRIVER || !(adapter.StateFlags & DISPLAY_DEVICE_ACTIVE))
|
|
||||||
continue;
|
|
||||||
|
|
||||||
EnumDisplaySettingsEx(adapter.DeviceName, ENUM_CURRENT_SETTINGS, &setting, EDS_ROTATEDMODE);
|
|
||||||
|
|
||||||
EnumDisplayDevices(adapter.DeviceName, 0, &monitor, 0);
|
|
||||||
|
|
||||||
curMonitor = _glfwCreateMonitor(curMonitor, &adapter, &monitor, &setting);
|
|
||||||
}
|
|
||||||
|
|
||||||
curNewMonitor = newMonitorList;
|
|
||||||
curOldMonitor = _glfwLibrary.monitorListHead;
|
|
||||||
|
|
||||||
while (_glfwLibrary.monitorCallback && (curNewMonitor || curOldMonitor))
|
|
||||||
{
|
|
||||||
_GLFWmonitor* lookAheadOldMonitor;
|
|
||||||
_GLFWmonitor* lookAheadNewMonitor;
|
|
||||||
|
|
||||||
if (curOldMonitor && curNewMonitor && !strcmp(curOldMonitor->name, curOldMonitor->name))
|
|
||||||
{
|
|
||||||
curNewMonitor = curNewMonitor->next;
|
|
||||||
curOldMonitor = curOldMonitor->next;
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (curNewMonitor && !curOldMonitor)
|
|
||||||
{
|
|
||||||
_glfwLibrary.monitorCallback(curNewMonitor, GLFW_MONITOR_CONNECTED);
|
|
||||||
curNewMonitor = curNewMonitor->next;
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!curNewMonitor && curOldMonitor)
|
|
||||||
{
|
|
||||||
_glfwLibrary.monitorCallback(curOldMonitor, GLFW_MONITOR_DISCONNECTED);
|
|
||||||
curOldMonitor = curOldMonitor->next;
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
lookAheadOldMonitor = curOldMonitor->next;
|
|
||||||
lookAheadNewMonitor = curNewMonitor->next;
|
|
||||||
|
|
||||||
while (lookAheadOldMonitor && !strcmp(curNewMonitor->name, lookAheadOldMonitor->name))
|
|
||||||
lookAheadOldMonitor = lookAheadOldMonitor->next;
|
|
||||||
|
|
||||||
while (lookAheadNewMonitor && !strcmp(curOldMonitor->name, lookAheadNewMonitor->name))
|
|
||||||
lookAheadNewMonitor = lookAheadNewMonitor->next;
|
|
||||||
|
|
||||||
if (!lookAheadOldMonitor)
|
|
||||||
{
|
|
||||||
// nothing found in the old monitor list, that matches the current new monitor.
|
|
||||||
_glfwLibrary.monitorCallback(curNewMonitor, GLFW_MONITOR_CONNECTED);
|
|
||||||
curNewMonitor = curNewMonitor->next;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
while (strcmp(curOldMonitor->name, lookAheadOldMonitor->name))
|
|
||||||
{
|
|
||||||
_glfwLibrary.monitorCallback(curOldMonitor, GLFW_MONITOR_DISCONNECTED);
|
|
||||||
curOldMonitor = curOldMonitor->next;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!lookAheadNewMonitor)
|
|
||||||
{
|
|
||||||
// nothing found in the new monitor list, that matches the current old monitor.
|
|
||||||
_glfwLibrary.monitorCallback(curOldMonitor, GLFW_MONITOR_DISCONNECTED);
|
|
||||||
curOldMonitor = curOldMonitor->next;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
while (strcmp(curNewMonitor->name, lookAheadNewMonitor->name))
|
|
||||||
{
|
|
||||||
_glfwLibrary.monitorCallback(curNewMonitor, GLFW_MONITOR_CONNECTED);
|
|
||||||
curNewMonitor = curNewMonitor->next;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
_glfwTerminateMonitors();
|
|
||||||
_glfwLibrary.monitorListHead = newMonitorList;
|
|
||||||
}
|
|
||||||
|
|
||||||
void _glfwTerminateMonitors(void)
|
|
||||||
{
|
|
||||||
while (_glfwLibrary.monitorListHead)
|
|
||||||
_glfwLibrary.monitorListHead = _glfwDestroyMonitor(_glfwLibrary.monitorListHead);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -49,7 +49,7 @@
|
|||||||
|
|
||||||
#include <windows.h>
|
#include <windows.h>
|
||||||
#include <mmsystem.h>
|
#include <mmsystem.h>
|
||||||
#include <Dbt.h>
|
#include <dbt.h>
|
||||||
|
|
||||||
// This path may need to be changed if you build GLFW using your own setup
|
// This path may need to be changed if you build GLFW using your own setup
|
||||||
// We ship and use our own copy of wglext.h since GLFW uses fairly new
|
// We ship and use our own copy of wglext.h since GLFW uses fairly new
|
||||||
@ -339,9 +339,8 @@ typedef struct _GLFWmonitorWin32
|
|||||||
void _glfwInitTimer(void);
|
void _glfwInitTimer(void);
|
||||||
|
|
||||||
// Monitor support
|
// Monitor support
|
||||||
void _glfwInitMonitors(void);
|
_GLFWmonitor* _glfwCreateMonitors(void);
|
||||||
void _glfwRefreshMonitors(void);
|
_GLFWmonitor* _glfwDestroyMonitor(_GLFWmonitor* monitor);
|
||||||
void _glfwTerminateMonitors(void);
|
|
||||||
|
|
||||||
// Fullscreen support
|
// Fullscreen support
|
||||||
void _glfwSetVideoMode(int* width, int* height,
|
void _glfwSetVideoMode(int* width, int* height,
|
||||||
|
@ -77,9 +77,11 @@ _GLFWmonitor* _glfwDestroyMonitor(_GLFWmonitor* monitor)
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
void _glfwInitMonitors(void)
|
_GLFWmonitor* _glfwCreateMonitors(void)
|
||||||
{
|
{
|
||||||
_glfwLibrary.monitorListHead = NULL;
|
_GLFWmonitor* monitorList;
|
||||||
|
|
||||||
|
monitorList = NULL;
|
||||||
|
|
||||||
if (_glfwLibrary.X11.RandR.available)
|
if (_glfwLibrary.X11.RandR.available)
|
||||||
{
|
{
|
||||||
@ -88,7 +90,7 @@ void _glfwInitMonitors(void)
|
|||||||
int outputIDX;
|
int outputIDX;
|
||||||
_GLFWmonitor** curMonitor;
|
_GLFWmonitor** curMonitor;
|
||||||
|
|
||||||
curMonitor = &_glfwLibrary.monitorListHead;
|
curMonitor = &monitorList;
|
||||||
|
|
||||||
resources = XRRGetScreenResources(_glfwLibrary.X11.display,
|
resources = XRRGetScreenResources(_glfwLibrary.X11.display,
|
||||||
_glfwLibrary.X11.root);
|
_glfwLibrary.X11.root);
|
||||||
@ -126,11 +128,7 @@ void _glfwInitMonitors(void)
|
|||||||
}
|
}
|
||||||
#endif /*_GLFW_HAS_XRANDR*/
|
#endif /*_GLFW_HAS_XRANDR*/
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
return monitorList;
|
||||||
void _glfwTerminateMonitors(void)
|
|
||||||
{
|
|
||||||
while (_glfwLibrary.monitorListHead)
|
|
||||||
_glfwLibrary.monitorListHead = _glfwDestroyMonitor(_glfwLibrary.monitorListHead);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -275,8 +275,8 @@ void _glfwInitJoysticks(void);
|
|||||||
void _glfwTerminateJoysticks(void);
|
void _glfwTerminateJoysticks(void);
|
||||||
|
|
||||||
// Monitors
|
// Monitors
|
||||||
void _glfwInitMonitors(void);
|
_GLFWmonitor* _glfwCreateMonitors(void);
|
||||||
void _glfwTerminateMonitors(void);
|
_GLFWmonitor* _glfwDestroyMonitor(_GLFWmonitor* monitor);
|
||||||
|
|
||||||
// Unicode support
|
// Unicode support
|
||||||
long _glfwKeySym2Unicode(KeySym keysym);
|
long _glfwKeySym2Unicode(KeySym keysym);
|
||||||
|
@ -1372,6 +1372,7 @@ static void processSingleEvent(void)
|
|||||||
{
|
{
|
||||||
// Show XRandR that we really care
|
// Show XRandR that we really care
|
||||||
XRRUpdateConfiguration(&event);
|
XRRUpdateConfiguration(&event);
|
||||||
|
_glfwRefreshMonitors();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1429,18 +1430,18 @@ int _glfwPlatformOpenWindow(_GLFWwindow* window,
|
|||||||
if (!createWindow(window, wndconfig))
|
if (!createWindow(window, wndconfig))
|
||||||
return GL_FALSE;
|
return GL_FALSE;
|
||||||
|
|
||||||
if (wndconfig->mode == GLFW_FULLSCREEN)
|
|
||||||
{
|
|
||||||
#if defined(_GLFW_HAS_XRANDR)
|
#if defined(_GLFW_HAS_XRANDR)
|
||||||
// Request screen change notifications
|
// Request screen change notifications
|
||||||
if (_glfwLibrary.X11.RandR.available)
|
if (_glfwLibrary.X11.RandR.available)
|
||||||
{
|
{
|
||||||
XRRSelectInput(_glfwLibrary.X11.display,
|
XRRSelectInput(_glfwLibrary.X11.display,
|
||||||
window->X11.handle,
|
window->X11.handle,
|
||||||
RRScreenChangeNotifyMask);
|
RRScreenChangeNotifyMask);
|
||||||
}
|
}
|
||||||
#endif /*_GLFW_HAS_XRANDR*/
|
#endif /*_GLFW_HAS_XRANDR*/
|
||||||
|
|
||||||
|
if (wndconfig->mode == GLFW_FULLSCREEN)
|
||||||
|
{
|
||||||
enterFullscreenMode(window);
|
enterFullscreenMode(window);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -339,7 +339,7 @@ static void char_callback(GLFWwindow window, int character)
|
|||||||
|
|
||||||
void monitor_callback(GLFWmonitor monitor, int event)
|
void monitor_callback(GLFWmonitor monitor, int event)
|
||||||
{
|
{
|
||||||
printf("%08x at %0.3f: Monitor %s %s",
|
printf("%08x at %0.3f: Monitor %s %s\n",
|
||||||
counter++,
|
counter++,
|
||||||
glfwGetTime(),
|
glfwGetTime(),
|
||||||
glfwGetMonitorString(monitor, GLFW_MONITOR_NAME),
|
glfwGetMonitorString(monitor, GLFW_MONITOR_NAME),
|
||||||
|
Loading…
Reference in New Issue
Block a user