//======================================================================== // GLFW 3.1 Mir - www.glfw.org //------------------------------------------------------------------------ // Copyright (c) 2014 Brandon Schaefer // // 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 ////////////////////////////////////////////////////////////////////////// ////// GLFW platform API ////// ////////////////////////////////////////////////////////////////////////// _GLFWmonitor** _glfwPlatformGetMonitors(int* count) { int d, found = 0; MirDisplayConfiguration* display_config = mir_connection_create_display_config(_glfw.mir.connection); _GLFWmonitor** monitors = NULL; _GLFWmonitor* monitor = NULL; for (d = 0; d < display_config->num_outputs; d++) { MirDisplayOutput const* out = display_config->outputs + d; if (out->used && out->connected && out->num_modes && out->current_mode < out->num_modes) { found++; monitors = realloc(monitors, sizeof(_GLFWmonitor*) * found); monitor = _glfwAllocMonitor("Unknown", out->physical_width_mm, out->physical_height_mm); monitor->mir.x = out->position_x; monitor->mir.y = out->position_y; monitor->mir.output_id = out->output_id; monitor->mir.cur_mode = out->current_mode; monitors[d] = monitor; } } *count = found; mir_display_config_destroy(display_config); return monitors; } GLboolean _glfwPlatformIsSameMonitor(_GLFWmonitor* first, _GLFWmonitor* second) { return first->mir.output_id == second->mir.output_id; } void _glfwPlatformGetMonitorPos(_GLFWmonitor* monitor, int* xpos, int* ypos) { if (xpos) *xpos = monitor->mir.x; if (ypos) *ypos = monitor->mir.y; } GLFWvidmode* _glfwPlatformGetVideoModes(_GLFWmonitor* monitor, int* found) { int i; GLFWvidmode* modes = NULL; MirDisplayConfiguration* display_config = mir_connection_create_display_config(_glfw.mir.connection); for (i = 0; i < display_config->num_outputs; i++) { const MirDisplayOutput* out = display_config->outputs + i; if (out->output_id != monitor->mir.output_id) continue; modes = calloc(out->num_modes, sizeof(GLFWvidmode)); for (*found = 0; *found < out->num_modes; (*found)++) { modes[*found].width = out->modes[*found].horizontal_resolution; modes[*found].height = out->modes[*found].vertical_resolution; modes[*found].refreshRate = out->modes[*found].refresh_rate; modes[*found].redBits = 8; modes[*found].greenBits = 8; modes[*found].blueBits = 8; } break; } mir_display_config_destroy(display_config); return modes; } void _glfwPlatformGetVideoMode(_GLFWmonitor* monitor, GLFWvidmode* mode) { *mode = monitor->modes[monitor->mir.cur_mode]; } void _glfwPlatformGetGammaRamp(_GLFWmonitor* monitor, GLFWgammaramp* ramp) { _glfwInputError(GLFW_PLATFORM_ERROR, "Mir: Unsupported Function %s!\n", __PRETTY_FUNCTION__); } void _glfwPlatformSetGammaRamp(_GLFWmonitor* monitor, const GLFWgammaramp* ramp) { _glfwInputError(GLFW_PLATFORM_ERROR, "Mir: Unsupported Function %s!\n", __PRETTY_FUNCTION__); }