فهرست منبع

Apply patch for issue #219

José Romero 14 سال پیش
والد
کامیت
dc2d87a90f

+ 7 - 0
src/modules/graphics/opengl/SpriteBatch.cpp

@@ -171,6 +171,13 @@ namespace opengl
 		glBindBuffer(GL_ARRAY_BUFFER, 0);
 	}
 
+	void SpriteBatch::setImage(Image * newimage)
+	{
+		image->release();
+		image = newimage;
+		image->retain();
+	}
+
 	void SpriteBatch::draw(float x, float y, float angle, float sx, float sy, float ox, float oy) const
 	{
 		static Matrix t;

+ 2 - 0
src/modules/graphics/opengl/SpriteBatch.h

@@ -96,6 +96,8 @@ namespace opengl
 		void * lock();
 		void unlock();
 
+		void setImage(Image * newimage);
+
 		// Implements Drawable.
 		void draw(float x, float y, float angle, float sx, float sy, float ox, float oy) const;
 

+ 10 - 1
src/modules/graphics/opengl/wrap_SpriteBatch.cpp

@@ -81,12 +81,21 @@ namespace opengl
 		return 0;
 	}
 
+	int w_SpriteBatch_setImage(lua_State * L)
+	{
+		SpriteBatch * t = luax_checkspritebatch(L, 1);
+		Image * image = luax_checktype<Image>(L, 2, "Image", GRAPHICS_IMAGE_T);
+		t->setImage(image);
+		return 0;
+	}
+
 	static const luaL_Reg functions[] = {
 		{ "add", w_SpriteBatch_add },
 		{ "addq", w_SpriteBatch_addq },
 		{ "clear", w_SpriteBatch_clear },
 		{ "lock", w_SpriteBatch_lock },
 		{ "unlock", w_SpriteBatch_unlock },
+		{ "setImage", w_SpriteBatch_setImage },
 		{ 0, 0 }
 	};
 
@@ -97,4 +106,4 @@ namespace opengl
 
 } // opengl
 } // graphics
-} // love
+} // love

+ 2 - 0
src/modules/graphics/opengl/wrap_SpriteBatch.h

@@ -36,6 +36,8 @@ namespace opengl
 	int w_SpriteBatch_clear(lua_State * L);
 	int w_SpriteBatch_lock(lua_State * L);
 	int w_SpriteBatch_unlock(lua_State * L);
+	int w_SpriteBatch_setImage(lua_State * L);
+
 	int luaopen_spritebatch(lua_State * L);
 
 } // opengl