Qt: Pay down technical debt with map caches

This commit is contained in:
Vicki Pfau 2021-11-17 17:52:25 -08:00
parent 04b085cf9a
commit d6ad731ebe
8 changed files with 24 additions and 12 deletions

View File

@ -31,6 +31,8 @@ DECL_BIT(mMapCacheEntryFlags, HMirror, 5);
DECL_BIT(mMapCacheEntryFlags, VMirror, 6);
DECL_BITS(mMapCacheEntryFlags, Mirror, 5, 2);
#define mMapCacheTileCount(C) (1 << mMapCacheSystemInfoGetTilesWide((C)->sysConfig)) * (1 << mMapCacheSystemInfoGetTilesHigh((C)->sysConfig))
struct mMapCacheEntry {
uint32_t vramVersion;
uint16_t tileId;

View File

@ -32,7 +32,7 @@ static void _redoCacheSize(struct mMapCache* cache) {
return;
}
size_t tiles = (1 << mMapCacheSystemInfoGetTilesWide(cache->sysConfig)) * (1 << mMapCacheSystemInfoGetTilesHigh(cache->sysConfig));
size_t tiles = mMapCacheTileCount(cache);
cache->cache = anonymousMemoryMap(8 * 8 * sizeof(color_t) * tiles);
cache->status = anonymousMemoryMap(tiles * sizeof(*cache->status));
}
@ -54,12 +54,12 @@ void mMapCacheConfigureSystem(struct mMapCache* cache, mMapCacheSystemInfo confi
cache->sysConfig = config;
_redoCacheSize(cache);
size_t mapSize = (1 << mMapCacheSystemInfoGetTilesWide(cache->sysConfig)) * (1 << mMapCacheSystemInfoGetTilesHigh(cache->sysConfig));
size_t mapSize = mMapCacheTileCount(cache);
cache->mapSize = mapSize << mMapCacheSystemInfoGetMapAlign(cache->sysConfig);
}
void mMapCacheConfigureMap(struct mMapCache* cache, uint32_t mapStart) {
size_t tiles = (1 << mMapCacheSystemInfoGetTilesWide(cache->sysConfig)) * (1 << mMapCacheSystemInfoGetTilesHigh(cache->sysConfig));
size_t tiles = mMapCacheTileCount(cache);
memset(cache->status, 0, tiles * sizeof(*cache->status));
cache->mapStart = mapStart;
}

View File

@ -112,15 +112,19 @@ void AssetView::compositeTile(const void* tBuffer, void* buffer, size_t stride,
}
}
QImage AssetView::compositeMap(int map, mMapCacheEntry* mapStatus) {
QImage AssetView::compositeMap(int map, QVector<mMapCacheEntry>* mapStatus) {
mMapCache* mapCache = mMapCacheSetGetPointer(&m_cacheSet->maps, map);
int tilesW = 1 << mMapCacheSystemInfoGetTilesWide(mapCache->sysConfig);
int tilesH = 1 << mMapCacheSystemInfoGetTilesHigh(mapCache->sysConfig);
if (mapStatus->size() != tilesW * tilesH) {
mapStatus->resize(tilesW * tilesH);
mapStatus->fill({});
}
QImage rawMap = QImage(QSize(tilesW * 8, tilesH * 8), QImage::Format_ARGB32);
uchar* bgBits = rawMap.bits();
for (int j = 0; j < tilesH; ++j) {
for (int i = 0; i < tilesW; ++i) {
mMapCacheCleanTile(mapCache, mapStatus, i, j);
mMapCacheCleanTile(mapCache, mapStatus->data(), i, j);
}
for (int i = 0; i < 8; ++i) {
memcpy(static_cast<void*>(&bgBits[tilesW * 32 * (i + j * 8)]), mMapCacheGetRow(mapCache, i + j * 8), tilesW * 32);

View File

@ -65,7 +65,7 @@ protected:
};
static void compositeTile(const void* tile, void* image, size_t stride, size_t x, size_t y, int depth = 8);
QImage compositeMap(int map, mMapCacheEntry*);
QImage compositeMap(int map, QVector<mMapCacheEntry>*);
QImage compositeObj(const ObjInfo&);
bool lookupObj(int id, struct ObjInfo*);

View File

@ -245,7 +245,7 @@ void FrameView::updateTilesGBA(bool) {
m_queue.append({
{ LayerId::BACKGROUND, bg },
!m_disabled.contains({ LayerId::BACKGROUND, bg }),
QPixmap::fromImage(compositeMap(bg, m_mapStatus[bg])),
QPixmap::fromImage(compositeMap(bg, &m_mapStatus[bg])),
{}, offset, true, false
});
if (m_queue.back().image.hasAlpha()) {

View File

@ -108,7 +108,7 @@ private:
QSet<LayerId> m_disabled;
QPixmap m_composited;
QPixmap m_rendered;
mMapCacheEntry m_mapStatus[4][128 * 128] = {}; // TODO: Correct size
QVector<mMapCacheEntry> m_mapStatus[4];
ColorPicker m_backdropPicker;
QColor m_overrideBackdrop;

View File

@ -116,12 +116,18 @@ void MapView::selectMap(int map) {
return;
}
m_map = map;
m_mapStatus.fill({});
updateTiles(true);
}
void MapView::selectTile(int x, int y) {
CoreController::Interrupter interrupter(m_controller);
mMapCache* mapCache = mMapCacheSetGetPointer(&m_cacheSet->maps, m_map);
int tiles = mMapCacheTileCount(mapCache);
if (m_mapStatus.size() != tiles) {
m_mapStatus.resize(tiles);
m_mapStatus.fill({});
}
size_t tileCache = mTileCacheSetIndex(&m_cacheSet->tiles, mapCache->tileCache);
m_ui.tile->setBoundary(m_boundary, tileCache, tileCache);
uint32_t location = mMapCacheTileId(mapCache, x, y);
@ -221,7 +227,7 @@ void MapView::updateTilesGBA(bool) {
m_rawMap = QImage(QSize(width, height), QImage::Format_ARGB32);
uchar* bgBits = m_rawMap.bits();
for (int j = 0; j < height; ++j) {
mBitmapCacheCleanRow(bitmapCache, m_bitmapStatus, j);
mBitmapCacheCleanRow(bitmapCache, m_bitmapStatus.data(), j);
memcpy(static_cast<void*>(&bgBits[width * j * 4]), mBitmapCacheGetRow(bitmapCache, j), width * 4);
}
m_rawMap = m_rawMap.convertToFormat(QImage::Format_RGB32).rgbSwapped();
@ -239,7 +245,7 @@ void MapView::updateTilesGBA(bool) {
m_ui.bgInfo->setCustomProperty("priority", priority);
m_ui.bgInfo->setCustomProperty("offset", offset);
m_ui.bgInfo->setCustomProperty("transform", transform);
m_rawMap = compositeMap(m_map, m_mapStatus);
m_rawMap = compositeMap(m_map, &m_mapStatus);
}
}
QPixmap map = QPixmap::fromImage(m_rawMap.convertToFormat(QImage::Format_RGB32));

View File

@ -43,8 +43,8 @@ private:
Ui::MapView m_ui;
std::shared_ptr<CoreController> m_controller;
mMapCacheEntry m_mapStatus[128 * 128] = {}; // TODO: Correct size
mBitmapCacheEntry m_bitmapStatus[512 * 2] = {}; // TODO: Correct size
QVector<mMapCacheEntry> m_mapStatus;
QVector<mBitmapCacheEntry> m_bitmapStatus{512 * 2}; // TODO: Correct size
int m_map = 0;
QImage m_rawMap;
int m_boundary;