|
|
@ -1,6 +1,8 @@
|
|
|
|
#include <vector>
|
|
|
|
#include <vector>
|
|
|
|
#include <string>
|
|
|
|
#include <string>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#include <LuaTools.h>
|
|
|
|
|
|
|
|
|
|
|
|
#include "Core.h"
|
|
|
|
#include "Core.h"
|
|
|
|
#include "Console.h"
|
|
|
|
#include "Console.h"
|
|
|
|
#include "Export.h"
|
|
|
|
#include "Export.h"
|
|
|
@ -17,7 +19,7 @@ using std::vector;
|
|
|
|
using std::string;
|
|
|
|
using std::string;
|
|
|
|
enum RENDERER_MODE
|
|
|
|
enum RENDERER_MODE
|
|
|
|
{
|
|
|
|
{
|
|
|
|
MODE_DEFAULT,MODE_TRIPPY,MODE_TRUECOLOR
|
|
|
|
MODE_DEFAULT,MODE_TRIPPY,MODE_TRUECOLOR,MODE_LUA
|
|
|
|
};
|
|
|
|
};
|
|
|
|
RENDERER_MODE current_mode=MODE_DEFAULT;
|
|
|
|
RENDERER_MODE current_mode=MODE_DEFAULT;
|
|
|
|
static command_result rendermax(color_ostream &out, vector <string> & parameters);
|
|
|
|
static command_result rendermax(color_ostream &out, vector <string> & parameters);
|
|
|
@ -46,6 +48,159 @@ void installNew(df::renderer* r,RENDERER_MODE newMode)
|
|
|
|
df::global::enabler->renderer=r;
|
|
|
|
df::global::enabler->renderer=r;
|
|
|
|
current_mode=newMode;
|
|
|
|
current_mode=newMode;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static void lockGrids()
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if(current_mode!=MODE_LUA)
|
|
|
|
|
|
|
|
return ;
|
|
|
|
|
|
|
|
renderer_lua* r=reinterpret_cast<renderer_lua*>(df::global::enabler->renderer);
|
|
|
|
|
|
|
|
r->dataMutex.lock();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
static void unlockGrids()
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if(current_mode!=MODE_LUA)
|
|
|
|
|
|
|
|
return ;
|
|
|
|
|
|
|
|
renderer_lua* r=reinterpret_cast<renderer_lua*>(df::global::enabler->renderer);
|
|
|
|
|
|
|
|
r->dataMutex.unlock();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
static void resetGrids()
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if(current_mode!=MODE_LUA)
|
|
|
|
|
|
|
|
return ;
|
|
|
|
|
|
|
|
renderer_lua* r=reinterpret_cast<renderer_lua*>(df::global::enabler->renderer);
|
|
|
|
|
|
|
|
for(size_t i=0;i<r->foreMult.size();i++)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
r->foreMult[i]=lightCell(1,1,1);
|
|
|
|
|
|
|
|
r->foreOffset[i]=lightCell(0,0,0);
|
|
|
|
|
|
|
|
r->backMult[i]=lightCell(1,1,1);
|
|
|
|
|
|
|
|
r->backOffset[i]=lightCell(0,0,0);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
static int getGridsSize()
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if(current_mode!=MODE_LUA)
|
|
|
|
|
|
|
|
return -1;
|
|
|
|
|
|
|
|
renderer_lua* r=reinterpret_cast<renderer_lua*>(df::global::enabler->renderer);
|
|
|
|
|
|
|
|
lua_pushnumber(L,df::global::gps->dimx);
|
|
|
|
|
|
|
|
lua_pushnumber(L,df::global::gps->dimy);
|
|
|
|
|
|
|
|
return 2;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
static int getCell(lua_State* L)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if(current_mode!=MODE_LUA)
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
renderer_lua* r=reinterpret_cast<renderer_lua*>(df::global::enabler->renderer);
|
|
|
|
|
|
|
|
int x=luaL_checknumber(L,1);
|
|
|
|
|
|
|
|
int y=luaL_checknumber(L,2);
|
|
|
|
|
|
|
|
int id=r->xyToTile(x,y);
|
|
|
|
|
|
|
|
lightCell fo=r->foreOffset[id];
|
|
|
|
|
|
|
|
lightCell fm=r->foreMult[id];
|
|
|
|
|
|
|
|
lightCell bo=r->backOffset[id];
|
|
|
|
|
|
|
|
lightCell bm=r->backMult[id];
|
|
|
|
|
|
|
|
lua_newtable(L);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
lua_newtable(L);
|
|
|
|
|
|
|
|
lua_pushnumber(L,fo.r);
|
|
|
|
|
|
|
|
lua_setfield(L,-2,"r");
|
|
|
|
|
|
|
|
lua_pushnumber(L,fo.g);
|
|
|
|
|
|
|
|
lua_setfield(L,-2,"g");
|
|
|
|
|
|
|
|
lua_pushnumber(L,fo.b);
|
|
|
|
|
|
|
|
lua_setfield(L,-2,"b");
|
|
|
|
|
|
|
|
lua_setfield(L,-2,"fo");
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
lua_newtable(L);
|
|
|
|
|
|
|
|
lua_pushnumber(L,fm.r);
|
|
|
|
|
|
|
|
lua_setfield(L,-2,"r");
|
|
|
|
|
|
|
|
lua_pushnumber(L,fm.g);
|
|
|
|
|
|
|
|
lua_setfield(L,-2,"g");
|
|
|
|
|
|
|
|
lua_pushnumber(L,fm.b);
|
|
|
|
|
|
|
|
lua_setfield(L,-2,"b");
|
|
|
|
|
|
|
|
lua_setfield(L,-2,"fm");
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
lua_newtable(L);
|
|
|
|
|
|
|
|
lua_pushnumber(L,bo.r);
|
|
|
|
|
|
|
|
lua_setfield(L,-2,"r");
|
|
|
|
|
|
|
|
lua_pushnumber(L,bo.g);
|
|
|
|
|
|
|
|
lua_setfield(L,-2,"g");
|
|
|
|
|
|
|
|
lua_pushnumber(L,bo.b);
|
|
|
|
|
|
|
|
lua_setfield(L,-2,"b");
|
|
|
|
|
|
|
|
lua_setfield(L,-2,"bo");
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
lua_newtable(L);
|
|
|
|
|
|
|
|
lua_pushnumber(L,bm.r);
|
|
|
|
|
|
|
|
lua_setfield(L,-2,"r");
|
|
|
|
|
|
|
|
lua_pushnumber(L,bm.g);
|
|
|
|
|
|
|
|
lua_setfield(L,-2,"g");
|
|
|
|
|
|
|
|
lua_pushnumber(L,bm.b);
|
|
|
|
|
|
|
|
lua_setfield(L,-2,"b");
|
|
|
|
|
|
|
|
lua_setfield(L,-2,"bm");
|
|
|
|
|
|
|
|
return 1;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
static int setCell(lua_State* L)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if(current_mode!=MODE_LUA)
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
renderer_lua* r=reinterpret_cast<renderer_lua*>(df::global::enabler->renderer);
|
|
|
|
|
|
|
|
int x=luaL_checknumber(L,1);
|
|
|
|
|
|
|
|
int y=luaL_checknumber(L,2);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
lightCell fo;
|
|
|
|
|
|
|
|
lua_getfield(L,3,"fo");
|
|
|
|
|
|
|
|
lua_getfield(L,-1,"r");
|
|
|
|
|
|
|
|
fo.r=lua_tonumber(L,-1);lua_pop(L,1);
|
|
|
|
|
|
|
|
lua_getfield(L,-1,"g");
|
|
|
|
|
|
|
|
fo.g=lua_tonumber(L,-1);lua_pop(L,1);
|
|
|
|
|
|
|
|
lua_getfield(L,-1,"b");
|
|
|
|
|
|
|
|
fo.b=lua_tonumber(L,-1);lua_pop(L,1);
|
|
|
|
|
|
|
|
lightCell fm;
|
|
|
|
|
|
|
|
lua_getfield(L,3,"fm");
|
|
|
|
|
|
|
|
lua_getfield(L,-1,"r");
|
|
|
|
|
|
|
|
fm.r=lua_tonumber(L,-1);lua_pop(L,1);
|
|
|
|
|
|
|
|
lua_getfield(L,-1,"g");
|
|
|
|
|
|
|
|
fm.g=lua_tonumber(L,-1);lua_pop(L,1);
|
|
|
|
|
|
|
|
lua_getfield(L,-1,"b");
|
|
|
|
|
|
|
|
fm.b=lua_tonumber(L,-1);lua_pop(L,1);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
lightCell bo;
|
|
|
|
|
|
|
|
lua_getfield(L,3,"bo");
|
|
|
|
|
|
|
|
lua_getfield(L,-1,"r");
|
|
|
|
|
|
|
|
bo.r=lua_tonumber(L,-1);lua_pop(L,1);
|
|
|
|
|
|
|
|
lua_getfield(L,-1,"g");
|
|
|
|
|
|
|
|
bo.g=lua_tonumber(L,-1);lua_pop(L,1);
|
|
|
|
|
|
|
|
lua_getfield(L,-1,"b");
|
|
|
|
|
|
|
|
bo.b=lua_tonumber(L,-1);lua_pop(L,1);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
lightCell bm;
|
|
|
|
|
|
|
|
lua_getfield(L,3,"bm");
|
|
|
|
|
|
|
|
lua_getfield(L,-1,"r");
|
|
|
|
|
|
|
|
bm.r=lua_tonumber(L,-1);lua_pop(L,1);
|
|
|
|
|
|
|
|
lua_getfield(L,-1,"g");
|
|
|
|
|
|
|
|
bm.g=lua_tonumber(L,-1);lua_pop(L,1);
|
|
|
|
|
|
|
|
lua_getfield(L,-1,"b");
|
|
|
|
|
|
|
|
bm.b=lua_tonumber(L,-1);lua_pop(L,1);
|
|
|
|
|
|
|
|
int id=r->xyToTile(x,y);
|
|
|
|
|
|
|
|
r->foreMult[id]=fm;
|
|
|
|
|
|
|
|
r->foreOffset[id]=fo;
|
|
|
|
|
|
|
|
r->backMult[id]=bm;
|
|
|
|
|
|
|
|
r->backOffset[id]=bo;
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
bool isEnabled()
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
return current_mode==MODE_LUA;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
DFHACK_PLUGIN_LUA_FUNCTIONS {
|
|
|
|
|
|
|
|
DFHACK_LUA_FUNCTION(isEnabled),
|
|
|
|
|
|
|
|
DFHACK_LUA_FUNCTION(lockGrids),
|
|
|
|
|
|
|
|
DFHACK_LUA_FUNCTION(unlockGrids),
|
|
|
|
|
|
|
|
DFHACK_LUA_FUNCTION(getGridsSize),
|
|
|
|
|
|
|
|
DFHACK_LUA_FUNCTION(resetGrids),
|
|
|
|
|
|
|
|
DFHACK_LUA_END
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
DFHACK_PLUGIN_LUA_COMMANDS {
|
|
|
|
|
|
|
|
DFHACK_LUA_COMMAND(getCell),
|
|
|
|
|
|
|
|
DFHACK_LUA_COMMAND(setCell),
|
|
|
|
|
|
|
|
DFHACK_LUA_END
|
|
|
|
|
|
|
|
};
|
|
|
|
static command_result rendermax(color_ostream &out, vector <string> & parameters)
|
|
|
|
static command_result rendermax(color_ostream &out, vector <string> & parameters)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if(parameters.size()==0)
|
|
|
|
if(parameters.size()==0)
|
|
|
@ -102,8 +257,15 @@ static command_result rendermax(color_ostream &out, vector <string> & parameters
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return CR_OK;
|
|
|
|
return CR_OK;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else if(cmd=="lua")
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
removeOld();
|
|
|
|
|
|
|
|
installNew(new renderer_lua(df::global::enabler->renderer),MODE_LUA);
|
|
|
|
|
|
|
|
lockGrids();
|
|
|
|
|
|
|
|
resetGrids();
|
|
|
|
|
|
|
|
unlockGrids();
|
|
|
|
|
|
|
|
return CR_OK;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else if(cmd=="disable")
|
|
|
|
else if(cmd=="disable")
|
|
|
|
{
|
|
|
|
{
|
|
|
|