From a425e921680171c3eb3ae0c85c576030e2a8f834 Mon Sep 17 00:00:00 2001 From: Adam Frisby Date: Sat, 4 Aug 2007 00:45:55 +0000 Subject: * Little more cleaning of EstateManager - still needs packets to be moved, but general functionality has been abstracted. --- OpenSim/Region/Environment/EstateManager.cs | 146 ++++++++++++++++++++-------- 1 file changed, 103 insertions(+), 43 deletions(-) diff --git a/OpenSim/Region/Environment/EstateManager.cs b/OpenSim/Region/Environment/EstateManager.cs index b8bc949..67cfba6 100644 --- a/OpenSim/Region/Environment/EstateManager.cs +++ b/OpenSim/Region/Environment/EstateManager.cs @@ -64,6 +64,88 @@ namespace OpenSim.Region.Environment return false; } + /// + /// Sets terrain texture heights for each of the four corners of the region - textures are distributed as a linear range between the two heights. + /// + /// Which corner + /// Minimum height that texture range should cover + /// Maximum height that texture range should cover + public void setEstateTextureRange(UInt16 corner, float lowValue, float highValue) + { + + switch (corner) + { + case 0: + m_regInfo.estateSettings.terrainStartHeight0 = lowValue; + m_regInfo.estateSettings.terrainHeightRange0 = highValue; + break; + case 1: + m_regInfo.estateSettings.terrainStartHeight1 = lowValue; + m_regInfo.estateSettings.terrainHeightRange1 = highValue; + break; + case 2: + m_regInfo.estateSettings.terrainStartHeight2 = lowValue; + m_regInfo.estateSettings.terrainHeightRange2 = highValue; + break; + case 3: + m_regInfo.estateSettings.terrainStartHeight3 = lowValue; + m_regInfo.estateSettings.terrainHeightRange3 = highValue; + break; + } + } + + /// + /// Sets the 'detail' terrain texture on each of the bands. + /// + /// Which texture band + /// The UUID of the texture + public void setTerrainTexture(UInt16 band, LLUUID textureUUID) + { + switch (band) + { + case 0: + m_regInfo.estateSettings.terrainDetail0 = textureUUID; + break; + case 1: + m_regInfo.estateSettings.terrainDetail1 = textureUUID; + break; + case 2: + m_regInfo.estateSettings.terrainDetail2 = textureUUID; + break; + case 3: + m_regInfo.estateSettings.terrainDetail3 = textureUUID; + break; + } + } + + /// + /// Sets common region settings + /// + /// Water height of the waterplane (may not nessecarily be one value) + /// Maximum amount terrain can be raised from previous baking + /// Minimum amount terrain can be lowered from previous baking + /// Use a fixed time of day on the sun? + /// The offset hour of the day + public void setRegionSettings(float WaterHeight, float TerrainRaiseLimit, float TerrainLowerLimit, bool UseFixedSun, float SunHour) + { + // Water Height + m_regInfo.estateSettings.waterHeight = WaterHeight; + m_scene.Terrain.watermap.Fill(WaterHeight); + + // Terraforming limits + m_regInfo.estateSettings.terrainRaiseLimit = TerrainRaiseLimit; + m_regInfo.estateSettings.terrainLowerLimit = TerrainLowerLimit; + m_scene.Terrain.maxRaise = TerrainRaiseLimit; + m_scene.Terrain.minLower = TerrainLowerLimit; + + // Time of day / fixed sun + m_regInfo.estateSettings.useFixedSun = UseFixedSun; + m_regInfo.estateSettings.sunHour = SunHour; + } + + #region Packet Handlers + + public void handleEstateOwnerMessage(EstateOwnerMessagePacket packet, IClientAPI remote_client) { if (remote_client.AgentId == m_regInfo.MasterAvatarAssignedUUID) @@ -162,11 +244,13 @@ namespace OpenSim.Region.Environment } else { - m_regInfo.estateSettings.waterHeight = (float)Convert.ToDecimal(Helpers.FieldToUTF8String(packet.ParamList[0].Parameter)); - m_regInfo.estateSettings.terrainRaiseLimit = (float)Convert.ToDecimal(Helpers.FieldToUTF8String(packet.ParamList[1].Parameter)); - m_regInfo.estateSettings.terrainLowerLimit = (float)Convert.ToDecimal(Helpers.FieldToUTF8String(packet.ParamList[2].Parameter)); - m_regInfo.estateSettings.useFixedSun = this.convertParamStringToBool(packet.ParamList[4].Parameter); - m_regInfo.estateSettings.sunHour = (float)Convert.ToDecimal(Helpers.FieldToUTF8String(packet.ParamList[5].Parameter)); + float WaterHeight = (float)Convert.ToDecimal(Helpers.FieldToUTF8String(packet.ParamList[0].Parameter)); + float TerrainRaiseLimit = (float)Convert.ToDecimal(Helpers.FieldToUTF8String(packet.ParamList[1].Parameter)); + float TerrainLowerLimit = (float)Convert.ToDecimal(Helpers.FieldToUTF8String(packet.ParamList[2].Parameter)); + bool UseFixedSun = this.convertParamStringToBool(packet.ParamList[4].Parameter); + float SunHour = (float)Convert.ToDecimal(Helpers.FieldToUTF8String(packet.ParamList[5].Parameter)); + + setRegionSettings(WaterHeight, TerrainRaiseLimit, TerrainLowerLimit, UseFixedSun, SunHour); sendRegionInfoPacketToAll(); } @@ -176,34 +260,16 @@ namespace OpenSim.Region.Environment { foreach (EstateOwnerMessagePacket.ParamListBlock block in packet.ParamList) { - string s = Helpers.FieldToUTF8String(block.Parameter); string[] splitField = s.Split(' '); if (splitField.Length == 3) { - float tempHeightLow = (float)Convert.ToDecimal(splitField[1]); - float tempHeightHigh = (float)Convert.ToDecimal(splitField[2]); + UInt16 corner = Convert.ToInt16(splitField[0]); + float lowValue = (float)Convert.ToDecimal(splitField[1]); + float highValue = (float)Convert.ToDecimal(splitField[2]); - switch (Convert.ToInt16(splitField[0])) - { - case 0: - m_regInfo.estateSettings.terrainStartHeight0 = tempHeightLow; - m_regInfo.estateSettings.terrainHeightRange0 = tempHeightHigh; - break; - case 1: - m_regInfo.estateSettings.terrainStartHeight1 = tempHeightLow; - m_regInfo.estateSettings.terrainHeightRange1 = tempHeightHigh; - break; - case 2: - m_regInfo.estateSettings.terrainStartHeight2 = tempHeightLow; - m_regInfo.estateSettings.terrainHeightRange2 = tempHeightHigh; - break; - case 3: - m_regInfo.estateSettings.terrainStartHeight3 = tempHeightLow; - m_regInfo.estateSettings.terrainHeightRange3 = tempHeightHigh; - break; - } + setEstateTextureRange(corner, lowValue, highValue); } } } @@ -217,22 +283,10 @@ namespace OpenSim.Region.Environment string[] splitField = s.Split(' '); if (splitField.Length == 2) { - LLUUID tempUUID = new LLUUID(splitField[1]); - switch (Convert.ToInt16(splitField[0])) - { - case 0: - m_regInfo.estateSettings.terrainDetail0 = tempUUID; - break; - case 1: - m_regInfo.estateSettings.terrainDetail1 = tempUUID; - break; - case 2: - m_regInfo.estateSettings.terrainDetail2 = tempUUID; - break; - case 3: - m_regInfo.estateSettings.terrainDetail3 = tempUUID; - break; - } + UInt16 corner = Convert.ToInt16(splitField[0]); + LLUUID textureUUID = new LLUUID(splitField[1]); + + setTerrainTexture(corner, textureUUID); } } } @@ -265,6 +319,10 @@ namespace OpenSim.Region.Environment } } + #endregion + + #region Outgoing Packets + public void sendRegionInfoPacketToAll() { List avatars = m_scene.RequestAvatarList(); @@ -319,5 +377,7 @@ namespace OpenSim.Region.Environment remoteClient.SendRegionHandshake(m_regInfo); } + #endregion + } } -- cgit v1.1