aboutsummaryrefslogtreecommitdiffstats
path: root/c_src
diff options
context:
space:
mode:
Diffstat (limited to 'c_src')
-rw-r--r--c_src/esdl2.h1
-rw-r--r--c_src/sdl_texture.c22
2 files changed, 23 insertions, 0 deletions
diff --git a/c_src/esdl2.h b/c_src/esdl2.h
index 6516bee..043789f 100644
--- a/c_src/esdl2.h
+++ b/c_src/esdl2.h
@@ -201,6 +201,7 @@
F(get_texture_blend_mode, 1) \
F(get_texture_color_mod, 1) \
F(set_texture_alpha_mod, 2) \
+ F(set_texture_blend_mode, 2) \
/* 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 350491f..b9ec140 100644
--- a/c_src/sdl_texture.c
+++ b/c_src/sdl_texture.c
@@ -150,3 +150,25 @@ NIF_FUNCTION(set_texture_alpha_mod)
return nif_thread_call(env, thread_set_texture_alpha_mod, 2,
NIF_RES_GET(Texture, texture_res), alpha);
}
+
+// set_texture_blend_mode
+
+NIF_CALL_HANDLER(thread_set_texture_blend_mode)
+{
+ if (SDL_SetTextureBlendMode(args[0], (long)args[1]))
+ return sdl_error_tuple(env);
+
+ return atom_ok;
+}
+
+NIF_FUNCTION(set_texture_blend_mode)
+{
+ void* texture_res;
+ SDL_BlendMode mode;
+
+ BADARG_IF(!enif_get_resource(env, argv[0], res_Texture, &texture_res));
+ BADARG_IF(!atom_to_blend_mode(env, argv[1], &mode));
+
+ return nif_thread_call(env, thread_set_texture_blend_mode, 2,
+ NIF_RES_GET(Texture, texture_res), mode);
+}