Merge pull request #258 from ozkriff/android_color_and_depth_bits

android: Implemented color_bits and depth_bits
This commit is contained in:
tomaka 2015-02-08 08:03:26 +01:00
commit 98345b701f

View file

@ -115,18 +115,34 @@ impl Window {
_ => false, _ => false,
}; };
let config = unsafe {
let mut attribute_list = vec!(); let mut attribute_list = vec!();
if use_gles2 { if use_gles2 {
attribute_list.push_all(&[ffi::egl::RENDERABLE_TYPE as i32, attribute_list.push_all(&[
ffi::egl::OPENGL_ES2_BIT as i32]); ffi::egl::RENDERABLE_TYPE as i32,
ffi::egl::OPENGL_ES2_BIT as i32,
]);
} }
attribute_list.push_all(&[ffi::egl::RED_SIZE as i32, 1]);
attribute_list.push_all(&[ffi::egl::GREEN_SIZE as i32, 1]); {
attribute_list.push_all(&[ffi::egl::BLUE_SIZE as i32, 1]); let (red, green, blue) = match builder.color_bits.unwrap_or(24) {
attribute_list.push_all(&[ffi::egl::DEPTH_SIZE as i32, 1]); 24 => (8, 8, 8),
16 => (6, 5, 6),
_ => panic!("Bad color_bits"),
};
attribute_list.push_all(&[ffi::egl::RED_SIZE as i32, red]);
attribute_list.push_all(&[ffi::egl::GREEN_SIZE as i32, green]);
attribute_list.push_all(&[ffi::egl::BLUE_SIZE as i32, blue]);
}
attribute_list.push_all(&[
ffi::egl::DEPTH_SIZE as i32,
builder.depth_bits.unwrap_or(8) as i32,
]);
attribute_list.push(ffi::egl::NONE as i32); attribute_list.push(ffi::egl::NONE as i32);
let config = unsafe {
let mut num_config: ffi::egl::types::EGLint = mem::uninitialized(); let mut num_config: ffi::egl::types::EGLint = mem::uninitialized();
let mut config: ffi::egl::types::EGLConfig = mem::uninitialized(); let mut config: ffi::egl::types::EGLConfig = mem::uninitialized();
if ffi::egl::ChooseConfig(display, attribute_list.as_ptr(), &mut config, 1, if ffi::egl::ChooseConfig(display, attribute_list.as_ptr(), &mut config, 1,