aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim
diff options
context:
space:
mode:
authorBlueWall2012-01-23 11:10:42 -0500
committerBlueWall2012-01-23 11:10:42 -0500
commit0037577814b6a34a19febb1084a991e239b22569 (patch)
tree8861934903b633f82e0da32bec2d1d1940c4c497 /OpenSim
parentAdd note about setting up test databases (diff)
parentCleanup (diff)
downloadopensim-SC_OLD-0037577814b6a34a19febb1084a991e239b22569.zip
opensim-SC_OLD-0037577814b6a34a19febb1084a991e239b22569.tar.gz
opensim-SC_OLD-0037577814b6a34a19febb1084a991e239b22569.tar.bz2
opensim-SC_OLD-0037577814b6a34a19febb1084a991e239b22569.tar.xz
Merge branch 'telehub'
Diffstat (limited to 'OpenSim')
-rw-r--r--OpenSim/Region/CoreModules/World/Estate/TelehubManager.cs108
1 files changed, 55 insertions, 53 deletions
diff --git a/OpenSim/Region/CoreModules/World/Estate/TelehubManager.cs b/OpenSim/Region/CoreModules/World/Estate/TelehubManager.cs
index ee77ae1..9b92df9 100644
--- a/OpenSim/Region/CoreModules/World/Estate/TelehubManager.cs
+++ b/OpenSim/Region/CoreModules/World/Estate/TelehubManager.cs
@@ -35,83 +35,66 @@ namespace OpenSim.Region.CoreModules.World.Estate
35{ 35{
36 public class TelehubManager 36 public class TelehubManager
37 { 37 {
38
39 private UUID ObjectID;
40 private string ObjectName;
41 private Vector3 ObjectPosition;
42 Quaternion ObjectRotation;
43 List<Vector3> SpawnPoint = new List<Vector3>();
44 UUID EstateID;
45 bool m_HasTelehub = false;
46 Scene m_Scene; 38 Scene m_Scene;
47 // This will get an option...
48 Vector3 InitialSpawnPoint = new Vector3(0.0f,0.0f,0.0f);
49
50 public bool HasTelehub
51 {
52 get { return m_HasTelehub; }
53 }
54 39
55 public TelehubManager(Scene scene) 40 public TelehubManager(Scene scene)
56 { 41 {
57 m_Scene = scene; 42 m_Scene = scene;
58 } 43 }
59 44
60 // Fill our Telehub struct with values
61// public Telehub TelehubVals()
62// {
63// // Telehub telehub = new Telehub();
64// EstateSettings telehub = m_EstateSettings;
65//
66// telehub.TelehubObject = ObjectID;
67// telehub.TelehubName = ObjectName;
68// telehub.TelehubPos = ObjectPosition;
69// telehub.TelehubRot = ObjectRotation;
70// telehub. = SpawnPoint;
71// return telehub;
72// }
73
74 // Connect the Telehub 45 // Connect the Telehub
75 public bool Connect(SceneObjectPart part) 46 public bool Connect(SceneObjectPart part)
76 { 47 {
77 m_Scene.RegionInfo.RegionSettings.ClearSpawnPoints(); 48 bool result = false;
78 49
79 m_Scene.RegionInfo.RegionSettings.TelehubObject = part.UUID; 50 if (m_Scene.RegionInfo.RegionSettings.HasTelehub)
80 m_Scene.RegionInfo.RegionSettings.TelehubName = part.Name; 51 return result;
81 m_Scene.RegionInfo.RegionSettings.TelehubPos = part.AbsolutePosition;
82 m_Scene.RegionInfo.RegionSettings.TelehubRot = part.GetWorldRotation();
83 52
84 // Clear this for now 53 try
85 m_Scene.RegionInfo.RegionSettings.AddSpawnPoint(InitialSpawnPoint); 54 {
86 m_Scene.RegionInfo.RegionSettings.HasTelehub = true; 55 m_Scene.RegionInfo.RegionSettings.ClearSpawnPoints();
87 m_Scene.RegionInfo.RegionSettings.Save(); 56
88 return true; 57 m_Scene.RegionInfo.RegionSettings.TelehubObject = part.UUID;
58 m_Scene.RegionInfo.RegionSettings.TelehubName = part.Name;
59 m_Scene.RegionInfo.RegionSettings.TelehubPos = part.AbsolutePosition;
60 m_Scene.RegionInfo.RegionSettings.TelehubRot = part.GetWorldRotation();
61 m_Scene.RegionInfo.RegionSettings.AddSpawnPoint(new Vector3(0.0f,0.0f,0.0f));
62 m_Scene.RegionInfo.RegionSettings.HasTelehub = true;
63 m_Scene.RegionInfo.RegionSettings.Save();
64
65 result = true;
66 }
67 catch (Exception ex)
68 {
69 result = false;
70 }
71
72 return result;
89 } 73 }
90 74
91 // Disconnect the Telehub: Clear it out for now, look at just disableing 75 // Disconnect the Telehub:
92 public bool DisConnect(SceneObjectPart part) 76 public bool DisConnect(SceneObjectPart part)
93 { 77 {
94 bool result = false; 78 bool result = false;
95 79
96 try{ 80 if (!m_Scene.RegionInfo.RegionSettings.HasTelehub)
81 return result;
82
83 try
84 {
97 m_Scene.RegionInfo.RegionSettings.TelehubObject = UUID.Zero; 85 m_Scene.RegionInfo.RegionSettings.TelehubObject = UUID.Zero;
98 m_Scene.RegionInfo.RegionSettings.TelehubName = String.Empty; 86 m_Scene.RegionInfo.RegionSettings.TelehubName = String.Empty;
99 m_Scene.RegionInfo.RegionSettings.TelehubPos = Vector3.Zero; 87 m_Scene.RegionInfo.RegionSettings.TelehubPos = Vector3.Zero;
100 // This is probably wrong! But, HasTelehub will block access
101 m_Scene.RegionInfo.RegionSettings.TelehubRot = Quaternion.Identity;
102 m_Scene.RegionInfo.RegionSettings.ClearSpawnPoints(); 88 m_Scene.RegionInfo.RegionSettings.ClearSpawnPoints();
103 m_Scene.RegionInfo.RegionSettings.HasTelehub = false; 89 m_Scene.RegionInfo.RegionSettings.HasTelehub = false;
104 m_Scene.RegionInfo.RegionSettings.Save(); 90 m_Scene.RegionInfo.RegionSettings.Save();
91
105 result = true; 92 result = true;
106 } 93 }
107 catch (Exception ex) 94 catch (Exception ex)
108 { 95 {
109 result = false; 96 result = false;
110 } 97 }
111 finally
112 {
113
114 }
115 98
116 return result; 99 return result;
117 } 100 }
@@ -119,19 +102,38 @@ namespace OpenSim.Region.CoreModules.World.Estate
119 // Add a SpawnPoint to the Telehub 102 // Add a SpawnPoint to the Telehub
120 public bool AddSpawnPoint(Vector3 point) 103 public bool AddSpawnPoint(Vector3 point)
121 { 104 {
105 bool result = false;
122 106
123 float dist = (float) Util.GetDistanceTo(m_Scene.RegionInfo.RegionSettings.TelehubPos, point); 107 if (!m_Scene.RegionInfo.RegionSettings.HasTelehub)
124 Vector3 nvec = Util.GetNormalizedVector(point - m_Scene.RegionInfo.RegionSettings.TelehubPos); 108 return result;
125 Vector3 spoint = nvec * dist;
126 109
127 m_Scene.RegionInfo.RegionSettings.AddSpawnPoint(spoint); 110 try
128 m_Scene.RegionInfo.RegionSettings.Save(); 111 {
129 return true; 112 Vector3 thPos = m_Scene.RegionInfo.RegionSettings.TelehubPos;
113 Quaternion thRot = m_Scene.RegionInfo.RegionSettings.TelehubRot;
114
115 float dist = (float) Util.GetDistanceTo(thPos, point);
116 Vector3 nvec = Util.GetNormalizedVector(point - thPos);
117 Vector3 spoint = nvec * dist;
118
119 m_Scene.RegionInfo.RegionSettings.AddSpawnPoint(spoint);
120 m_Scene.RegionInfo.RegionSettings.Save();
121 result = true;
122 }
123 catch (Exception ex)
124 {
125 result = false;
126 }
127
128 return result;
130 } 129 }
131 130
132 // Remove a SpawnPoint from the Telehub 131 // Remove a SpawnPoint from the Telehub
133 public bool RemoveSpawnPoint(int spawnpoint) 132 public bool RemoveSpawnPoint(int spawnpoint)
134 { 133 {
134 if (!m_Scene.RegionInfo.RegionSettings.HasTelehub)
135 return false;
136
135 m_Scene.RegionInfo.RegionSettings.RemoveSpawnPoint(spawnpoint); 137 m_Scene.RegionInfo.RegionSettings.RemoveSpawnPoint(spawnpoint);
136 m_Scene.RegionInfo.RegionSettings.Save(); 138 m_Scene.RegionInfo.RegionSettings.Save();
137 139