Implemented display iteration for x11. Added attributes and queries for physical size, name and logical position. Updated test executable.
parent
b7d1d35c20
commit
beacbb3447
9 changed files with 315 additions and 12 deletions
@ -0,0 +1,111 @@ |
|||||||
|
//========================================================================
|
||||||
|
// GLFW - An OpenGL framework
|
||||||
|
// Platform: Any
|
||||||
|
// API version: 3.0
|
||||||
|
// WWW: http://www.glfw.org/
|
||||||
|
//------------------------------------------------------------------------
|
||||||
|
// Copyright (c) 2002-2006 Marcus Geelnard
|
||||||
|
// Copyright (c) 2006-2010 Camilla Berglund <elmindreda@elmindreda.org>
|
||||||
|
//
|
||||||
|
// This software is provided 'as-is', without any express or implied
|
||||||
|
// warranty. In no event will the authors be held liable for any damages
|
||||||
|
// arising from the use of this software.
|
||||||
|
//
|
||||||
|
// Permission is granted to anyone to use this software for any purpose,
|
||||||
|
// including commercial applications, and to alter it and redistribute it
|
||||||
|
// freely, subject to the following restrictions:
|
||||||
|
//
|
||||||
|
// 1. The origin of this software must not be misrepresented; you must not
|
||||||
|
// claim that you wrote the original software. If you use this software
|
||||||
|
// in a product, an acknowledgment in the product documentation would
|
||||||
|
// be appreciated but is not required.
|
||||||
|
//
|
||||||
|
// 2. Altered source versions must be plainly marked as such, and must not
|
||||||
|
// be misrepresented as being the original software.
|
||||||
|
//
|
||||||
|
// 3. This notice may not be removed or altered from any source
|
||||||
|
// distribution.
|
||||||
|
//
|
||||||
|
//========================================================================
|
||||||
|
|
||||||
|
#include "internal.h" |
||||||
|
|
||||||
|
|
||||||
|
//========================================================================
|
||||||
|
// Get a list of connected displays
|
||||||
|
//========================================================================
|
||||||
|
|
||||||
|
GLFWAPI GLFWdisplay glfwGetNextDisplay(GLFWdisplay iterator) |
||||||
|
{ |
||||||
|
GLFWdisplay result = GLFW_DISPLAY_INVALID_HANDLE; |
||||||
|
if (!_glfwInitialized) |
||||||
|
{ |
||||||
|
_glfwSetError(GLFW_NOT_INITIALIZED, NULL); |
||||||
|
return result; |
||||||
|
} |
||||||
|
|
||||||
|
if (iterator == GLFW_DISPLAY_INVALID_HANDLE) |
||||||
|
{ |
||||||
|
result = _glfwLibrary.displayListHead; |
||||||
|
} |
||||||
|
else |
||||||
|
{ |
||||||
|
result = iterator->next; |
||||||
|
} |
||||||
|
return result; |
||||||
|
} |
||||||
|
|
||||||
|
GLFWAPI int glfwGetDisplayIntegerParam(GLFWdisplay display, int param) |
||||||
|
{ |
||||||
|
if (!_glfwInitialized) |
||||||
|
{ |
||||||
|
_glfwSetError(GLFW_NOT_INITIALIZED, NULL); |
||||||
|
return 0; |
||||||
|
} |
||||||
|
|
||||||
|
if (display == GLFW_DISPLAY_INVALID_HANDLE) |
||||||
|
{ |
||||||
|
_glfwSetError(GLFW_INVALID_VALUE, "Display handle is invalid."); |
||||||
|
return 0; |
||||||
|
} |
||||||
|
|
||||||
|
switch(param) |
||||||
|
{ |
||||||
|
case GLFW_DISPLAY_PARAM_I_PHYS_WIDTH: |
||||||
|
return display->physicalWidth; |
||||||
|
case GLFW_DISPLAY_PARAM_I_PHYS_HEIGHT: |
||||||
|
return display->physicalHeight; |
||||||
|
case GLFW_DISPLAY_PARAM_I_SCREEN_X_POS: |
||||||
|
return display->screenXPosition; |
||||||
|
case GLFW_DISPLAY_PARAM_I_SCREEN_Y_POS: |
||||||
|
return display->screenYPosition; |
||||||
|
default: |
||||||
|
_glfwSetError(GLFW_INVALID_ENUM, "Param represents not a valid integer display attribute."); |
||||||
|
return 0; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
GLFWAPI const char* glfwGetDisplayStringParam(GLFWdisplay display, int param) |
||||||
|
{ |
||||||
|
if (!_glfwInitialized) |
||||||
|
{ |
||||||
|
_glfwSetError(GLFW_NOT_INITIALIZED, NULL); |
||||||
|
return NULL; |
||||||
|
} |
||||||
|
|
||||||
|
if (display == GLFW_DISPLAY_INVALID_HANDLE) |
||||||
|
{ |
||||||
|
_glfwSetError(GLFW_INVALID_VALUE, "display handle is invalid."); |
||||||
|
return NULL; |
||||||
|
} |
||||||
|
|
||||||
|
switch(param) |
||||||
|
{ |
||||||
|
case GLFW_DISPLAY_PARAM_S_NAME: |
||||||
|
return display->deviceName; |
||||||
|
default: |
||||||
|
_glfwSetError(GLFW_INVALID_ENUM, "Param represents not a valid string display attribute."); |
||||||
|
return NULL; |
||||||
|
} |
||||||
|
} |
||||||
|
|
@ -0,0 +1,121 @@ |
|||||||
|
//========================================================================
|
||||||
|
// GLFW - An OpenGL library
|
||||||
|
// Platform: X11 (Unix)
|
||||||
|
// API version: 3.0
|
||||||
|
// WWW: http://www.glfw.org/
|
||||||
|
//------------------------------------------------------------------------
|
||||||
|
// Copyright (c) 2002-2006 Marcus Geelnard
|
||||||
|
// Copyright (c) 2006-2010 Camilla Berglund <elmindreda@elmindreda.org>
|
||||||
|
//
|
||||||
|
// This software is provided 'as-is', without any express or implied
|
||||||
|
// warranty. In no event will the authors be held liable for any damages
|
||||||
|
// arising from the use of this software.
|
||||||
|
//
|
||||||
|
// Permission is granted to anyone to use this software for any purpose,
|
||||||
|
// including commercial applications, and to alter it and redistribute it
|
||||||
|
// freely, subject to the following restrictions:
|
||||||
|
//
|
||||||
|
// 1. The origin of this software must not be misrepresented; you must not
|
||||||
|
// claim that you wrote the original software. If you use this software
|
||||||
|
// in a product, an acknowledgment in the product documentation would
|
||||||
|
// be appreciated but is not required.
|
||||||
|
//
|
||||||
|
// 2. Altered source versions must be plainly marked as such, and must not
|
||||||
|
// be misrepresented as being the original software.
|
||||||
|
//
|
||||||
|
// 3. This notice may not be removed or altered from any source
|
||||||
|
// distribution.
|
||||||
|
//
|
||||||
|
//========================================================================
|
||||||
|
|
||||||
|
#include "internal.h" |
||||||
|
|
||||||
|
#include <stdlib.h> |
||||||
|
#include <string.h> |
||||||
|
|
||||||
|
|
||||||
|
//////////////////////////////////////////////////////////////////////////
|
||||||
|
////// GLFW platform API //////
|
||||||
|
//////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
_GLFWdisplay** _glfwCreateDisplay(_GLFWdisplay** current, XRROutputInfo* outputInfo, XRRCrtcInfo* crtcInfo) |
||||||
|
{ |
||||||
|
*current = _glfwMalloc(sizeof(_GLFWdisplay)); |
||||||
|
memset(*current, 0, sizeof(_GLFWdisplay)); |
||||||
|
|
||||||
|
(*current)->physicalWidth = outputInfo->mm_width; |
||||||
|
(*current)->physicalHeight = outputInfo->mm_height; |
||||||
|
|
||||||
|
memcpy((*current)->deviceName, outputInfo->name, GLFW_DISPLAY_PARAM_S_NAME_LEN+1); |
||||||
|
(*current)->deviceName[GLFW_DISPLAY_PARAM_S_NAME_LEN] = '\0'; |
||||||
|
|
||||||
|
(*current)->screenXPosition = crtcInfo->x; |
||||||
|
(*current)->screenYPosition = crtcInfo->y; |
||||||
|
return &((*current)->next); |
||||||
|
} |
||||||
|
|
||||||
|
_GLFWdisplay* _glfwDestroyDisplay(_GLFWdisplay* display) |
||||||
|
{ |
||||||
|
_GLFWdisplay* result; |
||||||
|
|
||||||
|
result = display->next; |
||||||
|
|
||||||
|
_glfwFree(display); |
||||||
|
|
||||||
|
return result; |
||||||
|
} |
||||||
|
|
||||||
|
void _glfwInitDisplays(void) |
||||||
|
{ |
||||||
|
if(_glfwLibrary.X11.RandR.available == GL_TRUE) |
||||||
|
{ |
||||||
|
XRRScreenResources* resources; |
||||||
|
int outputIDX; |
||||||
|
_GLFWdisplay** curDisplay; |
||||||
|
|
||||||
|
curDisplay = &_glfwLibrary.displayListHead; |
||||||
|
|
||||||
|
resources = XRRGetScreenResources(_glfwLibrary.X11.display, |
||||||
|
_glfwLibrary.X11.root); |
||||||
|
|
||||||
|
for(outputIDX = 0; outputIDX < resources->noutput; outputIDX++) |
||||||
|
{ |
||||||
|
// physical device
|
||||||
|
XRROutputInfo* outputInfo = NULL; |
||||||
|
// logical surface
|
||||||
|
XRRCrtcInfo* crtcInfo = NULL; |
||||||
|
int crtcIDX; |
||||||
|
|
||||||
|
outputInfo = XRRGetOutputInfo(_glfwLibrary.X11.display, |
||||||
|
resources, |
||||||
|
resources->outputs[outputIDX]); |
||||||
|
|
||||||
|
if(outputInfo->connection == RR_Connected) |
||||||
|
{ |
||||||
|
for(crtcIDX = 0; crtcIDX < outputInfo->ncrtc; crtcIDX++) |
||||||
|
{ |
||||||
|
if(outputInfo->crtc == outputInfo->crtcs[crtcIDX]) |
||||||
|
{ |
||||||
|
crtcInfo = XRRGetCrtcInfo(_glfwLibrary.X11.display, |
||||||
|
resources, |
||||||
|
outputInfo->crtcs[crtcIDX]); |
||||||
|
break; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
curDisplay = _glfwCreateDisplay(curDisplay, outputInfo, crtcInfo); |
||||||
|
|
||||||
|
XRRFreeCrtcInfo(crtcInfo); |
||||||
|
} |
||||||
|
|
||||||
|
XRRFreeOutputInfo(outputInfo); |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
void _glfwTerminateDisplays(void) |
||||||
|
{ |
||||||
|
while(_glfwLibrary.displayListHead) |
||||||
|
_glfwLibrary.displayListHead = _glfwDestroyDisplay(_glfwLibrary.displayListHead); |
||||||
|
} |
||||||
|
|
Loading…
Reference in New Issue