mirror of
https://github.com/vcmi/vcmi.git
synced 2025-01-14 02:33:51 +02:00
Map edge drawing converted to CAnimation
This commit is contained in:
parent
46196daa07
commit
6782136e3e
@ -174,8 +174,6 @@ void CMapHandler::prepareFOWDefs()
|
|||||||
FoWpartialHide.resize(size);
|
FoWpartialHide.resize(size);
|
||||||
for(size_t frame = 0; frame < size; frame++)
|
for(size_t frame = 0; frame < size; frame++)
|
||||||
FoWpartialHide[frame] = graphics->fogOfWarPartialHide->getImage(frame);
|
FoWpartialHide[frame] = graphics->fogOfWarPartialHide->getImage(frame);
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
EMapAnimRedrawStatus CMapHandler::drawTerrainRectNew(SDL_Surface * targetSurface, const MapDrawingInfo * info, bool redrawOnlyAnim /* = false */)
|
EMapAnimRedrawStatus CMapHandler::drawTerrainRectNew(SDL_Surface * targetSurface, const MapDrawingInfo * info, bool redrawOnlyAnim /* = false */)
|
||||||
@ -228,31 +226,32 @@ void CMapHandler::roadsRiverTerrainInit()
|
|||||||
|
|
||||||
void CMapHandler::borderAndTerrainBitmapInit()
|
void CMapHandler::borderAndTerrainBitmapInit()
|
||||||
{
|
{
|
||||||
CDefHandler * bord = CDefHandler::giveDef("EDG.DEF");
|
egdeImages.resize(egdeAnimation->size(0));
|
||||||
bord->notFreeImgs = true;
|
for(size_t i = 0; i < egdeImages.size(); i++)
|
||||||
terrainGraphics.resize(10);
|
egdeImages[i] = egdeAnimation->getImage(i);
|
||||||
for (int i = 0; i < 10 ; i++)
|
|
||||||
|
edgeFrames.resize(sizes.x, frameW, frameW);
|
||||||
|
for (int i=0-frameW;i<edgeFrames.size()-frameW;i++)
|
||||||
{
|
{
|
||||||
CDefHandler *hlp = CDefHandler::giveDef(nameFromType(i));
|
edgeFrames[i].resize(sizes.y, frameH, frameH);
|
||||||
terrainGraphics[i].resize(hlp->ourImages.size());
|
|
||||||
hlp->notFreeImgs = true;
|
|
||||||
for(size_t j=0; j < hlp->ourImages.size(); ++j)
|
|
||||||
terrainGraphics[i][j] = hlp->ourImages[j].bitmap;
|
|
||||||
delete hlp;
|
|
||||||
}
|
}
|
||||||
|
for (int i=0-frameW;i<edgeFrames.size()-frameW;i++)
|
||||||
|
{
|
||||||
|
for (int j=0-frameH;j<(int)sizes.y+frameH;j++)
|
||||||
|
edgeFrames[i][j].resize(sizes.z, 0, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
auto & rand = CRandomGenerator::getDefault();
|
||||||
|
|
||||||
for (int i=0-frameW; i<sizes.x+frameW; i++) //by width
|
for (int i=0-frameW; i<sizes.x+frameW; i++) //by width
|
||||||
{
|
{
|
||||||
for (int j=0-frameH; j<sizes.y+frameH;j++) //by height
|
for (int j=0-frameH; j<sizes.y+frameH;j++) //by height
|
||||||
{
|
{
|
||||||
for(int k=0; k<sizes.z; ++k) //by levles
|
for(int k=0; k<sizes.z; ++k) //by levels
|
||||||
{
|
{
|
||||||
|
ui8 terBitmapNum = 0;
|
||||||
if(i < 0 || i > (sizes.x-1) || j < 0 || j > (sizes.y-1))
|
if(i < 0 || i > (sizes.x-1) || j < 0 || j > (sizes.y-1))
|
||||||
{
|
{
|
||||||
int terBitmapNum = -1;
|
|
||||||
|
|
||||||
auto & rand = CRandomGenerator::getDefault();
|
|
||||||
|
|
||||||
if(i==-1 && j==-1)
|
if(i==-1 && j==-1)
|
||||||
terBitmapNum = 16;
|
terBitmapNum = 16;
|
||||||
else if(i==-1 && j==(sizes.y))
|
else if(i==-1 && j==(sizes.y))
|
||||||
@ -272,16 +271,22 @@ void CMapHandler::borderAndTerrainBitmapInit()
|
|||||||
else
|
else
|
||||||
terBitmapNum = rand.nextInt(15);
|
terBitmapNum = rand.nextInt(15);
|
||||||
|
|
||||||
if(terBitmapNum != -1)
|
|
||||||
{
|
|
||||||
ttiles[i][j][k].terbitmap = bord->ourImages[terBitmapNum].bitmap;
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
edgeFrames[i][j][k] = terBitmapNum;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
delete bord;
|
|
||||||
|
terrainGraphics.resize(10);
|
||||||
|
for (int i = 0; i < 10 ; i++)
|
||||||
|
{
|
||||||
|
CDefHandler *hlp = CDefHandler::giveDef(nameFromType(i));
|
||||||
|
terrainGraphics[i].resize(hlp->ourImages.size());
|
||||||
|
hlp->notFreeImgs = true;
|
||||||
|
for(size_t j=0; j < hlp->ourImages.size(); ++j)
|
||||||
|
terrainGraphics[i][j] = hlp->ourImages[j].bitmap;
|
||||||
|
delete hlp;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void CMapHandler::initObjectRects()
|
void CMapHandler::initObjectRects()
|
||||||
@ -791,7 +796,7 @@ CMapHandler::CMapPuzzleViewBlitter::CMapPuzzleViewBlitter(CMapHandler * parent)
|
|||||||
void CMapHandler::CMapBlitter::drawFrame(SDL_Surface * targetSurf) const
|
void CMapHandler::CMapBlitter::drawFrame(SDL_Surface * targetSurf) const
|
||||||
{
|
{
|
||||||
Rect destRect(realTileRect);
|
Rect destRect(realTileRect);
|
||||||
drawElement(EMapCacheType::FRAME, parent->ttiles[pos.x][pos.y][topTile.z].terbitmap, nullptr, targetSurf, &destRect);
|
drawElement(EMapCacheType::FRAME, parent->egdeImages[parent->edgeFrames[pos.x][pos.y][topTile.z]], nullptr, targetSurf, &destRect);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CMapHandler::CMapBlitter::drawOverlayEx(SDL_Surface * targetSurf)
|
void CMapHandler::CMapBlitter::drawOverlayEx(SDL_Surface * targetSurf)
|
||||||
@ -1452,6 +1457,9 @@ CMapHandler::CMapHandler()
|
|||||||
worldViewBlitter = new CMapWorldViewBlitter(this);
|
worldViewBlitter = new CMapWorldViewBlitter(this);
|
||||||
puzzleViewBlitter = new CMapPuzzleViewBlitter(this);
|
puzzleViewBlitter = new CMapPuzzleViewBlitter(this);
|
||||||
fadeAnimCounter = 0;
|
fadeAnimCounter = 0;
|
||||||
|
|
||||||
|
egdeAnimation = make_unique<CAnimation>("EDG");
|
||||||
|
egdeAnimation->preload();
|
||||||
}
|
}
|
||||||
|
|
||||||
void CMapHandler::getTerrainDescr( const int3 &pos, std::string & out, bool terName )
|
void CMapHandler::getTerrainDescr( const int3 &pos, std::string & out, bool terName )
|
||||||
@ -1567,10 +1575,6 @@ intptr_t CMapHandler::CMapCache::genKey(intptr_t realPtr, ui8 mod)
|
|||||||
return (intptr_t)(realPtr ^ (mod << (sizeof(intptr_t) - 2))); // maybe some cleaner method to pack rotation into cache key?
|
return (intptr_t)(realPtr ^ (mod << (sizeof(intptr_t) - 2))); // maybe some cleaner method to pack rotation into cache key?
|
||||||
}
|
}
|
||||||
|
|
||||||
TerrainTile2::TerrainTile2()
|
|
||||||
:terbitmap(nullptr)
|
|
||||||
{}
|
|
||||||
|
|
||||||
bool CMapHandler::compareObjectBlitOrder(const CGObjectInstance * a, const CGObjectInstance * b)
|
bool CMapHandler::compareObjectBlitOrder(const CGObjectInstance * a, const CGObjectInstance * b)
|
||||||
{
|
{
|
||||||
if (!a)
|
if (!a)
|
||||||
|
@ -80,10 +80,7 @@ struct TerrainTileObject
|
|||||||
|
|
||||||
struct TerrainTile2
|
struct TerrainTile2
|
||||||
{
|
{
|
||||||
SDL_Surface * terbitmap; //bitmap of terrain
|
|
||||||
|
|
||||||
std::vector<TerrainTileObject> objects; //pointers to objects being on this tile with rects to be easier to blit this tile on screen
|
std::vector<TerrainTileObject> objects; //pointers to objects being on this tile with rects to be easier to blit this tile on screen
|
||||||
TerrainTile2();
|
|
||||||
};
|
};
|
||||||
|
|
||||||
struct MapDrawingInfo
|
struct MapDrawingInfo
|
||||||
@ -366,15 +363,20 @@ public:
|
|||||||
int offsetX;
|
int offsetX;
|
||||||
int offsetY;
|
int offsetY;
|
||||||
|
|
||||||
//Fog of War cache (not owned)
|
std::vector<std::vector<SDL_Surface *> > terrainGraphics; // [terrain id] [view type]
|
||||||
std::vector<const IImage *> FoWfullHide;
|
|
||||||
std::vector<const IImage *> FoWpartialHide;
|
|
||||||
|
|
||||||
std::vector<std::vector<SDL_Surface *> > terrainGraphics; // [terrain id] [view type] [rotation type]
|
|
||||||
std::vector<CDefEssential *> roadDefs;
|
std::vector<CDefEssential *> roadDefs;
|
||||||
std::vector<CDefEssential *> staticRiverDefs;
|
std::vector<CDefEssential *> staticRiverDefs;
|
||||||
|
|
||||||
std::vector<std::vector<std::vector<ui8> > > hideBitmap; //specifies number of graphic that should be used to fully hide a tile
|
//Fog of War cache (not owned)
|
||||||
|
std::vector<const IImage *> FoWfullHide;
|
||||||
|
std::vector<std::vector<std::vector<ui8> > > hideBitmap; //frame indexes (in FoWfullHide) of graphic that should be used to fully hide a tile
|
||||||
|
|
||||||
|
std::vector<const IImage *> FoWpartialHide;
|
||||||
|
|
||||||
|
//edge graphics
|
||||||
|
std::unique_ptr<CAnimation> egdeAnimation;
|
||||||
|
std::vector<const IImage *> egdeImages;//cache of links to egdeAnimation (for faster access)
|
||||||
|
PseudoV< PseudoV< PseudoV <ui8> > > edgeFrames; //frame indexes (in egdeImages) of tile outside of map
|
||||||
|
|
||||||
mutable std::map<const CGObjectInstance*, ui8> animationPhase;
|
mutable std::map<const CGObjectInstance*, ui8> animationPhase;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user