Annotation of /branches/taiga-0.1/ModularRex/RexParts/ModrexObjects.cs
Parent Directory
|
Revision Log
Revision 80 -
(view)
(download)
Original Path: trunk/ModularRex/RexParts/ModrexObjects.cs
| 1 : | mikkopa | 39 | using System; |
| 2 : | using System.Collections.Generic; | ||
| 3 : | using System.IO; | ||
| 4 : | using System.Reflection; | ||
| 5 : | using log4net; | ||
| 6 : | using ModularRex.RexFramework; | ||
| 7 : | using ModularRex.RexNetwork; | ||
| 8 : | using Nini.Config; | ||
| 9 : | using OpenMetaverse; | ||
| 10 : | mikkopa | 63 | using OpenSim.Region.Framework.Interfaces; |
| 11 : | using OpenSim.Region.Framework.Scenes; | ||
| 12 : | mikkopa | 39 | using OpenSim.Data.NHibernate; |
| 13 : | tuco | 53 | using OpenSim.Framework; |
| 14 : | mikkopa | 39 | |
| 15 : | namespace ModularRex.RexParts | ||
| 16 : | { | ||
| 17 : | tuco | 57 | public class ModrexObjects : IRegionModule, IRexObjectPropertiesEventManager |
| 18 : | mikkopa | 39 | { |
| 19 : | private static readonly ILog m_log = | ||
| 20 : | LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType); | ||
| 21 : | |||
| 22 : | tuco | 57 | private RexObjectPropertiesManager RexObjectPropertiesCache = new RexObjectPropertiesManager(); |
| 23 : | mikkopa | 39 | private List<Scene> m_scenes = new List<Scene>(); |
| 24 : | |||
| 25 : | private NHibernateRexObjectData m_db; | ||
| 26 : | private string m_db_connectionstring; | ||
| 27 : | |||
| 28 : | tuco | 57 | public delegate void OnChangePythonClassDelegate(UUID id); |
| 29 : | mikkopa | 42 | public event OnChangePythonClassDelegate OnPythonClassChange; |
| 30 : | |||
| 31 : | mikkopa | 39 | public void Initialise(Scene scene, IConfigSource source) |
| 32 : | { | ||
| 33 : | m_scenes.Add(scene); | ||
| 34 : | |||
| 35 : | scene.EventManager.OnClientConnect += EventManager_OnClientConnect; | ||
| 36 : | mikkopa | 75 | scene.SceneContents.OnObjectDuplicate += SceneGraph_OnObjectDuplicate; |
| 37 : | scene.SceneContents.OnObjectRemove += SceneGraph_OnObjectRemove; | ||
| 38 : | mikkopa | 39 | |
| 39 : | tuco | 80 | scene.AddCommand(this, "modreximport", "load 0.4 rex database <connstring>", "conn string example: SQLiteDialect;SQLite20Driver;Data Source=beneath_the_waves.db;Version=3", HandleLoadRexLegacyData); |
| 40 : | mikkopa | 39 | |
| 41 : | if (m_db == null) | ||
| 42 : | { | ||
| 43 : | m_db = new NHibernateRexObjectData(); | ||
| 44 : | } | ||
| 45 : | |||
| 46 : | if (source != null) | ||
| 47 : | { | ||
| 48 : | try | ||
| 49 : | { | ||
| 50 : | m_db_connectionstring = source.Configs["realXtend"].GetString("db_connectionstring", "SQLiteDialect;SQLite20Driver;Data Source=RexObjects.db;Version=3"); | ||
| 51 : | |||
| 52 : | } | ||
| 53 : | catch (Exception) | ||
| 54 : | { | ||
| 55 : | |||
| 56 : | m_db_connectionstring = "SQLiteDialect;SQLite20Driver;Data Source=RexObjects.db;Version=3"; | ||
| 57 : | } | ||
| 58 : | } | ||
| 59 : | else | ||
| 60 : | { | ||
| 61 : | m_db_connectionstring = "SQLiteDialect;SQLite20Driver;Data Source=RexObjects.db;Version=3"; | ||
| 62 : | } | ||
| 63 : | } | ||
| 64 : | |||
| 65 : | void EventManager_OnClientConnect(OpenSim.Framework.Client.IClientCore client) | ||
| 66 : | { | ||
| 67 : | RexClientView rcv; | ||
| 68 : | if (client.TryGet(out rcv)) | ||
| 69 : | { | ||
| 70 : | rcv.OnRexObjectProperties += rcv_OnRexObjectProperties; | ||
| 71 : | //rcv.OnChatFromClient += rcv_OnChatFromClient; | ||
| 72 : | |||
| 73 : | // Send them the current Scene. | ||
| 74 : | SendAllPropertiesToUser(rcv); | ||
| 75 : | } | ||
| 76 : | } | ||
| 77 : | |||
| 78 : | tuco | 59 | void SceneGraph_OnObjectDuplicate(EntityBase original, EntityBase clone) |
| 79 : | { | ||
| 80 : | RexObjectProperties origprops = GetObject(original.UUID); | ||
| 81 : | RexObjectProperties cloneprops = GetObject(clone.UUID); | ||
| 82 : | |||
| 83 : | cloneprops.SetRexPrimDataFromObject(origprops); | ||
| 84 : | } | ||
| 85 : | |||
| 86 : | tuco | 60 | void SceneGraph_OnObjectRemove(EntityBase obj) |
| 87 : | { | ||
| 88 : | DeleteObject(obj.UUID); | ||
| 89 : | } | ||
| 90 : | |||
| 91 : | |||
| 92 : | mikkopa | 39 | //void rcv_OnChatFromClient(object sender, OpenSim.Framework.OSChatMessage e) |
| 93 : | //{ | ||
| 94 : | // if (e.Message.StartsWith("/rexobj ")) | ||
| 95 : | // { | ||
| 96 : | // string uuid = e.Message.Split(' ')[1]; | ||
| 97 : | // string asset = e.Message.Split(' ')[2]; | ||
| 98 : | |||
| 99 : | // UUID prim = new UUID(uuid); | ||
| 100 : | // UUID assetID = new UUID(asset); | ||
| 101 : | |||
| 102 : | // m_objs[prim].RexMeshUUID = assetID; | ||
| 103 : | // SendPropertiesToAllUsers(prim, m_objs[prim]); | ||
| 104 : | // } | ||
| 105 : | //} | ||
| 106 : | |||
| 107 : | void SendPropertiesToAllUsers(UUID id, RexObjectProperties props) | ||
| 108 : | { | ||
| 109 : | foreach (Scene scene in m_scenes) | ||
| 110 : | { | ||
| 111 : | scene.ForEachScenePresence( | ||
| 112 : | delegate(ScenePresence avatar) | ||
| 113 : | { | ||
| 114 : | RexClientView rex; | ||
| 115 : | if (avatar.ClientView.TryGet(out rex)) | ||
| 116 : | { | ||
| 117 : | rex.SendRexObjectProperties(id,props); | ||
| 118 : | } | ||
| 119 : | }); | ||
| 120 : | } | ||
| 121 : | } | ||
| 122 : | |||
| 123 : | mikkopa | 69 | private void SendPreloadAssetsToUser(RexClientView user) |
| 124 : | { | ||
| 125 : | try | ||
| 126 : | { | ||
| 127 : | Scene ourScene = null; | ||
| 128 : | foreach (Scene s in m_scenes) | ||
| 129 : | { | ||
| 130 : | if (user.Scene.RegionInfo.RegionHandle == s.RegionInfo.RegionHandle) | ||
| 131 : | ourScene = s; | ||
| 132 : | } | ||
| 133 : | |||
| 134 : | if (ourScene != null) | ||
| 135 : | { | ||
| 136 : | if (ourScene.Modules.ContainsKey("RexAssetPreload")) | ||
| 137 : | { | ||
| 138 : | RexAssetPreload module = (RexAssetPreload)ourScene.Modules["RexAssetPreload"]; | ||
| 139 : | if (module.PreloadAssetDictionary.Count > 0) | ||
| 140 : | { | ||
| 141 : | user.SendRexPreloadAssets(module.PreloadAssetDictionary); | ||
| 142 : | } | ||
| 143 : | } | ||
| 144 : | } | ||
| 145 : | } | ||
| 146 : | catch (Exception e) | ||
| 147 : | { | ||
| 148 : | m_log.Error("[MODREXOBJECTS]: Sending preload assets failed.", e); | ||
| 149 : | } | ||
| 150 : | } | ||
| 151 : | |||
| 152 : | mikkopa | 39 | void SendAllPropertiesToUser(RexClientView user) |
| 153 : | { | ||
| 154 : | mikkopa | 69 | SendPreloadAssetsToUser(user); |
| 155 : | |||
| 156 : | tuco | 57 | foreach (RexObjectProperties p in GetObjects()) |
| 157 : | mikkopa | 39 | { |
| 158 : | tuco | 57 | user.SendRexObjectProperties(p.ParentObjectID, p); |
| 159 : | mikkopa | 39 | } |
| 160 : | } | ||
| 161 : | |||
| 162 : | void rcv_OnRexObjectProperties(RexClientView sender, UUID id, RexObjectProperties props) | ||
| 163 : | { | ||
| 164 : | tuco | 50 | m_log.Info("[REXOBJS] Received RexObjData for " + id); |
| 165 : | mikkopa | 39 | if (props.ParentObjectID == UUID.Zero) |
| 166 : | props.ParentObjectID = id; | ||
| 167 : | tuco | 50 | |
| 168 : | tuco | 57 | // debugdata props.PrintRexPrimdata(); |
| 169 : | |||
| 170 : | RexObjectProperties currentprops = GetObject(id); | ||
| 171 : | currentprops.SetRexPrimDataFromObject(props); | ||
| 172 : | mikkopa | 39 | } |
| 173 : | |||
| 174 : | public void PostInitialise() | ||
| 175 : | { | ||
| 176 : | lock (m_db) | ||
| 177 : | { | ||
| 178 : | if (!m_db.Inizialized) | ||
| 179 : | { | ||
| 180 : | m_db.Initialise(m_db_connectionstring); | ||
| 181 : | } | ||
| 182 : | } | ||
| 183 : | tuco | 57 | LoadRexObjectPropertiesToCache(); |
| 184 : | mikkopa | 39 | } |
| 185 : | |||
| 186 : | public void Close() | ||
| 187 : | { | ||
| 188 : | ; | ||
| 189 : | } | ||
| 190 : | |||
| 191 : | public string Name | ||
| 192 : | { | ||
| 193 : | get { return "RexObjectsModule"; } | ||
| 194 : | } | ||
| 195 : | |||
| 196 : | public bool IsSharedModule | ||
| 197 : | { | ||
| 198 : | get { return true; } | ||
| 199 : | } | ||
| 200 : | mikkopa | 42 | |
| 201 : | tuco | 57 | |
| 202 : | |||
| 203 : | #region Trigger/handle rexobjectproperties events | ||
| 204 : | public void TriggerOnChangePythonClass(UUID id) | ||
| 205 : | mikkopa | 42 | { |
| 206 : | tuco | 57 | if (OnPythonClassChange != null) |
| 207 : | OnPythonClassChange(id); | ||
| 208 : | mikkopa | 42 | } |
| 209 : | |||
| 210 : | tuco | 57 | public void TriggerOnChangeCollisionMesh(UUID id) |
| 211 : | mikkopa | 42 | { |
| 212 : | tuco | 50 | // tucofixme, add |
| 213 : | //if (!GlobalSettings.Instance.m_3d_collision_models) | ||
| 214 : | // return; | ||
| 215 : | |||
| 216 : | tuco | 57 | RexObjectProperties p = GetObject(id); |
| 217 : | tuco | 50 | SceneObjectPart sop = m_scenes[0].GetSceneObjectPart(id); |
| 218 : | if (sop == null) | ||
| 219 : | { | ||
| 220 : | tuco | 57 | m_log.Error("[REXOBJS] TriggerOnChangeCollisionMesh, no SceneObjectPart for id:" + id.ToString()); |
| 221 : | tuco | 50 | return; |
| 222 : | } | ||
| 223 : | tuco | 57 | |
| 224 : | tuco | 65 | if (sop.ParentGroup != null && sop.PhysActor is IRexPhysicsActor) |
| 225 : | tuco | 50 | { |
| 226 : | tuco | 57 | if (p.RexCollisionMeshUUID != UUID.Zero) |
| 227 : | RexUpdateCollisionMesh(id); | ||
| 228 : | else | ||
| 229 : | tuco | 65 | ((IRexPhysicsActor)sop.PhysActor).SetCollisionMesh(null, "", false); |
| 230 : | tuco | 57 | } |
| 231 : | tuco | 50 | } |
| 232 : | |||
| 233 : | tuco | 57 | public void TriggerOnChangeScaleToPrim(UUID id) |
| 234 : | tuco | 50 | { |
| 235 : | // tucofixme, add | ||
| 236 : | //if (!GlobalSettings.Instance.m_3d_collision_models) | ||
| 237 : | // return; | ||
| 238 : | tuco | 57 | |
| 239 : | RexObjectProperties p = GetObject(id); | ||
| 240 : | tuco | 50 | SceneObjectPart sop = m_scenes[0].GetSceneObjectPart(id); |
| 241 : | if (sop == null) | ||
| 242 : | { | ||
| 243 : | tuco | 57 | m_log.Error("[REXOBJS] TriggerOnChangeScaleToPrim, no SceneObjectPart for id:" + id.ToString()); |
| 244 : | return; | ||
| 245 : | tuco | 50 | } |
| 246 : | |||
| 247 : | tuco | 65 | if (sop.ParentGroup != null && sop.PhysActor is IRexPhysicsActor) |
| 248 : | tuco | 50 | { |
| 249 : | tuco | 65 | ((IRexPhysicsActor)sop.PhysActor).SetBoundsScaling(p.RexScaleToPrim); |
| 250 : | tuco | 57 | sop.ParentGroup.Scene.PhysicsScene.AddPhysicsActorTaint(sop.PhysActor); |
| 251 : | tuco | 50 | } |
| 252 : | } | ||
| 253 : | |||
| 254 : | tuco | 57 | public void TriggerOnChangeRexObjectProperties(UUID id) |
| 255 : | { | ||
| 256 : | RexObjectProperties props = GetObject(id); | ||
| 257 : | |||
| 258 : | m_db.StoreObject(props); | ||
| 259 : | SendPropertiesToAllUsers(id,props); | ||
| 260 : | } | ||
| 261 : | |||
| 262 : | public void TriggerOnChangeRexObjectMetaData(UUID id) | ||
| 263 : | { | ||
| 264 : | RexObjectProperties props = GetObject(id); | ||
| 265 : | |||
| 266 : | m_db.StoreObject(props); | ||
| 267 : | // tucofixme, send metadata to all users | ||
| 268 : | } | ||
| 269 : | |||
| 270 : | |||
| 271 : | |||
| 272 : | tuco | 50 | public void RexUpdateCollisionMesh(UUID id) |
| 273 : | { | ||
| 274 : | tuco | 57 | // tucofixme, add |
| 275 : | tuco | 50 | //if (!GlobalSettings.Instance.m_3d_collision_models) |
| 276 : | // return; | ||
| 277 : | |||
| 278 : | tuco | 57 | RexObjectProperties p = GetObject(id); |
| 279 : | tuco | 50 | SceneObjectPart sop = m_scenes[0].GetSceneObjectPart(id); |
| 280 : | if (sop == null) | ||
| 281 : | { | ||
| 282 : | m_log.Error("[REXOBJS] RexUpdateCollisionMesh, no SceneObjectPart for id:" + id.ToString()); | ||
| 283 : | return; | ||
| 284 : | tuco | 57 | } |
| 285 : | |||
| 286 : | tuco | 65 | if (p.RexCollisionMeshUUID != UUID.Zero && sop.PhysActor is IRexPhysicsActor) |
| 287 : | tuco | 50 | { |
| 288 : | mikkopa | 72 | AssetBase tempmodel = sop.ParentGroup.Scene.CommsManager.AssetCache.GetAsset(p.RexCollisionMeshUUID, false); |
| 289 : | tuco | 50 | if (tempmodel != null) |
| 290 : | mikkopa | 72 | ((IRexPhysicsActor)sop.PhysActor).SetCollisionMesh(tempmodel.Data, tempmodel.Name, p.RexScaleToPrim); |
| 291 : | tuco | 50 | } |
| 292 : | tuco | 57 | } |
| 293 : | tuco | 64 | |
| 294 : | public byte GetAssetType(UUID assetid) | ||
| 295 : | { | ||
| 296 : | mikkopa | 72 | AssetBase tempmodel = m_scenes[0].CommsManager.AssetCache.GetAsset(assetid, true); |
| 297 : | tuco | 64 | if (tempmodel == null) |
| 298 : | mikkopa | 72 | m_scenes[0].CommsManager.AssetCache.GetAsset(assetid, false); |
| 299 : | tuco | 64 | |
| 300 : | if (tempmodel != null) | ||
| 301 : | mikkopa | 72 | return(byte)(tempmodel.Type); |
| 302 : | tuco | 64 | else |
| 303 : | return 0; | ||
| 304 : | } | ||
| 305 : | tuco | 57 | #endregion |
| 306 : | |||
| 307 : | |||
| 308 : | #region RexObjectProperties Cache | ||
| 309 : | |||
| 310 : | private void LoadRexObjectPropertiesToCache() | ||
| 311 : | { | ||
| 312 : | if (!m_db.Inizialized) | ||
| 313 : | { | ||
| 314 : | m_log.ErrorFormat("LoadRexObjectPropertiesToCache failed, db not initialized"); | ||
| 315 : | return; | ||
| 316 : | } | ||
| 317 : | |||
| 318 : | foreach (Scene s in m_scenes) | ||
| 319 : | { | ||
| 320 : | foreach (EntityBase e in s.Entities) | ||
| 321 : | { | ||
| 322 : | RexObjectProperties p = LoadObject(e.UUID); | ||
| 323 : | p.ParentObjectID = e.UUID; | ||
| 324 : | p.SetRexEventManager(this); | ||
| 325 : | RexObjectPropertiesCache.Add(e.UUID,p); | ||
| 326 : | |||
| 327 : | // Since loaded objects have their properties already set, any initialization that needs to be done should be here. | ||
| 328 : | if(p.RexCollisionMeshUUID != UUID.Zero) | ||
| 329 : | TriggerOnChangeCollisionMesh(e.UUID); | ||
| 330 : | |||
| 331 : | if (p.RexClassName.Length > 0) | ||
| 332 : | { | ||
| 333 : | SceneObjectPart sop = m_scenes[0].GetSceneObjectPart(p.ParentObjectID); | ||
| 334 : | if (sop != null) | ||
| 335 : | sop.SetScriptEvents(p.ParentObjectID, (int)scriptEvents.touch_start); | ||
| 336 : | } | ||
| 337 : | } | ||
| 338 : | } | ||
| 339 : | } | ||
| 340 : | |||
| 341 : | private RexObjectProperties LoadObject(UUID id) | ||
| 342 : | { | ||
| 343 : | RexObjectProperties robject = m_db.LoadObject(id); | ||
| 344 : | if (robject == null) | ||
| 345 : | { | ||
| 346 : | robject = new RexObjectProperties(); | ||
| 347 : | robject.ParentObjectID = id; | ||
| 348 : | } | ||
| 349 : | return robject; | ||
| 350 : | tuco | 50 | } |
| 351 : | |||
| 352 : | tuco | 57 | public RexObjectProperties GetObject(UUID id) |
| 353 : | { | ||
| 354 : | RexObjectProperties props = RexObjectPropertiesCache[id]; | ||
| 355 : | if (props == null) | ||
| 356 : | { | ||
| 357 : | props = new RexObjectProperties(id, this); | ||
| 358 : | RexObjectPropertiesCache.Add(id, props); | ||
| 359 : | } | ||
| 360 : | return props; | ||
| 361 : | } | ||
| 362 : | |||
| 363 : | public List<RexObjectProperties> GetObjects() | ||
| 364 : | { | ||
| 365 : | return RexObjectPropertiesCache.GetAllRexObjectProperties(); | ||
| 366 : | } | ||
| 367 : | |||
| 368 : | public bool DeleteObject(UUID id) | ||
| 369 : | { | ||
| 370 : | if (RexObjectPropertiesCache.ContainsKey(id)) | ||
| 371 : | { | ||
| 372 : | RexObjectPropertiesCache.Remove(id); | ||
| 373 : | tuco | 60 | m_db.RemoveObject(id); |
| 374 : | tuco | 57 | return true; |
| 375 : | } | ||
| 376 : | return false; | ||
| 377 : | } | ||
| 378 : | |||
| 379 : | |||
| 380 : | #endregion | ||
| 381 : | |||
| 382 : | tuco | 80 | |
| 383 : | public void HandleLoadRexLegacyData(string module, string[] args) | ||
| 384 : | { | ||
| 385 : | NHibernateRexLegacyData legacydata = new NHibernateRexLegacyData(); | ||
| 386 : | |||
| 387 : | legacydata.Initialise(args[1]); | ||
| 388 : | if(!legacydata.Inizialized) | ||
| 389 : | { | ||
| 390 : | m_log.Info("[MODREXOBJECTS]: Legacy database failed to initialize."); | ||
| 391 : | return; | ||
| 392 : | } | ||
| 393 : | |||
| 394 : | List<RexLegacyPrimData> rexprimdata = legacydata.LoadAllRexPrimData(); | ||
| 395 : | m_log.Info("[MODREXOBJECTS]: Legacy rexprimdata objects loaded:" + rexprimdata.Count.ToString()); | ||
| 396 : | |||
| 397 : | List<RexLegacyPrimMaterialData> rexprimmaterialdata = legacydata.LoadAllRexPrimMaterialData(); | ||
| 398 : | m_log.Info("[MODREXOBJECTS]: Legacy rexprimmaterialdata objects loaded:" + rexprimmaterialdata.Count.ToString()); | ||
| 399 : | |||
| 400 : | foreach (RexLegacyPrimData prim in rexprimdata) | ||
| 401 : | { | ||
| 402 : | RexObjectProperties p = GetObject(prim.UUID); | ||
| 403 : | p.SetRexPrimDataFromLegacyData(prim); | ||
| 404 : | } | ||
| 405 : | |||
| 406 : | foreach (RexLegacyPrimMaterialData primmat in rexprimmaterialdata) | ||
| 407 : | { | ||
| 408 : | RexObjectProperties p = GetObject(primmat.UUID); | ||
| 409 : | p.RexMaterials.AddMaterial((uint)primmat.MaterialIndex,primmat.MaterialUUID); | ||
| 410 : | } | ||
| 411 : | } | ||
| 412 : | |||
| 413 : | mikkopa | 39 | } |
| 414 : | } |
| ViewVC Help | |
| Powered by ViewVC 1.0.0 |

