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

