123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228 |
- /**
- * Copyright (c) 2006-2013 LOVE Development Team
- *
- * This software is provided 'as-is', without any express or implied
- * warranty. In no event will the authors be held liable for any damages
- * arising from the use of this software.
- *
- * Permission is granted to anyone to use this software for any purpose,
- * including commercial applications, and to alter it and redistribute it
- * freely, subject to the following restrictions:
- *
- * 1. The origin of this software must not be misrepresented; you must not
- * claim that you wrote the original software. If you use this software
- * in a product, an acknowledgment in the product documentation would be
- * appreciated but is not required.
- * 2. Altered source versions must be plainly marked as such, and must not be
- * misrepresented as being the original software.
- * 3. This notice may not be removed or altered from any source distribution.
- **/
- // LOVE
- #include "wrap_Image.h"
- namespace love
- {
- namespace graphics
- {
- namespace opengl
- {
- Image *luax_checkimage(lua_State *L, int idx)
- {
- return luax_checktype<Image>(L, idx, "Image", GRAPHICS_IMAGE_T);
- }
- int w_Image_getWidth(lua_State *L)
- {
- Image *t = luax_checkimage(L, 1);
- lua_pushnumber(L, t->getWidth());
- return 1;
- }
- int w_Image_getHeight(lua_State *L)
- {
- Image *t = luax_checkimage(L, 1);
- lua_pushnumber(L, t->getHeight());
- return 1;
- }
- int w_Image_getDimensions(lua_State *L)
- {
- Image *t = luax_checkimage(L, 1);
- lua_pushnumber(L, t->getWidth());
- lua_pushnumber(L, t->getHeight());
- return 2;
- }
- int w_Image_setFilter(lua_State *L)
- {
- Image *t = luax_checkimage(L, 1);
- Texture::Filter f = t->getFilter();
- const char *minstr = luaL_checkstring(L, 2);
- const char *magstr = luaL_optstring(L, 3, minstr);
- if (!Texture::getConstant(minstr, f.min))
- return luaL_error(L, "Invalid filter mode: %s", minstr);
- if (!Texture::getConstant(magstr, f.mag))
- return luaL_error(L, "Invalid filter mode: %s", magstr);
- f.anisotropy = (float) luaL_optnumber(L, 4, 1.0);
- EXCEPT_GUARD(t->setFilter(f);)
- return 0;
- }
- int w_Image_getFilter(lua_State *L)
- {
- Image *t = luax_checkimage(L, 1);
- const Texture::Filter f = t->getFilter();
- const char *minstr;
- const char *magstr;
- Texture::getConstant(f.min, minstr);
- Texture::getConstant(f.mag, magstr);
- lua_pushstring(L, minstr);
- lua_pushstring(L, magstr);
- lua_pushnumber(L, f.anisotropy);
- return 3;
- }
- int w_Image_setMipmapFilter(lua_State *L)
- {
- Image *t = luax_checkimage(L, 1);
- Texture::Filter f = t->getFilter();
- if (lua_isnoneornil(L, 2))
- f.mipmap = Texture::FILTER_NONE; // mipmapping is disabled if no argument is given
- else
- {
- const char *mipmapstr = luaL_checkstring(L, 2);
- if (!Texture::getConstant(mipmapstr, f.mipmap))
- return luaL_error(L, "Invalid filter mode: %s", mipmapstr);
- }
- EXCEPT_GUARD(t->setFilter(f);)
- float sharpness = (float) luaL_optnumber(L, 3, 0);
- t->setMipmapSharpness(sharpness);
- return 0;
- }
- int w_Image_getMipmapFilter(lua_State *L)
- {
- Image *t = luax_checkimage(L, 1);
- const Texture::Filter &f = t->getFilter();
- const char *mipmapstr;
- if (Texture::getConstant(f.mipmap, mipmapstr))
- lua_pushstring(L, mipmapstr);
- else
- lua_pushnil(L); // only return a mipmap filter if mipmapping is enabled
- lua_pushnumber(L, t->getMipmapSharpness());
- return 2;
- }
- int w_Image_setWrap(lua_State *L)
- {
- Image *i = luax_checkimage(L, 1);
- Texture::Wrap w;
- const char *sstr = luaL_checkstring(L, 2);
- const char *tstr = luaL_optstring(L, 3, sstr);
- if (!Texture::getConstant(sstr, w.s))
- return luaL_error(L, "Invalid wrap mode: %s", sstr);
- if (!Texture::getConstant(tstr, w.t))
- return luaL_error(L, "Invalid wrap mode, %s", tstr);
- i->setWrap(w);
- return 0;
- }
- int w_Image_getWrap(lua_State *L)
- {
- Image *i = luax_checkimage(L, 1);
- const Texture::Wrap w = i->getWrap();
- const char *sstr;
- const char *tstr;
- Texture::getConstant(w.s, sstr);
- Texture::getConstant(w.t, tstr);
- lua_pushstring(L, sstr);
- lua_pushstring(L, tstr);
- return 2;
- }
- int w_Image_isCompressed(lua_State *L)
- {
- Image *i = luax_checkimage(L, 1);
- luax_pushboolean(L, i->isCompressed());
- return 1;
- }
- int w_Image_refresh(lua_State *L)
- {
- Image *i = luax_checkimage(L, 1);
- EXCEPT_GUARD(i->refresh();)
- return 0;
- }
- int w_Image_getData(lua_State *L)
- {
- Image *i = luax_checkimage(L, 1);
- if (i->isCompressed())
- {
- love::image::CompressedData *t = i->getCompressedData();
- if (t)
- {
- t->retain();
- luax_pushtype(L, "CompressedData", IMAGE_COMPRESSED_DATA_T, t);
- }
- else
- lua_pushnil(L);
- }
- else
- {
- love::image::ImageData *t = i->getImageData();
- if (t)
- {
- t->retain();
- luax_pushtype(L, "ImageData", IMAGE_IMAGE_DATA_T, t);
- }
- else
- lua_pushnil(L);
- }
- return 1;
- }
- static const luaL_Reg functions[] =
- {
- { "getWidth", w_Image_getWidth },
- { "getHeight", w_Image_getHeight },
- { "getDimensions", w_Image_getDimensions },
- { "setFilter", w_Image_setFilter },
- { "getFilter", w_Image_getFilter },
- { "setWrap", w_Image_setWrap },
- { "getWrap", w_Image_getWrap },
- { "setMipmapFilter", w_Image_setMipmapFilter },
- { "getMipmapFilter", w_Image_getMipmapFilter },
- { "isCompressed", w_Image_isCompressed },
- { "refresh", w_Image_refresh },
- { "getData", w_Image_getData },
- { 0, 0 }
- };
- extern "C" int luaopen_image(lua_State *L)
- {
- return luax_register_type(L, "Image", functions);
- }
- } // opengl
- } // graphics
- } // love
|