aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Region/ClientStack/Linden/UDP
diff options
context:
space:
mode:
Diffstat (limited to 'OpenSim/Region/ClientStack/Linden/UDP')
-rw-r--r--OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs187
1 files changed, 81 insertions, 106 deletions
diff --git a/OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs b/OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs
index f580e5a..fad250b 100644
--- a/OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs
+++ b/OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs
@@ -2801,6 +2801,48 @@ namespace OpenSim.Region.ClientStack.LindenUDP
2801 SendAgentGroupDataUpdate(AgentId,GroupMembership); 2801 SendAgentGroupDataUpdate(AgentId,GroupMembership);
2802 } 2802 }
2803 2803
2804 public void SendSelectedPartsProprieties(List<ISceneEntity> parts)
2805 {
2806 // udp part
2807 ObjectPropertiesPacket packet =
2808 (ObjectPropertiesPacket)PacketPool.Instance.GetPacket(PacketType.ObjectProperties);
2809 ObjectPropertiesPacket.ObjectDataBlock[] ObjectData = new ObjectPropertiesPacket.ObjectDataBlock[parts.Count];
2810
2811 int i = 0;
2812 foreach(SceneObjectPart sop in parts)
2813 ObjectData[i++] = CreateObjectPropertiesBlock(sop);
2814
2815 packet.ObjectData = ObjectData;
2816 packet.Header.Zerocoded = true;
2817 // udp send splits this mega packets correctly
2818 // mb later will avoid that to reduce gc stress
2819 OutPacket(packet, ThrottleOutPacketType.Task, true);
2820
2821 // caps physics part
2822 IEventQueue eq = Scene.RequestModuleInterface<IEventQueue>();
2823 if(eq == null)
2824 return;
2825
2826 OSDArray array = new OSDArray();
2827 foreach(SceneObjectPart sop in parts)
2828 {
2829 OSDMap physinfo = new OSDMap(6);
2830 physinfo["LocalID"] = sop.LocalId;
2831 physinfo["Density"] = sop.Density;
2832 physinfo["Friction"] = sop.Friction;
2833 physinfo["GravityMultiplier"] = sop.GravityModifier;
2834 physinfo["Restitution"] = sop.Restitution;
2835 physinfo["PhysicsShapeType"] = (int)sop.PhysicsShapeType;
2836 array.Add(physinfo);
2837 }
2838
2839 OSDMap llsdBody = new OSDMap(1);
2840 llsdBody.Add("ObjectData", array);
2841
2842 eq.Enqueue(BuildEvent("ObjectPhysicsProperties", llsdBody),AgentId);
2843 }
2844
2845
2804 public void SendPartPhysicsProprieties(ISceneEntity entity) 2846 public void SendPartPhysicsProprieties(ISceneEntity entity)
2805 { 2847 {
2806 SceneObjectPart part = (SceneObjectPart)entity; 2848 SceneObjectPart part = (SceneObjectPart)entity;
@@ -2882,18 +2924,24 @@ namespace OpenSim.Region.ClientStack.LindenUDP
2882 2924
2883 public void SendAsset(AssetRequestToClient req) 2925 public void SendAsset(AssetRequestToClient req)
2884 { 2926 {
2927 if (req.AssetInf == null)
2928 {
2929 m_log.ErrorFormat("{0} Cannot send asset {1} ({2}), asset is null",
2930 LogHeader);
2931 return;
2932 }
2933
2885 if (req.AssetInf.Data == null) 2934 if (req.AssetInf.Data == null)
2886 { 2935 {
2887 m_log.ErrorFormat("{0} Cannot send asset {1} ({2}), asset data is null", 2936 m_log.ErrorFormat("{0} Cannot send asset {1} ({2}), asset data is null",
2888 LogHeader, req.AssetInf.ID, req.AssetInf.Metadata.ContentType); 2937 LogHeader, req.AssetInf.ID, req.AssetInf.Metadata.ContentType);
2889 return; 2938 return;
2890 } 2939 }
2940
2891 int WearableOut = 0; 2941 int WearableOut = 0;
2892 bool isWearable = false; 2942 bool isWearable = false;
2893 2943
2894 if (req.AssetInf != null) 2944 isWearable = ((AssetType) req.AssetInf.Type ==
2895 isWearable =
2896 ((AssetType) req.AssetInf.Type ==
2897 AssetType.Bodypart || (AssetType) req.AssetInf.Type == AssetType.Clothing); 2945 AssetType.Bodypart || (AssetType) req.AssetInf.Type == AssetType.Clothing);
2898 2946
2899 2947
@@ -3013,7 +3061,7 @@ namespace OpenSim.Region.ClientStack.LindenUDP
3013 reply.Data.ParcelID = parcelID; 3061 reply.Data.ParcelID = parcelID;
3014 reply.Data.OwnerID = land.OwnerID; 3062 reply.Data.OwnerID = land.OwnerID;
3015 reply.Data.Name = Utils.StringToBytes(land.Name); 3063 reply.Data.Name = Utils.StringToBytes(land.Name);
3016 if (land != null && land.Description != null && land.Description != String.Empty) 3064 if (land.Description != null && land.Description != String.Empty)
3017 reply.Data.Desc = Utils.StringToBytes(land.Description.Substring(0, land.Description.Length > 254 ? 254: land.Description.Length)); 3065 reply.Data.Desc = Utils.StringToBytes(land.Description.Substring(0, land.Description.Length > 254 ? 254: land.Description.Length));
3018 else 3066 else
3019 reply.Data.Desc = new Byte[0]; 3067 reply.Data.Desc = new Byte[0];
@@ -4221,46 +4269,42 @@ namespace OpenSim.Region.ClientStack.LindenUDP
4221 4269
4222 if (!canUseImproved && !canUseCompressed) 4270 if (!canUseImproved && !canUseCompressed)
4223 { 4271 {
4272 ObjectUpdatePacket.ObjectDataBlock ablock;
4224 if (update.Entity is ScenePresence) 4273 if (update.Entity is ScenePresence)
4225 { 4274 ablock = CreateAvatarUpdateBlock((ScenePresence)update.Entity);
4226 ObjectUpdatePacket.ObjectDataBlock ablock =
4227 CreateAvatarUpdateBlock((ScenePresence)update.Entity);
4228 objectUpdateBlocks.Value.Add(ablock);
4229 maxUpdatesBytes -= ablock.Length;
4230 }
4231 else 4275 else
4232 { 4276 ablock = CreatePrimUpdateBlock((SceneObjectPart)update.Entity, this.m_agentId);
4233 ObjectUpdatePacket.ObjectDataBlock ablock = 4277 objectUpdateBlocks.Value.Add(ablock);
4234 CreatePrimUpdateBlock((SceneObjectPart)update.Entity, this.m_agentId); 4278 objectUpdates.Value.Add(update);
4235 objectUpdateBlocks.Value.Add(ablock); 4279 maxUpdatesBytes -= ablock.Length;
4236 maxUpdatesBytes -= ablock.Length; 4280
4237 }
4238 } 4281 }
4239 else if (!canUseImproved) 4282 else if (!canUseImproved)
4240 { 4283 {
4241 ObjectUpdateCompressedPacket.ObjectDataBlock ablock = 4284 ObjectUpdateCompressedPacket.ObjectDataBlock ablock =
4242 CreateCompressedUpdateBlock((SceneObjectPart)update.Entity, updateFlags); 4285 CreateCompressedUpdateBlock((SceneObjectPart)update.Entity, updateFlags);
4243 compressedUpdateBlocks.Value.Add(ablock); 4286 compressedUpdateBlocks.Value.Add(ablock);
4287 compressedUpdates.Value.Add(update);
4244 maxUpdatesBytes -= ablock.Length; 4288 maxUpdatesBytes -= ablock.Length;
4245 } 4289 }
4246 else 4290 else
4247 { 4291 {
4292 ImprovedTerseObjectUpdatePacket.ObjectDataBlock ablock;
4248 if (update.Entity is ScenePresence) 4293 if (update.Entity is ScenePresence)
4249 { 4294 {
4250 // ALL presence updates go into a special list 4295 // ALL presence updates go into a special list
4251 ImprovedTerseObjectUpdatePacket.ObjectDataBlock ablock = 4296 ablock = CreateImprovedTerseBlock(update.Entity, updateFlags.HasFlag(PrimUpdateFlags.Textures));
4252 CreateImprovedTerseBlock(update.Entity, updateFlags.HasFlag(PrimUpdateFlags.Textures));
4253 terseAgentUpdateBlocks.Value.Add(ablock); 4297 terseAgentUpdateBlocks.Value.Add(ablock);
4254 maxUpdatesBytes -= ablock.Length; 4298 terseAgentUpdates.Value.Add(update);
4255 } 4299 }
4256 else 4300 else
4257 { 4301 {
4258 // Everything else goes here 4302 // Everything else goes here
4259 ImprovedTerseObjectUpdatePacket.ObjectDataBlock ablock = 4303 ablock = CreateImprovedTerseBlock(update.Entity, updateFlags.HasFlag(PrimUpdateFlags.Textures));
4260 CreateImprovedTerseBlock(update.Entity, updateFlags.HasFlag(PrimUpdateFlags.Textures));
4261 terseUpdateBlocks.Value.Add(ablock); 4304 terseUpdateBlocks.Value.Add(ablock);
4262 maxUpdatesBytes -= ablock.Length; 4305 terseUpdates.Value.Add(update);
4263 } 4306 }
4307 maxUpdatesBytes -= ablock.Length;
4264 } 4308 }
4265 4309
4266 #endregion Block Construction 4310 #endregion Block Construction
@@ -4290,7 +4334,7 @@ namespace OpenSim.Region.ClientStack.LindenUDP
4290 for (int i = 0; i < blocks.Count; i++) 4334 for (int i = 0; i < blocks.Count; i++)
4291 packet.ObjectData[i] = blocks[i]; 4335 packet.ObjectData[i] = blocks[i];
4292 4336
4293 OutPacket(packet, ThrottleOutPacketType.Unknown, true, delegate(OutgoingPacket oPacket) { ResendPrimUpdates(terseUpdates.Value, oPacket); }); 4337 OutPacket(packet, ThrottleOutPacketType.Unknown, true, delegate(OutgoingPacket oPacket) { ResendPrimUpdates(terseAgentUpdates.Value, oPacket); });
4294 } 4338 }
4295 4339
4296 if (objectUpdateBlocks.IsValueCreated) 4340 if (objectUpdateBlocks.IsValueCreated)
@@ -4305,7 +4349,7 @@ namespace OpenSim.Region.ClientStack.LindenUDP
4305 for (int i = 0; i < blocks.Count; i++) 4349 for (int i = 0; i < blocks.Count; i++)
4306 packet.ObjectData[i] = blocks[i]; 4350 packet.ObjectData[i] = blocks[i];
4307 4351
4308 OutPacket(packet, ThrottleOutPacketType.Task, true); 4352 OutPacket(packet, ThrottleOutPacketType.Task, true, delegate(OutgoingPacket oPacket) { ResendPrimUpdates(objectUpdates.Value, oPacket); });
4309 } 4353 }
4310 4354
4311 if (compressedUpdateBlocks.IsValueCreated) 4355 if (compressedUpdateBlocks.IsValueCreated)
@@ -4320,7 +4364,7 @@ namespace OpenSim.Region.ClientStack.LindenUDP
4320 for (int i = 0; i < blocks.Count; i++) 4364 for (int i = 0; i < blocks.Count; i++)
4321 packet.ObjectData[i] = blocks[i]; 4365 packet.ObjectData[i] = blocks[i];
4322 4366
4323 OutPacket(packet, ThrottleOutPacketType.Task, true); 4367 OutPacket(packet, ThrottleOutPacketType.Task, true, delegate(OutgoingPacket oPacket) { ResendPrimUpdates(compressedUpdates.Value, oPacket); });
4324 } 4368 }
4325 4369
4326 if (terseUpdateBlocks.IsValueCreated) 4370 if (terseUpdateBlocks.IsValueCreated)
@@ -5444,22 +5488,21 @@ namespace OpenSim.Region.ClientStack.LindenUDP
5444 Quaternion rotation; 5488 Quaternion rotation;
5445 byte[] textureEntry; 5489 byte[] textureEntry;
5446 5490
5447 if (entity is ScenePresence) 5491 if (avatar)
5448 { 5492 {
5449 ScenePresence presence = (ScenePresence)entity; 5493 ScenePresence presence = (ScenePresence)entity;
5450 5494
5451 position = presence.OffsetPosition; 5495 position = presence.OffsetPosition;
5496 velocity = presence.Velocity;
5497 acceleration = Vector3.Zero;
5452 rotation = presence.Rotation; 5498 rotation = presence.Rotation;
5453 angularVelocity = presence.AngularVelocity; 5499 angularVelocity = presence.AngularVelocity;
5454 rotation = presence.Rotation;
5455 5500
5456// m_log.DebugFormat( 5501// m_log.DebugFormat(
5457// "[LLCLIENTVIEW]: Sending terse update to {0} with position {1} in {2}", Name, presence.OffsetPosition, m_scene.Name); 5502// "[LLCLIENTVIEW]: Sending terse update to {0} with position {1} in {2}", Name, presence.OffsetPosition, m_scene.Name);
5458 5503
5459 attachPoint = presence.State; 5504 attachPoint = presence.State;
5460 collisionPlane = presence.CollisionPlane; 5505 collisionPlane = presence.CollisionPlane;
5461 velocity = presence.Velocity;
5462 acceleration = Vector3.Zero;
5463 5506
5464 if (sendTexture) 5507 if (sendTexture)
5465 { 5508 {
@@ -7710,20 +7753,19 @@ namespace OpenSim.Region.ClientStack.LindenUDP
7710 return true; 7753 return true;
7711 } 7754 }
7712 #endregion 7755 #endregion
7713 7756 List<uint> thisSelection = new List<uint>();
7714 ObjectSelect handlerObjectSelect = null; 7757 ObjectSelect handlerObjectSelect = null;
7715 uint objID; 7758 uint objID;
7716 for (int i = 0; i < incomingselect.ObjectData.Length; i++) 7759 handlerObjectSelect = OnObjectSelect;
7760 if (handlerObjectSelect != null)
7717 { 7761 {
7718 objID = incomingselect.ObjectData[i].ObjectLocalID; 7762 for (int i = 0; i < incomingselect.ObjectData.Length; i++)
7719 if (!SelectedObjects.Contains(objID))
7720 SelectedObjects.Add(objID);
7721
7722 handlerObjectSelect = OnObjectSelect;
7723 if (handlerObjectSelect != null)
7724 { 7763 {
7725 handlerObjectSelect(objID, this); 7764 objID = incomingselect.ObjectData[i].ObjectLocalID;
7765 thisSelection.Add(objID);
7726 } 7766 }
7767
7768 handlerObjectSelect(thisSelection, this);
7727 } 7769 }
7728 return true; 7770 return true;
7729 } 7771 }
@@ -7746,8 +7788,6 @@ namespace OpenSim.Region.ClientStack.LindenUDP
7746 for (int i = 0; i < incomingdeselect.ObjectData.Length; i++) 7788 for (int i = 0; i < incomingdeselect.ObjectData.Length; i++)
7747 { 7789 {
7748 objID = incomingdeselect.ObjectData[i].ObjectLocalID; 7790 objID = incomingdeselect.ObjectData[i].ObjectLocalID;
7749 if (SelectedObjects.Contains(objID))
7750 SelectedObjects.Remove(objID);
7751 7791
7752 handlerObjectDeselect = OnObjectDeselect; 7792 handlerObjectDeselect = OnObjectDeselect;
7753 if (handlerObjectDeselect != null) 7793 if (handlerObjectDeselect != null)
@@ -7969,6 +8009,7 @@ namespace OpenSim.Region.ClientStack.LindenUDP
7969 touchArgs.Add(arg); 8009 touchArgs.Add(arg);
7970 } 8010 }
7971 } 8011 }
8012
7972 handlerGrabUpdate(grabUpdate.ObjectData.ObjectID, grabUpdate.ObjectData.GrabOffsetInitial, 8013 handlerGrabUpdate(grabUpdate.ObjectData.ObjectID, grabUpdate.ObjectData.GrabOffsetInitial,
7973 grabUpdate.ObjectData.GrabPosition, this, touchArgs); 8014 grabUpdate.ObjectData.GrabPosition, this, touchArgs);
7974 } 8015 }
@@ -12409,72 +12450,6 @@ namespace OpenSim.Region.ClientStack.LindenUDP
12409 /// <param name="simclient"></param> 12450 /// <param name="simclient"></param>
12410 /// <param name="packet"></param> 12451 /// <param name="packet"></param>
12411 /// <returns></returns> 12452 /// <returns></returns>
12412 // TODO: Convert old handler to use new method
12413/*
12414 protected bool HandleAgentTextureCached(IClientAPI simclient, Packet packet)
12415 {
12416 AgentCachedTexturePacket cachedtex = (AgentCachedTexturePacket)packet;
12417 AgentCachedTextureResponsePacket cachedresp = (AgentCachedTextureResponsePacket)PacketPool.Instance.GetPacket(PacketType.AgentCachedTextureResponse);
12418
12419 if (cachedtex.AgentData.SessionID != SessionId)
12420 return false;
12421
12422
12423
12424 // TODO: don't create new blocks if recycling an old packet
12425 cachedresp.AgentData.AgentID = AgentId;
12426 cachedresp.AgentData.SessionID = m_sessionId;
12427 cachedresp.AgentData.SerialNum = m_cachedTextureSerial;
12428 m_cachedTextureSerial++;
12429 cachedresp.WearableData =
12430 new AgentCachedTextureResponsePacket.WearableDataBlock[cachedtex.WearableData.Length];
12431
12432 int maxWearablesLoop = cachedtex.WearableData.Length;
12433 if (maxWearablesLoop > AvatarWearable.MAX_WEARABLES)
12434 maxWearablesLoop = AvatarWearable.MAX_WEARABLES;
12435
12436 // Find the cached baked textures for this user, if they're available
12437
12438 IAssetService cache = m_scene.AssetService;
12439 IBakedTextureModule bakedTextureModule = m_scene.RequestModuleInterface<IBakedTextureModule>();
12440
12441 WearableCacheItem[] cacheItems = null;
12442
12443 if (bakedTextureModule != null && cache != null)
12444 {
12445 ScenePresence p = m_scene.GetScenePresence(AgentId);
12446 if (p.Appearance != null)
12447 {
12448 if (p.Appearance.WearableCacheItems == null || p.Appearance.WearableCacheItemsDirty)
12449 {
12450 try
12451 {
12452 cacheItems = bakedTextureModule.Get(AgentId);
12453 p.Appearance.WearableCacheItems = cacheItems;
12454 p.Appearance.WearableCacheItemsDirty = false;
12455 }
12456 catch (Exception)
12457 {
12458 cacheItems = null;
12459 }
12460
12461 }
12462 else if (p.Appearance.WearableCacheItems != null)
12463 {
12464 cacheItems = p.Appearance.WearableCacheItems;
12465 }
12466 }
12467 }
12468
12469 CachedTextureRequest handlerCachedTextureRequest = OnCachedTextureRequest;
12470 if (handlerCachedTextureRequest != null)
12471 {
12472 handlerCachedTextureRequest(simclient,cachedtex.AgentData.SerialNum,requestArgs);
12473 }
12474
12475 return true;
12476 }
12477*/
12478 12453
12479 protected bool HandleAgentTextureCached(IClientAPI simclient, Packet packet) 12454 protected bool HandleAgentTextureCached(IClientAPI simclient, Packet packet)
12480 { 12455 {