diff options
author | Loïc Hoguin <[email protected]> | 2014-04-07 21:23:36 +0200 |
---|---|---|
committer | Loïc Hoguin <[email protected]> | 2014-04-07 21:23:36 +0200 |
commit | 581fcdd640b918055c06bb9f96ae8a098cb340f7 (patch) | |
tree | 14d98e2cf7b724afbb98a5de34096c6f23cdb7ce | |
parent | 333823ed12461420d48ea8c1e47743fe22eaf32f (diff) | |
download | esdl2-581fcdd640b918055c06bb9f96ae8a098cb340f7.tar.gz esdl2-581fcdd640b918055c06bb9f96ae8a098cb340f7.tar.bz2 esdl2-581fcdd640b918055c06bb9f96ae8a098cb340f7.zip |
Add sdl_texture:get_color_mod/1
-rw-r--r-- | c_src/esdl2.h | 1 | ||||
-rw-r--r-- | c_src/sdl_texture.c | 29 | ||||
-rw-r--r-- | src/esdl2.erl | 4 | ||||
-rw-r--r-- | src/sdl_texture.erl | 8 |
4 files changed, 42 insertions, 0 deletions
diff --git a/c_src/esdl2.h b/c_src/esdl2.h index ac5c45c..b9289e5 100644 --- a/c_src/esdl2.h +++ b/c_src/esdl2.h @@ -199,6 +199,7 @@ F(create_texture_from_surface, 2) \ F(get_texture_alpha_mod, 1) \ F(get_texture_blend_mode, 1) \ + F(get_texture_color_mod, 1) \ /* sdl_version */ \ F(get_version, 0) \ F(get_revision, 0) \ diff --git a/c_src/sdl_texture.c b/c_src/sdl_texture.c index 04dc0f8..e421676 100644 --- a/c_src/sdl_texture.c +++ b/c_src/sdl_texture.c @@ -99,3 +99,32 @@ NIF_FUNCTION(get_texture_blend_mode) return nif_thread_call(env, thread_get_texture_blend_mode, 1, NIF_RES_GET(Texture, texture_res)); } + +// get_texture_color_mod + +NIF_CALL_HANDLER(thread_get_texture_color_mod) +{ + Uint8 r, g, b; + + if (SDL_GetTextureColorMod(args[0], &r, &g, &b)) + return sdl_error_tuple(env); + + return enif_make_tuple2(env, + atom_ok, + enif_make_tuple3(env, + enif_make_uint(env, r), + enif_make_uint(env, g), + enif_make_uint(env, b) + ) + ); +} + +NIF_FUNCTION(get_texture_color_mod) +{ + void* texture_res; + + BADARG_IF(!enif_get_resource(env, argv[0], res_Texture, &texture_res)); + + return nif_thread_call(env, thread_get_texture_color_mod, 1, + NIF_RES_GET(Texture, texture_res)); +} diff --git a/src/esdl2.erl b/src/esdl2.erl index f4c9b28..00f2273 100644 --- a/src/esdl2.erl +++ b/src/esdl2.erl @@ -89,6 +89,7 @@ -export([create_texture_from_surface/2]). -export([get_texture_alpha_mod/1]). -export([get_texture_blend_mode/1]). +-export([get_texture_color_mod/1]). %% sdl_version -export([get_version/0]). @@ -328,6 +329,9 @@ get_texture_alpha_mod(_) -> get_texture_blend_mode(_) -> erlang:nif_error({not_loaded, ?MODULE}). +get_texture_color_mod(_) -> + erlang:nif_error({not_loaded, ?MODULE}). + %% sdl_version get_version() -> diff --git a/src/sdl_texture.erl b/src/sdl_texture.erl index fa29d96..4412884 100644 --- a/src/sdl_texture.erl +++ b/src/sdl_texture.erl @@ -18,6 +18,7 @@ -export([create_from_surface/2]). -export([get_alpha_mod/1]). -export([get_blend_mode/1]). +-export([get_color_mod/1]). create_from_file(Renderer, Filename) -> {ok, Surface} = sdl_surface:load(Filename), @@ -40,3 +41,10 @@ get_blend_mode(Texture) -> {ok, Alpha} = Ret, Alpha end. + +get_color_mod(Texture) -> + esdl2:get_texture_color_mod(Texture), + receive {'_nif_thread_ret_', Ret} -> + {ok, Alpha} = Ret, + Alpha + end. |