122 lines
3.0 KiB
C++
122 lines
3.0 KiB
C++
/* Copyright: (c) Kayne Ruse 2013
|
|
*
|
|
* 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.
|
|
*/
|
|
#include "region_pager.hpp"
|
|
|
|
#include "utility.hpp"
|
|
|
|
#include <stdexcept>
|
|
#include <string>
|
|
|
|
RegionPager::RegionPager() {
|
|
//
|
|
}
|
|
|
|
RegionPager::~RegionPager() {
|
|
if (onDelete) {
|
|
for (auto& i : regionList) {
|
|
onDelete(&i);
|
|
}
|
|
}
|
|
}
|
|
|
|
Region* RegionPager::NewRegion(int x, int y) {
|
|
for (auto& i : regionList) {
|
|
if (i.GetX() == x && i.GetY() == y) {
|
|
throw(std::runtime_error("Duplicate Regions detected"));
|
|
}
|
|
}
|
|
|
|
regionList.push_front({x, y, regionWidth, regionHeight});
|
|
if (onNew) {
|
|
onNew(®ionList.front());
|
|
}
|
|
return ®ionList.front();
|
|
}
|
|
|
|
Region* RegionPager::GetRegion(int x, int y) {
|
|
for (auto& i : regionList) {
|
|
if (i.GetX() == x && i.GetY() == y) {
|
|
return &i;
|
|
}
|
|
}
|
|
//create, insert and return
|
|
regionList.push_front({x, y, regionWidth, regionHeight});
|
|
if (onNew) {
|
|
onNew(®ionList.front());
|
|
}
|
|
return ®ionList.front();
|
|
}
|
|
|
|
void RegionPager::DeleteRegion(int x, int y) {
|
|
for (std::list<Region>::iterator i = regionList.begin(); i != regionList.end(); i++) {
|
|
if (i->GetX() == x && i->GetY() == y) {
|
|
if (onDelete) {
|
|
onDelete(&(*i));
|
|
}
|
|
regionList.erase(i);
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
|
|
void RegionPager::DrawTo(SDL_Surface* const dest, TileSheetManager* const sheetMgr, int camX, int camY) {
|
|
for (auto& regionIter : regionList) {
|
|
|
|
#ifdef DEBUG
|
|
//draw the region's location
|
|
SDL_Rect box = {
|
|
Sint16(regionIter.GetX() - camX),
|
|
Sint16(regionIter.GetY() - camY),
|
|
Uint16(regionIter.GetWidth()),
|
|
Uint16(regionIter.GetHeight())
|
|
};
|
|
SDL_FillRect(dest, &box, SDL_MapRGB(dest->format, 10, 10, 20));
|
|
#endif
|
|
|
|
//draw each tile
|
|
for (auto& tileIter : *regionIter.GetTiles()) {
|
|
sheetMgr->DrawTo(
|
|
dest,
|
|
tileIter.x + regionIter.GetX() - camX,
|
|
tileIter.y + regionIter.GetY() - camY,
|
|
tileIter.tileIndex
|
|
);
|
|
}
|
|
}
|
|
}
|
|
|
|
void RegionPager::Prune(int left, int top, int right, int bottom) {
|
|
std::list<Region>::iterator it = regionList.begin();
|
|
|
|
while(it != regionList.end()) {
|
|
if (it->GetX() >= right || it->GetY() >= bottom || it->GetX() + it->GetWidth() < left || it->GetY() + it->GetHeight() < top) {
|
|
if (onDelete) {
|
|
onDelete(&(*it));
|
|
}
|
|
regionList.erase(it);
|
|
it = regionList.begin();
|
|
continue;
|
|
}
|
|
it++;
|
|
}
|
|
}
|