mirror of
https://github.com/italicsjenga/winit-sonoma-fix.git
synced 2025-01-11 13:31:29 +11:00
Add support for specific OpenGL version for Win32
This commit is contained in:
parent
13c73cce5e
commit
8c074af9fc
11
src/lib.rs
11
src/lib.rs
|
@ -29,6 +29,7 @@ pub struct WindowBuilder {
|
|||
dimensions: (uint, uint),
|
||||
title: String,
|
||||
monitor: Option<winimpl::MonitorID>,
|
||||
gl_version: Option<(uint, uint)>,
|
||||
}
|
||||
|
||||
impl WindowBuilder {
|
||||
|
@ -38,6 +39,7 @@ impl WindowBuilder {
|
|||
dimensions: (1024, 768),
|
||||
title: String::new(),
|
||||
monitor: None,
|
||||
gl_version: None,
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -57,6 +59,15 @@ impl WindowBuilder {
|
|||
self
|
||||
}
|
||||
|
||||
/// Requests to use a specific OpenGL version.
|
||||
///
|
||||
/// Version is a (major, minor) pair. For example to request OpenGL 3.3
|
||||
/// you would pass `(3, 3)`.
|
||||
pub fn with_gl_version(mut self, version: (uint, uint)) -> WindowBuilder {
|
||||
self.gl_version = Some(version);
|
||||
self
|
||||
}
|
||||
|
||||
/// Builds the window.
|
||||
///
|
||||
/// Error should be very rare and only occur in case of permission denied, incompatible system,
|
||||
|
|
|
@ -365,6 +365,17 @@ pub static VK_NONAME: WPARAM = 0xFC;
|
|||
pub static VK_PA1: WPARAM = 0xFD;
|
||||
pub static VK_OEM_CLEAR: WPARAM = 0xFE;
|
||||
|
||||
// ?
|
||||
pub static WGL_CONTEXT_DEBUG_BIT_ARB: libc::c_int = 0x00000001;
|
||||
pub static WGL_CONTEXT_FORWARD_COMPATIBLE_BIT_ARB: libc::c_int = 0x00000002;
|
||||
pub static WGL_CONTEXT_MAJOR_VERSION_ARB: libc::c_int = 0x2091;
|
||||
pub static WGL_CONTEXT_MINOR_VERSION_ARB: libc::c_int = 0x2092;
|
||||
pub static WGL_CONTEXT_LAYER_PLANE_ARB: libc::c_int = 0x2093;
|
||||
pub static WGL_CONTEXT_FLAGS_ARB: libc::c_int = 0x2094;
|
||||
pub static WGL_CONTEXT_PROFILE_MASK_ARB: libc::c_int = 0x9126;
|
||||
pub static WGL_CONTEXT_CORE_PROFILE_BIT_ARB: libc::c_int = 0x00000001;
|
||||
pub static WGL_CONTEXT_COMPATIBILITY_PROFILE_BIT_ARB: libc::c_int = 0x00000002;
|
||||
|
||||
// messages
|
||||
pub static WM_LBUTTONDOWN: UINT = 0x0201;
|
||||
pub static WM_LBUTTONUP: UINT = 0x0202;
|
||||
|
|
|
@ -250,14 +250,22 @@ pub fn new_window(builder: WindowBuilder) -> Result<Window, String> {
|
|||
let context = {
|
||||
use libc;
|
||||
|
||||
let attributes: [libc::c_int, ..1] = [
|
||||
0
|
||||
];
|
||||
let mut attributes = Vec::new();
|
||||
|
||||
if builder.gl_version.is_some() {
|
||||
let version = builder.gl_version.as_ref().unwrap();
|
||||
attributes.push(ffi::WGL_CONTEXT_MAJOR_VERSION_ARB);
|
||||
attributes.push(version.val0() as libc::c_int);
|
||||
attributes.push(ffi::WGL_CONTEXT_MINOR_VERSION_ARB);
|
||||
attributes.push(version.val1() as libc::c_int);
|
||||
}
|
||||
|
||||
attributes.push(0);
|
||||
|
||||
let ctxt = unsafe {
|
||||
match create_context_attribs {
|
||||
None => ffi::wglCreateContext(hdc),
|
||||
Some(ptr) => ptr(hdc, ptr::mut_null(), attributes.as_ptr())
|
||||
Some(ptr) => ptr(hdc, ptr::mut_null(), attributes.as_slice().as_ptr())
|
||||
}
|
||||
};
|
||||
|
||||
|
|
Loading…
Reference in a new issue