mirror of
https://github.com/AquariaOSE/Aquaria.git
synced 2025-01-26 02:07:26 +00:00
Temp commit, some WIP things:
- QuadGrid draft - Fix minimap_setHealthBarTex accidentally calling MiniMapRender::setAvatarTex - don't trunkcate to int in entity_rotateTo*() functions
This commit is contained in:
parent
c81d880b41
commit
ce4ca7f794
7 changed files with 225 additions and 22 deletions
|
@ -60,6 +60,7 @@ extern "C" {
|
|||
#include "Spore.h"
|
||||
#include "Shader.h"
|
||||
#include "ActionMapper.h"
|
||||
#include "QuadGrid.h"
|
||||
|
||||
|
||||
#include "MathFunctions.h"
|
||||
|
@ -655,6 +656,16 @@ ParticleEffect *getParticle(lua_State *L, int slot = 1)
|
|||
return q;
|
||||
}
|
||||
|
||||
static inline
|
||||
QuadGrid *getQuadGrid(lua_State *L, int slot = 1)
|
||||
{
|
||||
QuadGrid *q = (QuadGrid*)lua_touserdata(L, slot);
|
||||
ENSURE_TYPE(q, SCO_QUAD_GRID);
|
||||
if (!q)
|
||||
scriptDebug(L, "Invalid QuadGrid");
|
||||
return q;
|
||||
}
|
||||
|
||||
static bool looksLikeGlobal(const char *s)
|
||||
{
|
||||
for( ; *s; ++s)
|
||||
|
@ -1002,6 +1013,7 @@ MakeTypeCheckFunc(isBeam, SCO_BEAM)
|
|||
MakeTypeCheckFunc(isText, SCO_TEXT)
|
||||
MakeTypeCheckFunc(isShader, SCO_SHADER)
|
||||
MakeTypeCheckFunc(isParticleEffect, SCO_PARTICLE_EFFECT)
|
||||
MakeTypeCheckFunc(isQuadGrid, SCO_QUAD_GRID)
|
||||
|
||||
#undef MakeTypeCheckFunc
|
||||
|
||||
|
@ -5661,7 +5673,7 @@ luaFunc(entity_rotateToVel)
|
|||
{
|
||||
if (!e->vel.isZero())
|
||||
{
|
||||
e->rotateToVec(e->vel, lua_tonumber(L, 2), lua_tointeger(L, 3));
|
||||
e->rotateToVec(e->vel, lua_tonumber(L, 2), lua_tonumber(L, 3));
|
||||
}
|
||||
}
|
||||
luaReturnNil();
|
||||
|
@ -5677,7 +5689,7 @@ luaFunc(entity_rotateToEntity)
|
|||
Vector vec = e2->position - e->position;
|
||||
if (!vec.isZero())
|
||||
{
|
||||
e->rotateToVec(vec, lua_tonumber(L, 3), lua_tointeger(L, 4));
|
||||
e->rotateToVec(vec, lua_tonumber(L, 3), lua_tonumber(L, 4));
|
||||
}
|
||||
}
|
||||
luaReturnNil();
|
||||
|
@ -5691,7 +5703,7 @@ luaFunc(entity_rotateToVec)
|
|||
{
|
||||
if (!vec.isZero())
|
||||
{
|
||||
e->rotateToVec(vec, lua_tonumber(L, 4), lua_tointeger(L, 5));
|
||||
e->rotateToVec(vec, lua_tonumber(L, 4), lua_tonumber(L, 5));
|
||||
}
|
||||
}
|
||||
luaReturnNil();
|
||||
|
@ -5977,18 +5989,23 @@ luaFunc(entity_isInRect)
|
|||
luaReturnBool(v);
|
||||
}
|
||||
|
||||
luaFunc(createQuad)
|
||||
static void setupQuadCommon(lua_State *L, RenderObject *q, int idx)
|
||||
{
|
||||
PauseQuad *q = new PauseQuad();
|
||||
q->setTexture(getString(L, 1));
|
||||
int layer = lua_tointeger(L, 2);
|
||||
q->setTexture(getString(L, idx));
|
||||
int layer = lua_tointeger(L, idx + 1);
|
||||
if (layer == 13)
|
||||
layer = 13;
|
||||
else
|
||||
layer = (LR_PARTICLES+1) - LR_ELEMENTS1;
|
||||
dsq->game->addRenderObject(q, LR_ELEMENTS1+(layer-1));
|
||||
q->moveToFront();
|
||||
}
|
||||
|
||||
|
||||
luaFunc(createQuad)
|
||||
{
|
||||
PauseQuad *q = new PauseQuad();
|
||||
setupQuadCommon(L, q, 1);
|
||||
luaReturnPtr(q);
|
||||
}
|
||||
|
||||
|
@ -9536,6 +9553,50 @@ luaFunc(getPerformanceFreq)
|
|||
#endif
|
||||
}
|
||||
|
||||
// ----------- Grid Quad -----------------------
|
||||
|
||||
luaFunc(createQuadGrid)
|
||||
{
|
||||
QuadGrid *q = QuadGrid::New(luaL_checkinteger(L, 1), luaL_checkinteger(L, 2));
|
||||
if(q)
|
||||
setupQuadCommon(L, q, 3);
|
||||
luaReturnPtr(q);
|
||||
}
|
||||
|
||||
luaFunc(quadgrid_numPoints)
|
||||
{
|
||||
QuadGrid *q = getQuadGrid(L);
|
||||
lua_pushinteger(L, q->pointsX());
|
||||
lua_pushinteger(L, q->pointsY());
|
||||
return 2;
|
||||
}
|
||||
|
||||
luaFunc(quadgrid_setPoint)
|
||||
{
|
||||
QuadGrid *q = getQuadGrid(L);
|
||||
size_t ix = luaL_checkinteger(L, 2);
|
||||
size_t iy = luaL_checkinteger(L, 3);
|
||||
if(ix < q->pointsX() && iy < q->pointsY())
|
||||
{
|
||||
QuadGrid::Point &p = (*q)(ix, iy);
|
||||
if(!lua_isnoneornil(L, 4))
|
||||
p.x = lua_tonumber(L, 4);
|
||||
if(!lua_isnoneornil(L, 5))
|
||||
p.y = lua_tonumber(L, 5);
|
||||
if(!lua_isnoneornil(L, 6))
|
||||
p.u = lua_tonumber(L, 6);
|
||||
if(!lua_isnoneornil(L, 7))
|
||||
p.v = lua_tonumber(L, 7);
|
||||
|
||||
luaReturnNil();
|
||||
}
|
||||
return luaL_error(L, "out of range");
|
||||
}
|
||||
|
||||
|
||||
q;
|
||||
// TODO: interp texOffset, setPauseLevel
|
||||
|
||||
// ---------- Minimap related ------------------
|
||||
|
||||
luaFunc(getMinimapRender)
|
||||
|
@ -9561,7 +9622,7 @@ luaFunc(minimap_setAvatarIconTex)
|
|||
}
|
||||
luaFunc(minimap_setHealthBarTex)
|
||||
{
|
||||
luaReturnBool(MiniMapRender::setAvatarTex(getString(L)));
|
||||
luaReturnBool(MiniMapRender::setHealthBarTex(getString(L)));
|
||||
}
|
||||
luaFunc(minimap_setMaxHealthMarkerTex)
|
||||
{
|
||||
|
|
|
@ -61,6 +61,8 @@ set(BBGE_SRCS
|
|||
Precacher.h
|
||||
Quad.cpp
|
||||
Quad.h
|
||||
QuadGrid.cpp
|
||||
QuadGrid.h
|
||||
QuadTrail.cpp
|
||||
QuadTrail.h
|
||||
ReadXML.cpp
|
||||
|
|
|
@ -71,19 +71,6 @@ void Quad::createStrip(bool vert, int num)
|
|||
resetStrip();
|
||||
}
|
||||
|
||||
void Quad::setStrip(const std::vector<Vector> &st)
|
||||
{
|
||||
resetStrip();
|
||||
for (size_t i = 0; i < st.size(); i++)
|
||||
{
|
||||
if (i < strip.size())
|
||||
{
|
||||
strip[i].x += st[i].x;
|
||||
strip[i].y += st[i].y;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void Quad::createGrid(int xd, int yd)
|
||||
{
|
||||
deleteGrid();
|
||||
|
|
|
@ -64,7 +64,6 @@ public:
|
|||
void refreshRepeatTextureToFill();
|
||||
bool isRepeatingTextureToFill() const { return repeatingTextureToFill; }
|
||||
void setGridPoints(bool vert, const std::vector<Vector> &points);
|
||||
void setStrip(const std::vector<Vector> &strip);
|
||||
virtual void createStrip(bool stripVert, int num);
|
||||
float getStripSegmentSize();
|
||||
void resetStrip();
|
||||
|
|
84
BBGE/QuadGrid.cpp
Normal file
84
BBGE/QuadGrid.cpp
Normal file
|
@ -0,0 +1,84 @@
|
|||
#include "QuadGrid.h"
|
||||
#include "Texture.h"
|
||||
#include "RenderBase.h"
|
||||
#include "Core.h"
|
||||
|
||||
QuadGrid::QuadGrid(size_t w, size_t h)
|
||||
: pauseLevel(0), _w(w), _h(h)
|
||||
{
|
||||
addType(SCO_QUAD_GRID);
|
||||
_points.resize((w+1) * (h+1));
|
||||
}
|
||||
|
||||
QuadGrid* QuadGrid::New(size_t w, size_t h)
|
||||
{
|
||||
return w && h ? new QuadGrid(w, h) : NULL;
|
||||
}
|
||||
|
||||
QuadGrid::~QuadGrid()
|
||||
{
|
||||
}
|
||||
|
||||
void QuadGrid::resetUV(float xmul, float ymul)
|
||||
{
|
||||
const float incX = 1.0f / float(_w + 1);
|
||||
const float incY = 1.0f / float(_h + 1);
|
||||
|
||||
float u0 = 0, u1 = incX, v0 = 0, v1 = incY;
|
||||
|
||||
// go over points, so <= to compare boundaries
|
||||
for(size_t y = 0; y <= _h; ++y, v0 = v1, v1 += incY)
|
||||
{
|
||||
Point *row = &_points[y * _w];
|
||||
for(size_t x = 0; x <= _w; ++x, u0 = u1, u1 += incX)
|
||||
{
|
||||
row[x].u = u0;
|
||||
row[y].v = v0;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
static inline void drawOnePoint(const QuadGrid::Point& p, float ox, float oy)
|
||||
{
|
||||
glTexCoord2f(p.u + ox, p.v + oy);
|
||||
glVertex2f(p.x, p.y);
|
||||
}
|
||||
|
||||
|
||||
void QuadGrid::onRender()
|
||||
{
|
||||
glBindTexture(GL_TEXTURE_2D, texture->textures[0]);
|
||||
glColor4f(color.x, color.y, color.z, alpha.x * alphaMod);
|
||||
|
||||
const float ox = texOffset.x;
|
||||
const float oy = texOffset.y;
|
||||
|
||||
const size_t NX = _w + 1;
|
||||
|
||||
// go over grids, so < to compare boundaries
|
||||
for(size_t y = 0; y < _h; ++y)
|
||||
{
|
||||
Point * const row0 = &_points[y * NX];
|
||||
Point * const row1 = row0 + NX;
|
||||
for(size_t x = 0; x < _w; ++x)
|
||||
{
|
||||
glBegin(GL_QUADS);
|
||||
drawOnePoint(row0[x], ox, oy);
|
||||
drawOnePoint(row0[x+1], ox, oy);
|
||||
drawOnePoint(row1[x+1], ox, oy);
|
||||
drawOnePoint(row1[x], ox, oy);
|
||||
glEnd();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void QuadGrid::onUpdate(float dt)
|
||||
{
|
||||
if(pauseLevel < core->particlesPaused)
|
||||
return;
|
||||
|
||||
texOffset.update(dt);
|
||||
|
||||
RenderObject::onUpdate(dt);
|
||||
}
|
||||
|
69
BBGE/QuadGrid.h
Normal file
69
BBGE/QuadGrid.h
Normal file
|
@ -0,0 +1,69 @@
|
|||
#ifndef BBGE_QUADGRID_H
|
||||
#define BBGE_QUADGRID_H
|
||||
|
||||
#include <vector>
|
||||
#include "RenderObject.h"
|
||||
|
||||
/*
|
||||
This class is an extension for Quad, where coordinates and UV coords can be set freely.
|
||||
Yes, the Quad class also has a grid function that's used for quad strips, segmented animation and so on, but this is different.
|
||||
|
||||
TODO:
|
||||
In *most* cases a full Quad (as it's implemented right now) isn't needed.
|
||||
A Quad *should* be just a dumb texture with a center point that can be slapped somewhere and scaled/rotated/etc. Like a normal map tile (Element) without any specials applied.
|
||||
Only some Elements are worthy of being grid Quads -- those with a wavy tile effect applied.
|
||||
Same goes for bones. Most bones don't have any strip animation so they don't need what a Quad provides.
|
||||
Strip anim is just a 2xN or Nx2 grid, btw.
|
||||
|
||||
A future goal is to eventually rip all strip/xy-grid/segs functionality out of the Quad, make the Quad dumb,
|
||||
and make this QuadGrid class derive from Quad (or probably PauseQuad) instead of RenderObject.
|
||||
The Bone and Element classes need to be fixed to accompany for this of course but
|
||||
*/
|
||||
|
||||
class QuadGrid : public RenderObject
|
||||
{
|
||||
public:
|
||||
static QuadGrid *New(size_t w, size_t h);
|
||||
virtual ~QuadGrid();
|
||||
|
||||
struct Point
|
||||
{
|
||||
float x, y, u, v;
|
||||
};
|
||||
|
||||
|
||||
inline Point& operator()(size_t x, size_t y)
|
||||
{
|
||||
return _points[y * _w + x];
|
||||
}
|
||||
|
||||
inline const Point& operator()(size_t x, size_t y) const
|
||||
{
|
||||
return _points[y * _w + x];
|
||||
}
|
||||
|
||||
virtual void onRender();
|
||||
virtual void onUpdate(float dt);
|
||||
|
||||
void resetUV(float xmul = 1, float ymul = 1);
|
||||
|
||||
inline size_t quadsX() const { return _w; }
|
||||
inline size_t quadsY() const { return _h; }
|
||||
|
||||
inline size_t pointsX() const { return _w + 1; }
|
||||
inline size_t pointsY() const { return _h + 1; }
|
||||
|
||||
|
||||
public:
|
||||
InterpolatedVector texOffset;
|
||||
int pauseLevel;
|
||||
|
||||
|
||||
private:
|
||||
QuadGrid(size_t w, size_t h);
|
||||
const size_t _w, _h;
|
||||
std::vector<Point> _points;
|
||||
};
|
||||
|
||||
|
||||
#endif
|
|
@ -42,6 +42,7 @@ enum ScriptObjectType
|
|||
SCO_PAUSEQUAD = 0x1000,
|
||||
SCO_SHADER = 0x2000,
|
||||
SCO_PARTICLE_EFFECT = 0x4000,
|
||||
SCO_QUAD_GRID = 0x8000,
|
||||
|
||||
SCO_FORCE_32BIT = 0xFFFFFFFF
|
||||
};
|
||||
|
|
Loading…
Reference in a new issue