diff options
Diffstat (limited to '')
-rw-r--r-- | OpenSim/Region/Physics/BasicPhysicsPlugin/BasicPhysicsPlugin.cs | 62 | ||||
-rw-r--r-- | OpenSim/Region/Terrain.BasicTerrain/TerrainEngine.cs | 2 |
2 files changed, 29 insertions, 35 deletions
diff --git a/OpenSim/Region/Physics/BasicPhysicsPlugin/BasicPhysicsPlugin.cs b/OpenSim/Region/Physics/BasicPhysicsPlugin/BasicPhysicsPlugin.cs index 81e2ea3..4d0699b 100644 --- a/OpenSim/Region/Physics/BasicPhysicsPlugin/BasicPhysicsPlugin.cs +++ b/OpenSim/Region/Physics/BasicPhysicsPlugin/BasicPhysicsPlugin.cs | |||
@@ -99,49 +99,43 @@ namespace OpenSim.Region.Physics.BasicPhysicsPlugin | |||
99 | { | 99 | { |
100 | foreach (BasicActor actor in _actors) | 100 | foreach (BasicActor actor in _actors) |
101 | { | 101 | { |
102 | if ((actor.Position.Y > 0 && actor.Position.Y < 256) && (actor.Position.X > 0 && actor.Position.X < 256)) | 102 | float height = _heightMap[(int)actor.Position.Y * 256 + (int)actor.Position.X] + 1.2f; |
103 | { | 103 | actor.Position.X = actor.Position.X + (actor.Velocity.X * timeStep); |
104 | float height = _heightMap[(int)actor.Position.Y * 256 + (int)actor.Position.X] + 1.2f; | 104 | actor.Position.Y = actor.Position.Y + (actor.Velocity.Y * timeStep); |
105 | actor.Position.X = actor.Position.X + (actor.Velocity.X * timeStep); | 105 | if (actor.Flying) |
106 | actor.Position.Y = actor.Position.Y + (actor.Velocity.Y * timeStep); | ||
107 | if (actor.Flying) | ||
108 | { | 106 | { |
109 | if (actor.Position.Z + (actor.Velocity.Z * timeStep) < | 107 | if (actor.Position.Z + (actor.Velocity.Z * timeStep) < _heightMap[(int)actor.Position.Y * 256 + (int)actor.Position.X] + 2) |
110 | _heightMap[(int)actor.Position.Y * 256 + (int)actor.Position.X] + 2) | ||
111 | { | ||
112 | actor.Position.Z = height; | ||
113 | actor.Velocity.Z = 0; | ||
114 | } | ||
115 | else | ||
116 | { | ||
117 | actor.Position.Z = actor.Position.Z + (actor.Velocity.Z * timeStep); | ||
118 | } | ||
119 | } | ||
120 | else | ||
121 | { | 108 | { |
122 | actor.Position.Z = height; | 109 | actor.Position.Z = height; |
123 | actor.Velocity.Z = 0; | 110 | actor.Velocity.Z = 0; |
124 | } | 111 | } |
112 | else | ||
113 | { | ||
114 | actor.Position.Z = actor.Position.Z + (actor.Velocity.Z * timeStep); | ||
115 | } | ||
125 | } | 116 | } |
126 | else | 117 | else |
127 | { | 118 | { |
128 | if (actor.Position.Y < 0) | 119 | actor.Position.Z = height; |
129 | { | 120 | actor.Velocity.Z = 0; |
130 | actor.Position.Y = 0; | 121 | } |
131 | } | ||
132 | else if (actor.Position.Y > 256) | ||
133 | { | ||
134 | actor.Position.Y = 256; | ||
135 | } | ||
136 | 122 | ||
137 | if (actor.Position.X < 0) | 123 | if (actor.Position.Y < 0) |
138 | { | 124 | { |
139 | actor.Position.X = 0; | 125 | actor.Position.Y = 0; |
140 | } | 126 | } |
141 | if (actor.Position.X > 256) | 127 | else if (actor.Position.Y > 256) |
142 | { | 128 | { |
143 | actor.Position.X = 256; | 129 | actor.Position.Y = 256; |
144 | } | 130 | } |
131 | |||
132 | if (actor.Position.X < 0) | ||
133 | { | ||
134 | actor.Position.X = 0; | ||
135 | } | ||
136 | if (actor.Position.X > 256) | ||
137 | { | ||
138 | actor.Position.X = 256; | ||
145 | } | 139 | } |
146 | } | 140 | } |
147 | } | 141 | } |
diff --git a/OpenSim/Region/Terrain.BasicTerrain/TerrainEngine.cs b/OpenSim/Region/Terrain.BasicTerrain/TerrainEngine.cs index f52d25a..f37d625 100644 --- a/OpenSim/Region/Terrain.BasicTerrain/TerrainEngine.cs +++ b/OpenSim/Region/Terrain.BasicTerrain/TerrainEngine.cs | |||
@@ -1010,7 +1010,7 @@ namespace OpenSim.Region.Terrain | |||
1010 | for (int y = 0; y < copy.h; y++) | 1010 | for (int y = 0; y < copy.h; y++) |
1011 | { | 1011 | { |
1012 | // 512 is the largest possible height before colours clamp | 1012 | // 512 is the largest possible height before colours clamp |
1013 | int colorindex = (int)(Math.Max(Math.Min(1.0, copy.Get(copy.h - y, x) / 512.0), 0.0) * pallete); | 1013 | int colorindex = (int)(Math.Max(Math.Min(1.0, copy.Get(copy.h - y, x) / 512.0), 0.0) * (pallete - 1)); |
1014 | bmp.SetPixel(x, y, colours[colorindex]); | 1014 | bmp.SetPixel(x, y, colours[colorindex]); |
1015 | } | 1015 | } |
1016 | } | 1016 | } |