feat(editor): Find Valid Tile button, improved ADT loading workflow

- "Find Valid Tile" button in Load dialog: auto-scans manifest for the
  first available ADT tile of the selected map (checks center range
  25-45 first for open world, then full 0-63 for dungeons)
- Fixes "wrong coords" issue — dungeons use different tile coords than
  open world maps, now auto-detected
- Map name lowercased for manifest lookup consistency
- Tile check shows green "Tile found" or red "Tile not found" indicator
This commit is contained in:
Kelsi 2026-05-05 06:35:37 -07:00
parent 79a091526e
commit d253aed635
3 changed files with 54 additions and 9 deletions

View file

@ -89,6 +89,8 @@ void AssetBrowser::initialize(pipeline::AssetManager* am) {
mapNames_.assign(mapSet.begin(), mapSet.end());
std::sort(mapNames_.begin(), mapNames_.end());
LOG_INFO(" Maps found: ", mapNames_.size());
std::sort(textures_.begin(), textures_.end(),
[](const AssetEntry& a, const AssetEntry& b) { return a.wowPath < b.wowPath; });
std::sort(m2Models_.begin(), m2Models_.end(),
@ -105,7 +107,24 @@ void AssetBrowser::initialize(pipeline::AssetManager* am) {
std::sort(wmoDirs_.begin(), wmoDirs_.end());
LOG_INFO("Asset browser: ", textures_.size(), " textures, ",
m2Models_.size(), " M2s, ", wmos_.size(), " WMOs indexed");
m2Models_.size(), " M2s, ", wmos_.size(), " WMOs indexed, ",
mapNames_.size(), " maps");
}
std::vector<std::pair<int,int>> AssetBrowser::getMapTiles(const std::string& mapName) const {
// Build tile list by checking manifest for each possible ADT
// Only called when user selects a map, so 64x64 is fine
std::vector<std::pair<int,int>> tiles;
for (int x = 0; x < 64; x++) {
for (int y = 0; y < 64; y++) {
std::string path = "world\\maps\\" + mapName + "\\" + mapName + "_" +
std::to_string(x) + "_" + std::to_string(y) + ".adt";
// We stored entries as lowercase, so this should match
// But we don't have direct access to entries here
// Use a dummy check — the UI already does manifest lookups
}
}
return tiles; // Empty for now — UI uses direct manifest check per tile
}
} // namespace editor

View file

@ -28,6 +28,7 @@ public:
const std::vector<std::string>& getWMODirectories() const { return wmoDirs_; }
const std::vector<std::string>& getMapNames() const { return mapNames_; }
std::vector<std::pair<int,int>> getMapTiles(const std::string& mapName) const;
bool isInitialized() const { return initialized_; }

View file

@ -343,17 +343,42 @@ void EditorUI::renderLoadDialog(EditorApp& app) {
// Check if the selected tile exists
{
std::string testPath = std::string("world\\maps\\") + loadMapNameBuf_ + "\\" +
loadMapNameBuf_ + "_" + std::to_string(loadTileX_) + "_" +
std::to_string(loadTileY_) + ".adt";
std::string lower = testPath;
std::transform(lower.begin(), lower.end(), lower.begin(),
std::string mapLower(loadMapNameBuf_);
std::transform(mapLower.begin(), mapLower.end(), mapLower.begin(),
[](unsigned char c) { return std::tolower(c); });
bool exists = app.getAssetManager()->getManifest().hasEntry(lower);
std::string testPath = "world\\maps\\" + mapLower + "\\" + mapLower + "_" +
std::to_string(loadTileX_) + "_" + std::to_string(loadTileY_) + ".adt";
bool exists = app.getAssetManager()->getManifest().hasEntry(testPath);
if (exists)
ImGui::TextColored(ImVec4(0.3f, 0.9f, 0.3f, 1), "Tile found in manifest");
ImGui::TextColored(ImVec4(0.3f, 0.9f, 0.3f, 1), "Tile found");
else
ImGui::TextColored(ImVec4(0.9f, 0.4f, 0.3f, 1), "Tile not found — try different coords");
ImGui::TextColored(ImVec4(0.9f, 0.4f, 0.3f, 1), "Tile not found");
ImGui::SameLine();
if (ImGui::SmallButton("Find Valid Tile")) {
bool found = false;
for (int x = 25; x < 45 && !found; x++) {
for (int y = 25; y < 45 && !found; y++) {
std::string tp = "world\\maps\\" + mapLower + "\\" + mapLower + "_" +
std::to_string(x) + "_" + std::to_string(y) + ".adt";
if (app.getAssetManager()->getManifest().hasEntry(tp)) {
loadTileX_ = x; loadTileY_ = y; found = true;
}
}
}
if (!found) {
for (int x = 0; x < 64 && !found; x++) {
for (int y = 0; y < 64 && !found; y++) {
std::string tp = "world\\maps\\" + mapLower + "\\" + mapLower + "_" +
std::to_string(x) + "_" + std::to_string(y) + ".adt";
if (app.getAssetManager()->getManifest().hasEntry(tp)) {
loadTileX_ = x; loadTileY_ = y; found = true;
}
}
}
}
}
if (ImGui::IsItemHovered()) ImGui::SetTooltip("Scans for the first available tile");
}
ImGui::Spacing();