// Assets/Scripts/World/Map/IMapService.cs
// 地图服务接口,通过 ServiceLocator 注册与查询。
// MapManager 实现此接口;MapPanel 等调用方通过接口解耦。
using System;
using System.Collections.Generic;
namespace BaseGames.World.Map
{
public interface IMapService
{
bool IsExplored(string roomId);
bool IsMapped(string roomId);
void SetMapped(string roomId);
///
/// 批量解锁地图房间(地图碎片覆盖多间房间时调用)。
/// 内部去重,对每个新增房间触发 ,最后只广播一次 EVT_MapUpdated。
///
void SetMappedBatch(IEnumerable roomIds);
MapDatabaseSO Database { get; }
/// 玩家当前所在区域 ID(最近一次 EVT_RegionChanged 对应的值)。
string CurrentRegionId { get; }
/// 已踏入的房间总数。
int ExploredRoomCount { get; }
/// 探索进度 0~1(已探索房间数 / 数据库总房间数)。
float GetExplorationProgress();
/// 返回属于指定区域的所有房间数据;regionId 为空时返回空数组。
MapRoomDataSO[] GetRoomsByRegion(string regionId);
///
/// 当地图数据库结构发生变化(房间增删/编辑器热改/运行时热更)时触发。
/// MapPanel、MinimapHUD 等 UI 应订阅此事件以执行完整重建。
///
event Action OnDatabaseChanged;
///
/// 探索进度变化事件(读档恢复 / 房间状态变化 / SetMapped 等)。
/// 与 区分:本事件不要求 UI 销毁重建结构,
/// 仅需调用 RefreshAllCells/RebuildPins 等轻量刷新即可。
///
event Action OnExplorationChanged;
///
/// 某个房间首次被标记为 Mapped 时触发(参数为 roomId)。
/// UI 可订阅做"地图碎片解锁"动画。批量 SetMappedBatch 时对每个新增房间各触发一次。
///
event Action OnRoomMapped;
/// 主动通知所有订阅者数据库结构已变更(同时会让 Database 的空间索引失效)。
void NotifyDatabaseChanged();
}
}