aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim
diff options
context:
space:
mode:
Diffstat (limited to 'OpenSim')
-rwxr-xr-xOpenSim/Region/CoreModules/World/Terrain/TerrainModule.cs237
1 files changed, 122 insertions, 115 deletions
diff --git a/OpenSim/Region/CoreModules/World/Terrain/TerrainModule.cs b/OpenSim/Region/CoreModules/World/Terrain/TerrainModule.cs
index 8f60d2f..f29011e 100755
--- a/OpenSim/Region/CoreModules/World/Terrain/TerrainModule.cs
+++ b/OpenSim/Region/CoreModules/World/Terrain/TerrainModule.cs
@@ -1336,156 +1336,163 @@ namespace OpenSim.Region.CoreModules.World.Terrain
1336 if(now < NextModifyTerrainTime) 1336 if(now < NextModifyTerrainTime)
1337 return; 1337 return;
1338 1338
1339 NextModifyTerrainTime = double.MaxValue; // block it 1339 try
1340
1341 //m_log.DebugFormat("brushs {0} seconds {1} height {2}, parcel {3}", brushSize, seconds, height, parcelLocalID);
1342 bool god = m_scene.Permissions.IsGod(user);
1343 bool allowed = false;
1344 if (north == south && east == west)
1345 { 1340 {
1346 if (m_painteffects.ContainsKey((StandardTerrainEffects)action)) 1341 NextModifyTerrainTime = double.MaxValue; // block it
1342
1343 //m_log.DebugFormat("brushs {0} seconds {1} height {2}, parcel {3}", brushSize, seconds, height, parcelLocalID);
1344 bool god = m_scene.Permissions.IsGod(user);
1345 bool allowed = false;
1346 if (north == south && east == west)
1347 { 1347 {
1348 bool[,] allowMask = new bool[m_channel.Width, m_channel.Height]; 1348 if (m_painteffects.ContainsKey((StandardTerrainEffects)action))
1349 {
1350 bool[,] allowMask = new bool[m_channel.Width, m_channel.Height];
1349 1351
1350 allowMask.Initialize(); 1352 allowMask.Initialize();
1351 1353
1352 int startX = (int)(west - brushSize + 0.5); 1354 int startX = (int)(west - brushSize + 0.5);
1353 if (startX < 0) 1355 if (startX < 0)
1354 startX = 0; 1356 startX = 0;
1355 1357
1356 int startY = (int)(north - brushSize + 0.5); 1358 int startY = (int)(north - brushSize + 0.5);
1357 if (startY < 0) 1359 if (startY < 0)
1358 startY = 0; 1360 startY = 0;
1359 1361
1360 int endX = (int)(west + brushSize + 0.5); 1362 int endX = (int)(west + brushSize + 0.5);
1361 if (endX >= m_channel.Width) 1363 if (endX >= m_channel.Width)
1362 endX = m_channel.Width - 1; 1364 endX = m_channel.Width - 1;
1363 int endY = (int)(north + brushSize + 0.5); 1365 int endY = (int)(north + brushSize + 0.5);
1364 if (endY >= m_channel.Height) 1366 if (endY >= m_channel.Height)
1365 endY = m_channel.Height - 1; 1367 endY = m_channel.Height - 1;
1366 1368
1367 int x, y; 1369 int x, y;
1368 1370
1369 for (x = startX; x <= endX; x++) 1371 for (x = startX; x <= endX; x++)
1370 {
1371 for (y = startY; y <= endY; y++)
1372 { 1372 {
1373 if (m_scene.Permissions.CanTerraformLand(user, new Vector3(x, y, -1))) 1373 for (y = startY; y <= endY; y++)
1374 { 1374 {
1375 allowMask[x, y] = true; 1375 if (m_scene.Permissions.CanTerraformLand(user, new Vector3(x, y, -1)))
1376 allowed = true; 1376 {
1377 allowMask[x, y] = true;
1378 allowed = true;
1379 }
1377 } 1380 }
1378 } 1381 }
1382 if (allowed)
1383 {
1384 StoreUndoState();
1385 m_painteffects[(StandardTerrainEffects) action].PaintEffect(
1386 m_channel, allowMask, west, south, height, brushSize, seconds,
1387 startX, endX, startY, endY);
1388
1389 //block changes outside estate limits
1390 if (!god)
1391 EnforceEstateLimits(startX, endX, startY, endY);
1392 }
1379 } 1393 }
1380 if (allowed) 1394 else
1381 { 1395 {
1382 StoreUndoState(); 1396 m_log.Debug("Unknown terrain brush type " + action);
1383 m_painteffects[(StandardTerrainEffects) action].PaintEffect(
1384 m_channel, allowMask, west, south, height, brushSize, seconds,
1385 startX, endX, startY, endY);
1386
1387 //block changes outside estate limits
1388 if (!god)
1389 EnforceEstateLimits(startX, endX, startY, endY);
1390 } 1397 }
1391 } 1398 }
1392 else 1399 else
1393 { 1400 {
1394 m_log.Debug("Unknown terrain brush type " + action); 1401 if (m_floodeffects.ContainsKey((StandardTerrainEffects)action))
1395 }
1396 }
1397 else
1398 {
1399 if (m_floodeffects.ContainsKey((StandardTerrainEffects)action))
1400 {
1401 bool[,] fillArea = new bool[m_channel.Width, m_channel.Height];
1402 fillArea.Initialize();
1403
1404 int startX = (int)west;
1405 int startY = (int)south;
1406 int endX = (int)east;
1407 int endY = (int)north;
1408
1409 if (startX < 0)
1410 startX = 0;
1411 else if (startX >= m_channel.Width)
1412 startX = m_channel.Width - 1;
1413
1414 if (endX < 0)
1415 endX = 0;
1416 else if (endX >= m_channel.Width)
1417 endX = m_channel.Width - 1;
1418
1419 if (startY < 0)
1420 startY = 0;
1421 else if (startY >= m_channel.Height)
1422 startY = m_channel.Height - 1;
1423
1424 if (endY < 0)
1425 endY = 0;
1426 else if (endY >= m_channel.Height)
1427 endY = m_channel.Height - 1;
1428
1429 int x, y;
1430 if (parcelLocalID == -1)
1431 { 1402 {
1432 for (x = startX; x <= endX; x++) 1403 bool[,] fillArea = new bool[m_channel.Width, m_channel.Height];
1404 fillArea.Initialize();
1405
1406 int startX = (int)west;
1407 int startY = (int)south;
1408 int endX = (int)east;
1409 int endY = (int)north;
1410
1411 if (startX < 0)
1412 startX = 0;
1413 else if (startX >= m_channel.Width)
1414 startX = m_channel.Width - 1;
1415
1416 if (endX < 0)
1417 endX = 0;
1418 else if (endX >= m_channel.Width)
1419 endX = m_channel.Width - 1;
1420
1421 if (startY < 0)
1422 startY = 0;
1423 else if (startY >= m_channel.Height)
1424 startY = m_channel.Height - 1;
1425
1426 if (endY < 0)
1427 endY = 0;
1428 else if (endY >= m_channel.Height)
1429 endY = m_channel.Height - 1;
1430
1431 int x, y;
1432 if (parcelLocalID == -1)
1433 { 1433 {
1434 for (y = startY; y <= endY; y++) 1434 for (x = startX; x <= endX; x++)
1435 { 1435 {
1436 if (m_scene.Permissions.CanTerraformLand(user, new Vector3(x, y, -1))) 1436 for (y = startY; y <= endY; y++)
1437 { 1437 {
1438 fillArea[x, y] = true; 1438 if (m_scene.Permissions.CanTerraformLand(user, new Vector3(x, y, -1)))
1439 allowed = true; 1439 {
1440 fillArea[x, y] = true;
1441 allowed = true;
1442 }
1440 } 1443 }
1441 } 1444 }
1442 } 1445 }
1443 } 1446 else
1444 else
1445 {
1446 if (!m_scene.Permissions.CanTerraformLand(user, new Vector3(-1, -1, parcelLocalID)))
1447 return;
1448
1449 ILandObject parcel = m_scene.LandChannel.GetLandObject(parcelLocalID);
1450 if(parcel == null)
1451 return;
1452 bool [,] parcelmap = parcel.GetLandBitmap();
1453//ugly
1454 for (x = startX; x <= endX; x++)
1455 { 1447 {
1456 int px = x >> 2; 1448 if (!m_scene.Permissions.CanTerraformLand(user, new Vector3(-1, -1, parcelLocalID)))
1457 y = startY; 1449 return;
1458 while( y <= endY) 1450
1451 ILandObject parcel = m_scene.LandChannel.GetLandObject(parcelLocalID);
1452 if(parcel == null)
1453 return;
1454
1455 bool[,] parcelmap = parcel.GetLandBitmap();
1456 //ugly
1457 for (x = startX; x <= endX; x++)
1459 { 1458 {
1460 int py = y >> 2; 1459 int px = x >> 2;
1461 bool inp = parcelmap[px, py]; 1460 y = startY;
1462 fillArea[x, y++] = inp; 1461 while( y <= endY)
1463 fillArea[x, y++] = inp; 1462 {
1464 fillArea[x, y++] = inp; 1463 int py = y >> 2;
1465 fillArea[x, y++] = inp; 1464 bool inp = parcelmap[px, py];
1465 fillArea[x, y++] = inp;
1466 fillArea[x, y++] = inp;
1467 fillArea[x, y++] = inp;
1468 fillArea[x, y++] = inp;
1469 }
1466 } 1470 }
1471
1472 allowed = true;
1467 } 1473 }
1468 1474
1469 allowed = true; 1475 if (allowed)
1470 } 1476 {
1477 StoreUndoState();
1478 m_floodeffects[(StandardTerrainEffects)action].FloodEffect(m_channel, fillArea, height, seconds,
1479 startX, endX, startY, endY);
1471 1480
1472 if (allowed) 1481 //block changes outside estate limits
1482 if (!god)
1483 EnforceEstateLimits(startX, endX, startY, endY);
1484 }
1485 }
1486 else
1473 { 1487 {
1474 StoreUndoState(); 1488 m_log.Debug("Unknown terrain flood type " + action);
1475 m_floodeffects[(StandardTerrainEffects)action].FloodEffect(m_channel, fillArea, height, seconds,
1476 startX, endX, startY, endY);
1477
1478 //block changes outside estate limits
1479 if (!god)
1480 EnforceEstateLimits(startX, endX, startY, endY);
1481 } 1489 }
1482 } 1490 }
1483 else
1484 {
1485 m_log.Debug("Unknown terrain flood type " + action);
1486 }
1487 } 1491 }
1488 NextModifyTerrainTime = Util.GetTimeStamp() + 0.02; // 20ms cooldown 1492 finally
1493 {
1494 NextModifyTerrainTime = Util.GetTimeStamp() + 0.02; // 20ms cooldown
1495 }
1489 } 1496 }
1490 1497
1491 private void client_OnBakeTerrain(IClientAPI remoteClient) 1498 private void client_OnBakeTerrain(IClientAPI remoteClient)