186 lines
4.6 KiB
C
186 lines
4.6 KiB
C
/*
|
|
This file is part of Iceball.
|
|
|
|
Iceball is free software: you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation, either version 3 of the License, or
|
|
(at your option) any later version.
|
|
|
|
Iceball is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with Iceball. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
// client functions
|
|
int icelua_fn_client_img_blit(lua_State *L)
|
|
{
|
|
int top = icelua_assert_stack(L, 3, 8);
|
|
int dx, dy, bw, bh, sx, sy;
|
|
uint32_t color;
|
|
|
|
img_t *img = lua_touserdata(L, 1);
|
|
if(img == NULL || img->udtype != UD_IMG)
|
|
return luaL_error(L, "not an image");
|
|
|
|
dx = lua_tointeger(L, 2);
|
|
dy = lua_tointeger(L, 3);
|
|
bw = (top < 4 ? img->head.width : lua_tointeger(L, 4));
|
|
bh = (top < 5 ? img->head.height : lua_tointeger(L, 5));
|
|
sx = (top < 6 ? 0 : lua_tointeger(L, 6));
|
|
sy = (top < 7 ? 0 : lua_tointeger(L, 7));
|
|
color = (top < 8 ? 0xFFFFFFFF : (uint32_t)lua_tointeger(L, 8));
|
|
|
|
#ifdef DEDI
|
|
return luaL_error(L, "EDOOFUS: why the hell is this being called in the dedi version?");
|
|
#else
|
|
render_blit_img(screen->pixels, screen->w, screen->h, screen->pitch/4,
|
|
img, dx, dy, bw, bh, sx, sy, color);
|
|
#endif
|
|
|
|
return 0;
|
|
}
|
|
|
|
int icelua_fn_client_img_blit_to(lua_State *L)
|
|
{
|
|
int top = icelua_assert_stack(L, 4, 9);
|
|
int dx, dy, bw, bh, sx, sy;
|
|
uint32_t color;
|
|
|
|
img_t *dest = lua_touserdata(L, 1);
|
|
if(dest == NULL || dest->udtype != UD_IMG)
|
|
return luaL_error(L, "not an image");
|
|
img_t *source = lua_touserdata(L, 2);
|
|
if(source == NULL || source->udtype != UD_IMG)
|
|
return luaL_error(L, "not an image");
|
|
|
|
dx = lua_tointeger(L, 3);
|
|
dy = lua_tointeger(L, 4);
|
|
bw = (top < 5 ? source->head.width : lua_tointeger(L, 5));
|
|
bh = (top < 6 ? source->head.height : lua_tointeger(L, 6));
|
|
sx = (top < 7 ? 0 : lua_tointeger(L, 7));
|
|
sy = (top < 8 ? 0 : lua_tointeger(L, 8));
|
|
color = (top < 9 ? 0xFFFFFFFF : (uint32_t)lua_tointeger(L, 9));
|
|
|
|
render_blit_img(dest->pixels, dest->head.width, dest->head.height,
|
|
dest->head.width,
|
|
source, dx, dy, bw, bh, sx, sy, color);
|
|
|
|
return 0;
|
|
}
|
|
|
|
// common functions
|
|
int icelua_fn_common_img_load(lua_State *L)
|
|
{
|
|
int top = icelua_assert_stack(L, 1, 1);
|
|
|
|
const char *fname = lua_tostring(L, 1);
|
|
if(fname == NULL)
|
|
return luaL_error(L, "filename must be a string");
|
|
|
|
lua_getglobal(L, "common");
|
|
lua_getfield(L, -1, "fetch_block");
|
|
lua_remove(L, -2);
|
|
lua_pushstring(L, "tga");
|
|
lua_pushvalue(L, 1);
|
|
lua_call(L, 2, 1);
|
|
|
|
img_t *img = lua_touserdata(L, -1);
|
|
if(img == NULL)
|
|
return 0;
|
|
|
|
lua_pushinteger(L, img->head.width);
|
|
lua_pushinteger(L, img->head.height);
|
|
|
|
return 3;
|
|
}
|
|
|
|
int icelua_fn_common_img_new(lua_State *L)
|
|
{
|
|
int i;
|
|
|
|
int top = icelua_assert_stack(L, 2, 2);
|
|
|
|
int w = lua_tointeger(L, 1);
|
|
int h = lua_tointeger(L, 2);
|
|
|
|
if(w < 1 || h < 1)
|
|
return luaL_error(L, "image too small");
|
|
|
|
img_t *img = malloc(sizeof(img_t)+(w*h*sizeof(uint32_t)));
|
|
if(img == NULL)
|
|
return luaL_error(L, "could not allocate memory");
|
|
|
|
img->head.idlen = 0; // no ID
|
|
img->head.cmtype = 0; // no colourmap
|
|
img->head.imgtype = 2; // uncompressed RGB
|
|
img->head.cmoffs = 0;
|
|
img->head.cmlen = 0;
|
|
img->head.cmbpp = 0;
|
|
img->head.xstart = 0;
|
|
img->head.ystart = h-1;
|
|
img->head.width = w;
|
|
img->head.height = h;
|
|
img->head.bpp = 32;
|
|
img->head.flags = 0x20;
|
|
|
|
for(i = 0; i < w*h; i++)
|
|
img->pixels[i] = 0x00000000;
|
|
|
|
img->udtype = UD_IMG;
|
|
|
|
lua_pushlightuserdata(L, img);
|
|
return 1;
|
|
}
|
|
|
|
int icelua_fn_common_img_pixel_set(lua_State *L)
|
|
{
|
|
int i;
|
|
|
|
int top = icelua_assert_stack(L, 4, 4);
|
|
|
|
img_t *img = lua_touserdata(L, 1);
|
|
if(img == NULL || img->udtype != UD_IMG)
|
|
return luaL_error(L, "not an image");
|
|
int x = lua_tointeger(L, 2);
|
|
int y = lua_tointeger(L, 3);
|
|
uint32_t color = lua_tointeger(L, 4);
|
|
|
|
if(x < 0 || y < 0 || x >= img->head.width || y >= img->head.height)
|
|
return 0;
|
|
|
|
img->pixels[y*img->head.width+x] = color;
|
|
|
|
return 0;
|
|
}
|
|
|
|
int icelua_fn_common_img_free(lua_State *L)
|
|
{
|
|
int top = icelua_assert_stack(L, 1, 1);
|
|
|
|
img_t *img = lua_touserdata(L, 1);
|
|
if(img == NULL || img->udtype != UD_IMG)
|
|
return luaL_error(L, "not an image");
|
|
|
|
img_free(img);
|
|
|
|
return 0;
|
|
}
|
|
|
|
int icelua_fn_common_img_get_dims(lua_State *L)
|
|
{
|
|
int top = icelua_assert_stack(L, 1, 1);
|
|
|
|
img_t *img = lua_touserdata(L, 1);
|
|
if(img == NULL || img->udtype != UD_IMG)
|
|
return luaL_error(L, "not an image");
|
|
|
|
lua_pushinteger(L, img->head.width);
|
|
lua_pushinteger(L, img->head.height);
|
|
|
|
return 2;
|
|
}
|