Merge pull request #139 from glennw/android-gles2

Add support for GLESv2 on android. Remove a few warnings.
This commit is contained in:
tomaka 2014-11-26 09:16:13 +01:00
commit 429874ed81
2 changed files with 25 additions and 12 deletions

View file

@ -1,7 +1,7 @@
#![allow(dead_code)]
#![allow(non_snake_case)]
#![allow(non_camel_case_types)]
#![allow(non_uppercase_statics)]
#![allow(non_upper_case_globals)]
use libc;

View file

@ -21,8 +21,6 @@ pub struct MonitorID;
mod ffi;
compile_warning!("The Android implementation is not fully working yet")
pub fn get_available_monitors() -> Vec<MonitorID> {
vec![ MonitorID ]
}
@ -47,7 +45,7 @@ pub struct HeadlessContext(int);
#[cfg(feature = "headless")]
impl HeadlessContext {
/// See the docs in the crate root file.
pub fn new(builder: HeadlessRendererBuilder) -> Result<HeadlessContext, CreationError> {
pub fn new(_builder: HeadlessRendererBuilder) -> Result<HeadlessContext, CreationError> {
unimplemented!()
}
@ -57,7 +55,7 @@ impl HeadlessContext {
}
/// See the docs in the crate root file.
pub fn get_proc_address(&self, addr: &str) -> *const () {
pub fn get_proc_address(&self, _addr: &str) -> *const () {
unimplemented!()
}
}
@ -98,13 +96,21 @@ impl Window {
android_glue::write_log("eglInitialize succeeded");
let use_gles2 = match builder.gl_version {
Some((2, 0)) => true,
_ => false,
};
let config = unsafe {
let attribute_list = [
ffi::egl::RED_SIZE as i32, 1,
ffi::egl::GREEN_SIZE as i32, 1,
ffi::egl::BLUE_SIZE as i32, 1,
ffi::egl::NONE as i32
];
let mut attribute_list = vec!();
if use_gles2 {
attribute_list.push_all([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]);
attribute_list.push(ffi::egl::NONE as i32);
let mut num_config: ffi::egl::types::EGLint = mem::uninitialized();
let mut config: ffi::egl::types::EGLConfig = mem::uninitialized();
@ -124,7 +130,14 @@ impl Window {
android_glue::write_log("eglChooseConfig succeeded");
let context = unsafe {
let context = ffi::egl::CreateContext(display, config, ptr::null(), ptr::null());
let mut context_attributes = vec!();
if use_gles2 {
context_attributes.push_all([ffi::egl::CONTEXT_CLIENT_VERSION as i32, 2]);
}
context_attributes.push(ffi::egl::NONE as i32);
let context = ffi::egl::CreateContext(display, config, ptr::null(),
context_attributes.as_ptr());
if context.is_null() {
return Err(OsError(format!("eglCreateContext failed")))
}