aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Region/CoreModules/Hypergrid
diff options
context:
space:
mode:
Diffstat (limited to 'OpenSim/Region/CoreModules/Hypergrid')
-rw-r--r--OpenSim/Region/CoreModules/Hypergrid/HGWorldMapModule.cs103
1 files changed, 7 insertions, 96 deletions
diff --git a/OpenSim/Region/CoreModules/Hypergrid/HGWorldMapModule.cs b/OpenSim/Region/CoreModules/Hypergrid/HGWorldMapModule.cs
index 6143c87..440765a 100644
--- a/OpenSim/Region/CoreModules/Hypergrid/HGWorldMapModule.cs
+++ b/OpenSim/Region/CoreModules/Hypergrid/HGWorldMapModule.cs
@@ -51,39 +51,6 @@ namespace OpenSim.Region.CoreModules.Hypergrid
51 m_Enabled = true; 51 m_Enabled = true;
52 } 52 }
53 53
54 public override void AddRegion(Scene scene)
55 {
56 if (!m_Enabled)
57 return;
58
59 m_log.Info("[HGMap] Initializing...");
60 lock (scene)
61 {
62 m_scene = scene;
63
64 m_scene.RegisterModuleInterface<IWorldMapModule>(this);
65
66 m_scene.AddCommand(
67 this, "export-map",
68 "export-map [<path>]",
69 "Save an image of the world map", HandleExportWorldMapConsoleCommand);
70 }
71 }
72
73 public override void RemoveRegion(Scene scene)
74 {
75 if (!m_Enabled)
76 return;
77
78 lock (m_scene)
79 {
80 m_Enabled = false;
81 m_scene.UnregisterModuleInterface<IWorldMapModule>(this);
82 // TODO: m_scene.RemoveCommand(this, "export-map");
83 m_scene = null;
84 }
85 }
86
87 public override string Name 54 public override string Name
88 { 55 {
89 get { return "HGWorldMap"; } 56 get { return "HGWorldMap"; }
@@ -91,74 +58,18 @@ namespace OpenSim.Region.CoreModules.Hypergrid
91 58
92 #endregion 59 #endregion
93 60
94 /// <summary> 61 protected override void GetAndSendBlocks(IClientAPI remoteClient, int minX, int minY, int maxX, int maxY, uint flag)
95 /// Requests map blocks in area of minX, maxX, minY, MaxY in world cordinates
96 /// </summary>
97 /// <param name="minX"></param>
98 /// <param name="minY"></param>
99 /// <param name="maxX"></param>
100 /// <param name="maxY"></param>
101 public override void RequestMapBlocks(IClientAPI remoteClient, int minX, int minY, int maxX, int maxY, uint flag)
102 { 62 {
103 // 63 List<MapBlockData> mapBlocks = m_scene.SceneGridService.RequestNeighbourMapBlocks(minX - 4, minY - 4, maxX + 4, maxY + 4);
104 // WARNING!!! COPY & PASTE FROM SUPERCLASS
105 // The only difference is at the very end
106 //
107
108 m_log.Info("[HGMap]: Request map blocks " + minX + "-" + maxX + " " + minY + "-" + maxY);
109 64
110 //m_scene.ForEachScenePresence(delegate (ScenePresence sp) { 65 // Different from super
111 // if (!sp.IsChildAgent && sp.UUID == remoteClient.AgentId) 66 FillInMap(mapBlocks, minX, minY, maxX, maxY);
112 // { 67 //
113 // m_log.Debug("XXX Root agent");
114 // DoRequestMapBlocks(remoteClient, minX, minY, maxX, maxY, flag);
115 // }
116 //};
117
118 List<MapBlockData> mapBlocks;
119 if ((flag & 0x10000) != 0) // user clicked on the map a tile that isn't visible
120 {
121 List<MapBlockData> response = new List<MapBlockData>();
122
123 // this should return one mapblock at most. But make sure: Look whether the one we requested is in there
124 mapBlocks = m_scene.SceneGridService.RequestNeighbourMapBlocks(minX, minY, maxX, maxY);
125 if (mapBlocks != null)
126 {
127 foreach (MapBlockData block in mapBlocks)
128 {
129 if (block.X == minX && block.Y == minY)
130 {
131 // found it => add it to response
132 response.Add(block);
133 break;
134 }
135 }
136 }
137
138 if (response.Count == 0)
139 {
140 // response still empty => couldn't find the map-tile the user clicked on => tell the client
141 MapBlockData block = new MapBlockData();
142 block.X = (ushort)minX;
143 block.Y = (ushort)minY;
144 block.Access = 254; // == not there
145 response.Add(block);
146 }
147 remoteClient.SendMapBlock(response, 0);
148 }
149 else
150 {
151 // normal mapblock request. Use the provided values
152 mapBlocks = m_scene.SceneGridService.RequestNeighbourMapBlocks(minX - 4, minY - 4, maxX + 4, maxY + 4);
153
154 // Different from super
155 FillInMap(mapBlocks, minX, minY, maxX, maxY);
156 //
157 68
158 remoteClient.SendMapBlock(mapBlocks, flag); 69 remoteClient.SendMapBlock(mapBlocks, flag);
159 }
160 } 70 }
161 71
72
162 private void FillInMap(List<MapBlockData> mapBlocks, int minX, int minY, int maxX, int maxY) 73 private void FillInMap(List<MapBlockData> mapBlocks, int minX, int minY, int maxX, int maxY)
163 { 74 {
164 for (int x = minX; x <= maxX; x++) 75 for (int x = minX; x <= maxX; x++)