summaryrefslogtreecommitdiffhomepage
path: root/ext
diff options
context:
space:
mode:
authorTom Black <[email protected]>2016-10-09 15:35:13 -0400
committerTom Black <[email protected]>2016-10-09 15:35:13 -0400
commit922d47027ead7cec732e086880a3a8127c0b8cf6 (patch)
tree0e6e9a251e69fdb4936bd9c18df7b66c9172a78c /ext
parent31aebd27ec78e6b751d69d2fb360187270b1be00 (diff)
downloadruby2d-922d47027ead7cec732e086880a3a8127c0b8cf6.tar.gz
ruby2d-922d47027ead7cec732e086880a3a8127c0b8cf6.zip
Add sprites
Also namespace `type_id` definitions
Diffstat (limited to 'ext')
-rw-r--r--ext/ruby2d/ruby2d.c65
1 files changed, 56 insertions, 9 deletions
diff --git a/ext/ruby2d/ruby2d.c b/ext/ruby2d/ruby2d.c
index e426f0d..784ca7c 100644
--- a/ext/ruby2d/ruby2d.c
+++ b/ext/ruby2d/ruby2d.c
@@ -2,10 +2,11 @@
#include <simple2d.h>
// @type_id values for rendering
-#define TRIANGLE 1
-#define QUAD 2
-#define IMAGE 3
-#define TEXT 4
+#define R2D_TRIANGLE 1
+#define R2D_QUAD 2
+#define R2D_IMAGE 3
+#define R2D_SPRITE 4
+#define R2D_TEXT 5
// Ruby 2D window
static VALUE self;
@@ -22,6 +23,9 @@ static VALUE c_data_klass;
struct image_data {
S2D_Image *img;
};
+struct sprite_data {
+ S2D_Sprite *spr;
+};
struct text_data {
S2D_Text *txt;
};
@@ -58,6 +62,25 @@ static VALUE init_image(char *path) {
/*
+ * Free sprite structure attached to Ruby 2D `Sprite` class
+ */
+static void free_sprite(struct sprite_data *data) {
+ S2D_FreeSprite(data->spr);
+ xfree(data);
+}
+
+
+/*
+ * Initialize sprite structure data
+ */
+static VALUE init_sprite(char *path) {
+ struct sprite_data *data = ALLOC(struct sprite_data);
+ data->spr = S2D_CreateSprite(path);
+ return Data_Wrap_Struct(c_data_klass, NULL, free_sprite, data);
+}
+
+
+/*
* Free text structure attached to Ruby 2D `Text` class
*/
static void free_text(struct text_data *data) {
@@ -145,7 +168,7 @@ static void render() {
// Switch on the object's type_id
switch(type_id) {
- case TRIANGLE: {
+ case R2D_TRIANGLE: {
VALUE c1 = rb_iv_get(el, "@c1");
VALUE c2 = rb_iv_get(el, "@c2");
VALUE c3 = rb_iv_get(el, "@c3");
@@ -175,7 +198,7 @@ static void render() {
}
break;
- case QUAD: {
+ case R2D_QUAD: {
VALUE c1 = rb_iv_get(el, "@c1");
VALUE c2 = rb_iv_get(el, "@c2");
VALUE c3 = rb_iv_get(el, "@c3");
@@ -213,10 +236,10 @@ static void render() {
}
break;
- case IMAGE: {
+ case R2D_IMAGE: {
if (rb_iv_get(el, "@data") == Qnil) {
VALUE data = init_image(RSTRING_PTR(rb_iv_get(el, "@path")));
- rb_iv_set(el, "@data", data);
+ rb_iv_set(el, "@data", data);
}
struct image_data *data;
@@ -228,7 +251,31 @@ static void render() {
}
break;
- case TEXT: {
+ case R2D_SPRITE: {
+ if (rb_iv_get(el, "@data") == Qnil) {
+ VALUE data = init_sprite(RSTRING_PTR(rb_iv_get(el, "@path")));
+ rb_iv_set(el, "@data", data);
+ }
+
+ struct sprite_data *data;
+ Data_Get_Struct(rb_iv_get(el, "@data"), struct sprite_data, data);
+
+ data->spr->x = NUM2DBL(rb_iv_get(el, "@x"));
+ data->spr->y = NUM2DBL(rb_iv_get(el, "@y"));
+
+ S2D_ClipSprite(
+ data->spr,
+ NUM2INT(rb_iv_get(el, "@clip_x")),
+ NUM2INT(rb_iv_get(el, "@clip_y")),
+ NUM2INT(rb_iv_get(el, "@clip_w")),
+ NUM2INT(rb_iv_get(el, "@clip_h"))
+ );
+
+ S2D_DrawSprite(data->spr);
+ }
+ break;
+
+ case R2D_TEXT: {
if (rb_iv_get(el, "@data") == Qnil) {
VALUE data = init_text(
RSTRING_PTR(rb_iv_get(el, "@font")),