wrap_Framebuffer.cpp 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. #include "wrap_Framebuffer.h"
  2. namespace love
  3. {
  4. namespace graphics
  5. {
  6. namespace opengl
  7. {
  8. Framebuffer * luax_checkfbo(lua_State * L, int idx)
  9. {
  10. return luax_checktype<Framebuffer>(L, idx, "Framebuffer", GRAPHICS_FRAMEBUFFER_T);
  11. }
  12. int w_Framebuffer_renderTo(lua_State * L)
  13. {
  14. // As startGrab() clears the framebuffer, better not allow
  15. // grabbing inside another grabbing
  16. if (Framebuffer::current != NULL) {
  17. Framebuffer::bindDefaultBuffer();
  18. return luaL_error(L, "Current render target not the default framebuffer!");
  19. }
  20. Framebuffer * fbo = luax_checkfbo(L, 1);
  21. if (!lua_isfunction(L, 2))
  22. return luaL_error(L, "Need a function to render to fbo");
  23. fbo->startGrab();
  24. lua_settop(L, 2); // make sure the function is on top of the stack
  25. lua_call(L, 0, 0);
  26. fbo->stopGrab();
  27. return 0;
  28. }
  29. int w_Framebuffer_getImageData(lua_State * L)
  30. {
  31. Framebuffer * fbo = luax_checkfbo(L, 1);
  32. love::image::Image * image = luax_getmodule<love::image::Image>(L, "image", MODULE_IMAGE_T);
  33. love::image::ImageData * img = fbo->getImageData( image );
  34. luax_newtype(L, "ImageData", IMAGE_IMAGE_DATA_T, (void *)img);
  35. return 1;
  36. }
  37. int w_Framebuffer_setFilter(lua_State * L)
  38. {
  39. Framebuffer * fbo = luax_checkfbo(L, 1);
  40. const char * minstr = luaL_checkstring(L, 2);
  41. const char * magstr = luaL_checkstring(L, 3);
  42. Image::Filter f;
  43. if (!Image::getConstant(minstr, f.min))
  44. return luaL_error(L, "Invalid min filter mode: %s", minstr);
  45. if (!Image::getConstant(magstr, f.mag))
  46. return luaL_error(L, "Invalid max filter mode: %s", magstr);
  47. fbo->setFilter(f);
  48. return 0;
  49. }
  50. int w_Framebuffer_getFilter(lua_State * L)
  51. {
  52. Framebuffer * fbo = luax_checkfbo(L, 1);
  53. Image::Filter f = fbo->getFilter();
  54. const char * minstr;
  55. const char * magstr;
  56. Image::getConstant(f.min, minstr);
  57. Image::getConstant(f.mag, magstr);
  58. lua_pushstring(L, minstr);
  59. lua_pushstring(L, magstr);
  60. return 2;
  61. }
  62. int w_Framebuffer_setWrap(lua_State * L)
  63. {
  64. Framebuffer * fbo = luax_checkfbo(L, 1);
  65. const char * wrap_s = luaL_checkstring(L, 2);
  66. const char * wrap_t = luaL_checkstring(L, 3);
  67. Image::Wrap w;
  68. if (!Image::getConstant(wrap_s, w.s))
  69. return luaL_error(L, "Invalid wrap mode: %s", wrap_s);
  70. if (!Image::getConstant(wrap_t, w.t))
  71. return luaL_error(L, "Invalid wrap mode: %s", wrap_t);
  72. fbo->setWrap(w);
  73. return 0;
  74. }
  75. int w_Framebuffer_getWrap(lua_State * L)
  76. {
  77. Framebuffer * fbo = luax_checkfbo(L, 1);
  78. Image::Wrap w = fbo->getWrap();
  79. const char * wrap_s;
  80. const char * wrap_t;
  81. Image::getConstant(w.s, wrap_s);
  82. Image::getConstant(w.t, wrap_t);
  83. lua_pushstring(L, wrap_s);
  84. lua_pushstring(L, wrap_t);
  85. return 2;
  86. }
  87. static const luaL_Reg functions[] = {
  88. { "renderTo", w_Framebuffer_renderTo },
  89. { "getImageData", w_Framebuffer_getImageData },
  90. { "setFilter", w_Framebuffer_setFilter },
  91. { "getFilter", w_Framebuffer_getFilter },
  92. { "setWrap", w_Framebuffer_setWrap },
  93. { "getWrap", w_Framebuffer_getWrap },
  94. { 0, 0 }
  95. };
  96. int luaopen_framebuffer(lua_State * L)
  97. {
  98. return luax_register_type(L, "Framebuffer", functions);
  99. }
  100. } // opengl
  101. } // graphics
  102. } // love