|
@@ -1,5 +1,5 @@
|
|
|
#include "Graphics.h"
|
|
|
-#include "wrap_Framebuffer.h"
|
|
|
+#include "wrap_Canvas.h"
|
|
|
|
|
|
namespace love
|
|
|
{
|
|
@@ -7,44 +7,44 @@ namespace graphics
|
|
|
{
|
|
|
namespace opengl
|
|
|
{
|
|
|
- Framebuffer * luax_checkfbo(lua_State * L, int idx)
|
|
|
+ Canvas * luax_checkcanvas(lua_State * L, int idx)
|
|
|
{
|
|
|
- return luax_checktype<Framebuffer>(L, idx, "Framebuffer", GRAPHICS_FRAMEBUFFER_T);
|
|
|
+ return luax_checktype<Canvas>(L, idx, "Canvas", GRAPHICS_CANVAS_T);
|
|
|
}
|
|
|
|
|
|
- int w_Framebuffer_renderTo(lua_State * L)
|
|
|
+ int w_Canvas_renderTo(lua_State * L)
|
|
|
{
|
|
|
// As startGrab() clears the framebuffer, better not allow
|
|
|
// grabbing inside another grabbing
|
|
|
- if (Framebuffer::current != NULL) {
|
|
|
- Framebuffer::bindDefaultBuffer();
|
|
|
- return luaL_error(L, "Current render target not the default framebuffer!");
|
|
|
+ if (Canvas::current != NULL) {
|
|
|
+ Canvas::bindDefaultCanvas();
|
|
|
+ return luaL_error(L, "Current render target not the default canvas!");
|
|
|
}
|
|
|
|
|
|
- Framebuffer * fbo = luax_checkfbo(L, 1);
|
|
|
+ Canvas * canvas = luax_checkcanvas(L, 1);
|
|
|
if (!lua_isfunction(L, 2))
|
|
|
- return luaL_error(L, "Need a function to render to fbo");
|
|
|
+ return luaL_error(L, "Need a function to render to canvas.");
|
|
|
|
|
|
- fbo->startGrab();
|
|
|
+ canvas->startGrab();
|
|
|
lua_settop(L, 2); // make sure the function is on top of the stack
|
|
|
lua_call(L, 0, 0);
|
|
|
- fbo->stopGrab();
|
|
|
+ canvas->stopGrab();
|
|
|
|
|
|
return 0;
|
|
|
}
|
|
|
|
|
|
- int w_Framebuffer_getImageData(lua_State * L)
|
|
|
+ int w_Canvas_getImageData(lua_State * L)
|
|
|
{
|
|
|
- Framebuffer * fbo = luax_checkfbo(L, 1);
|
|
|
+ Canvas * canvas = luax_checkcanvas(L, 1);
|
|
|
love::image::Image * image = luax_getmodule<love::image::Image>(L, "image", MODULE_IMAGE_T);
|
|
|
- love::image::ImageData * img = fbo->getImageData( image );
|
|
|
+ love::image::ImageData * img = canvas->getImageData( image );
|
|
|
luax_newtype(L, "ImageData", IMAGE_IMAGE_DATA_T, (void *)img);
|
|
|
return 1;
|
|
|
}
|
|
|
|
|
|
- int w_Framebuffer_setFilter(lua_State * L)
|
|
|
+ int w_Canvas_setFilter(lua_State * L)
|
|
|
{
|
|
|
- Framebuffer * fbo = luax_checkfbo(L, 1);
|
|
|
+ Canvas * canvas = luax_checkcanvas(L, 1);
|
|
|
const char * minstr = luaL_checkstring(L, 2);
|
|
|
const char * magstr = luaL_checkstring(L, 3);
|
|
|
|
|
@@ -54,14 +54,14 @@ namespace opengl
|
|
|
if (!Image::getConstant(magstr, f.mag))
|
|
|
return luaL_error(L, "Invalid max filter mode: %s", magstr);
|
|
|
|
|
|
- fbo->setFilter(f);
|
|
|
+ canvas->setFilter(f);
|
|
|
return 0;
|
|
|
}
|
|
|
|
|
|
- int w_Framebuffer_getFilter(lua_State * L)
|
|
|
+ int w_Canvas_getFilter(lua_State * L)
|
|
|
{
|
|
|
- Framebuffer * fbo = luax_checkfbo(L, 1);
|
|
|
- Image::Filter f = fbo->getFilter();
|
|
|
+ Canvas * canvas = luax_checkcanvas(L, 1);
|
|
|
+ Image::Filter f = canvas->getFilter();
|
|
|
|
|
|
const char * minstr;
|
|
|
const char * magstr;
|
|
@@ -74,9 +74,9 @@ namespace opengl
|
|
|
return 2;
|
|
|
}
|
|
|
|
|
|
- int w_Framebuffer_setWrap(lua_State * L)
|
|
|
+ int w_Canvas_setWrap(lua_State * L)
|
|
|
{
|
|
|
- Framebuffer * fbo = luax_checkfbo(L, 1);
|
|
|
+ Canvas * canvas = luax_checkcanvas(L, 1);
|
|
|
const char * wrap_s = luaL_checkstring(L, 2);
|
|
|
const char * wrap_t = luaL_checkstring(L, 3);
|
|
|
|
|
@@ -86,14 +86,14 @@ namespace opengl
|
|
|
if (!Image::getConstant(wrap_t, w.t))
|
|
|
return luaL_error(L, "Invalid wrap mode: %s", wrap_t);
|
|
|
|
|
|
- fbo->setWrap(w);
|
|
|
+ canvas->setWrap(w);
|
|
|
return 0;
|
|
|
}
|
|
|
|
|
|
- int w_Framebuffer_getWrap(lua_State * L)
|
|
|
+ int w_Canvas_getWrap(lua_State * L)
|
|
|
{
|
|
|
- Framebuffer * fbo = luax_checkfbo(L, 1);
|
|
|
- Image::Wrap w = fbo->getWrap();
|
|
|
+ Canvas * canvas = luax_checkcanvas(L, 1);
|
|
|
+ Image::Wrap w = canvas->getWrap();
|
|
|
|
|
|
const char * wrap_s;
|
|
|
const char * wrap_t;
|
|
@@ -106,9 +106,9 @@ namespace opengl
|
|
|
return 2;
|
|
|
}
|
|
|
|
|
|
- int w_Framebuffer_clear(lua_State * L)
|
|
|
+ int w_Canvas_clear(lua_State * L)
|
|
|
{
|
|
|
- Framebuffer * fbo = luax_checkfbo(L, 1);
|
|
|
+ Canvas * canvas = luax_checkcanvas(L, 1);
|
|
|
Color c;
|
|
|
if (lua_isnoneornil(L, 2)) {
|
|
|
c.r = 0;
|
|
@@ -135,25 +135,25 @@ namespace opengl
|
|
|
c.b = (unsigned char)luaL_checkint(L, 4);
|
|
|
c.a = (unsigned char)luaL_optint(L, 5, 255);
|
|
|
}
|
|
|
- fbo->clear(c);
|
|
|
+ canvas->clear(c);
|
|
|
|
|
|
return 0;
|
|
|
}
|
|
|
|
|
|
static const luaL_Reg functions[] = {
|
|
|
- { "renderTo", w_Framebuffer_renderTo },
|
|
|
- { "getImageData", w_Framebuffer_getImageData },
|
|
|
- { "setFilter", w_Framebuffer_setFilter },
|
|
|
- { "getFilter", w_Framebuffer_getFilter },
|
|
|
- { "setWrap", w_Framebuffer_setWrap },
|
|
|
- { "getWrap", w_Framebuffer_getWrap },
|
|
|
- { "clear", w_Framebuffer_clear },
|
|
|
+ { "renderTo", w_Canvas_renderTo },
|
|
|
+ { "getImageData", w_Canvas_getImageData },
|
|
|
+ { "setFilter", w_Canvas_setFilter },
|
|
|
+ { "getFilter", w_Canvas_getFilter },
|
|
|
+ { "setWrap", w_Canvas_setWrap },
|
|
|
+ { "getWrap", w_Canvas_getWrap },
|
|
|
+ { "clear", w_Canvas_clear },
|
|
|
{ 0, 0 }
|
|
|
};
|
|
|
|
|
|
- int luaopen_framebuffer(lua_State * L)
|
|
|
+ int luaopen_canvas(lua_State * L)
|
|
|
{
|
|
|
- return luax_register_type(L, "Framebuffer", functions);
|
|
|
+ return luax_register_type(L, "Canvas", functions);
|
|
|
}
|
|
|
|
|
|
} // opengl
|