From e8a75151fa7d17f7862a45112508d9d93654869b Mon Sep 17 00:00:00 2001 From: UbitUmarov Date: Sun, 23 Aug 2015 04:55:18 +0100 Subject: more on world map --- .../CoreModules/World/WorldMap/WorldMapModule.cs | 21 +++++++++++++++++++-- 1 file changed, 19 insertions(+), 2 deletions(-) diff --git a/OpenSim/Region/CoreModules/World/WorldMap/WorldMapModule.cs b/OpenSim/Region/CoreModules/World/WorldMap/WorldMapModule.cs index 1ebde68..1bbd9fe 100644 --- a/OpenSim/Region/CoreModules/World/WorldMap/WorldMapModule.cs +++ b/OpenSim/Region/CoreModules/World/WorldMap/WorldMapModule.cs @@ -999,7 +999,8 @@ namespace OpenSim.Region.CoreModules.World.WorldMap /// public void RequestMapBlocks(IClientAPI remoteClient, int minX, int minY, int maxX, int maxY, uint flag) { - //m_log.ErrorFormat("[YYY] RequestMapBlocks {0}={1}={2}={3} {4}", minX, minY, maxX, maxY, flag); + m_log.DebugFormat("[WoldMapModule] RequestMapBlocks {0}={1}={2}={3} {4}", minX, minY, maxX, maxY, flag); +/* this flag does not seem to mean what his says if ((flag & 0x10000) != 0) // user clicked on qthe map a tile that isn't visible { List response = new List(); @@ -1049,8 +1050,9 @@ namespace OpenSim.Region.CoreModules.World.WorldMap else { // normal mapblock request. Use the provided values + */ GetAndSendBlocks(remoteClient, minX, minY, maxX, maxY, flag); - } + // } } protected virtual List GetAndSendBlocks(IClientAPI remoteClient, int minX, int minY, int maxX, int maxY, uint flag) @@ -1123,6 +1125,21 @@ namespace OpenSim.Region.CoreModules.World.WorldMap // (maxX + 4) * (int)Constants.RegionSize, // (minY - 4) * (int)Constants.RegionSize, // (maxY + 4) * (int)Constants.RegionSize); + + //mb it means this + if(regions.Count == 0 && (flag & 0x10000) != 0) + { + MapBlockData block = new MapBlockData(); + block.X = (ushort)minX; + block.Y = (ushort)minY; + block.MapImageId = UUID.Zero; + block.Access = (byte)SimAccess.Down; // means 'simulator is offline' + allBlocks.Add(block); + mapBlocks.Add(block); + remoteClient.SendMapBlock(mapBlocks, flag & 0xffff); + return allBlocks; + } + foreach (GridRegion r in regions) { MapBlockData block = new MapBlockData(); -- cgit v1.1