aboutsummaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
-rw-r--r--OpenSim/Region/Framework/Scenes/SceneObjectGroup.cs473
-rw-r--r--OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs59
2 files changed, 199 insertions, 333 deletions
diff --git a/OpenSim/Region/Framework/Scenes/SceneObjectGroup.cs b/OpenSim/Region/Framework/Scenes/SceneObjectGroup.cs
index 39a1779..7d5bbbf 100644
--- a/OpenSim/Region/Framework/Scenes/SceneObjectGroup.cs
+++ b/OpenSim/Region/Framework/Scenes/SceneObjectGroup.cs
@@ -431,29 +431,47 @@ namespace OpenSim.Region.Framework.Scenes
431 { 431 {
432 get 432 get
433 { 433 {
434 Vector3 minScale = new Vector3(Constants.MaximumRegionSize, Constants.MaximumRegionSize, Constants.MaximumRegionSize); 434 Vector3 finalScale = new Vector3();
435 Vector3 maxScale = Vector3.Zero;
436 Vector3 finalScale = new Vector3(0.5f, 0.5f, 0.5f);
437 435
438 SceneObjectPart[] parts = m_parts.GetArray(); 436 SceneObjectPart[] parts = m_parts.GetArray();
439 for (int i = 0; i < parts.Length; i++) 437 SceneObjectPart part;
440 { 438 Vector3 partscale;
441 SceneObjectPart part = parts[i];
442 Vector3 partscale = part.Scale;
443 Vector3 partoffset = part.OffsetPosition;
444 439
445 minScale.X = (partscale.X + partoffset.X < minScale.X) ? partscale.X + partoffset.X : minScale.X; 440 float ftmp;
446 minScale.Y = (partscale.Y + partoffset.Y < minScale.Y) ? partscale.Y + partoffset.Y : minScale.Y; 441 float minScaleX = float.MaxValue;
447 minScale.Z = (partscale.Z + partoffset.Z < minScale.Z) ? partscale.Z + partoffset.Z : minScale.Z; 442 float minScaleY = float.MaxValue;
443 float minScaleZ = float.MaxValue;
444 float maxScaleX = 0f;
445 float maxScaleY = 0f;
446 float maxScaleZ = 0f;
448 447
449 maxScale.X = (partscale.X + partoffset.X > maxScale.X) ? partscale.X + partoffset.X : maxScale.X; 448 for (int i = 0; i < parts.Length; i++)
450 maxScale.Y = (partscale.Y + partoffset.Y > maxScale.Y) ? partscale.Y + partoffset.Y : maxScale.Y; 449 {
451 maxScale.Z = (partscale.Z + partoffset.Z > maxScale.Z) ? partscale.Z + partoffset.Z : maxScale.Z; 450 part = parts[i];
451 partscale = part.Scale + part.OffsetPosition;
452
453 ftmp = partscale.X;
454 if (ftmp < minScaleX)
455 minScaleX = ftmp;
456 if (ftmp > maxScaleX)
457 maxScaleX = ftmp;
458
459 ftmp = partscale.Y;
460 if (ftmp < minScaleY)
461 minScaleY = ftmp;
462 if (ftmp > maxScaleY)
463 maxScaleY = ftmp;
464
465 ftmp = partscale.Z;
466 if (ftmp < minScaleZ)
467 minScaleZ = ftmp;
468 if (ftmp > maxScaleZ)
469 maxScaleZ = ftmp;
452 } 470 }
453 471
454 finalScale.X = (minScale.X > maxScale.X) ? minScale.X : maxScale.X; 472 finalScale.X = (minScaleX > maxScaleX) ? minScaleX : maxScaleX;
455 finalScale.Y = (minScale.Y > maxScale.Y) ? minScale.Y : maxScale.Y; 473 finalScale.Y = (minScaleY > maxScaleY) ? minScaleY : maxScaleY;
456 finalScale.Z = (minScale.Z > maxScale.Z) ? minScale.Z : maxScale.Z; 474 finalScale.Z = (minScaleZ > maxScaleZ) ? minScaleZ : maxScaleZ;
457 475
458 return finalScale; 476 return finalScale;
459 } 477 }
@@ -1507,13 +1525,80 @@ namespace OpenSim.Region.Framework.Scenes
1507 return result; 1525 return result;
1508 } 1526 }
1509 1527
1510 /// <summary> 1528 public void GetBoundingBox(out float minX, out float maxX, out float minY, out float maxY, out float minZ, out float maxZ)
1511 /// Gets a vector representing the size of the bounding box containing all the prims in the group 1529 {
1512 /// Treats all prims as rectangular, so no shape (cut etc) is taken into account 1530 uint rootid = RootPart.LocalId;
1513 /// offsetHeight is the offset in the Z axis from the centre of the bounding box to the centre of the root prim 1531 Vector3 scale = RootPart.Scale * 0.5f;
1514 /// </summary> 1532
1515 /// <returns></returns> 1533 minX = -scale.X;
1516 public void GetAxisAlignedBoundingBoxRaw(out float minX, out float maxX, out float minY, out float maxY, out float minZ, out float maxZ) 1534 maxX = scale.X;
1535 minY = -scale.Y;
1536 maxY = scale.Y;
1537 minZ = -scale.Z;
1538 maxZ = scale.Z;
1539
1540 SceneObjectPart[] parts = m_parts.GetArray();
1541 SceneObjectPart part;
1542 for (int i = 0; i < parts.Length; ++i)
1543 {
1544 part = parts[i];
1545 if(part.LocalId == rootid)
1546 continue;
1547
1548 Vector3 offset = part.OffsetPosition;
1549 scale = part.Scale * 0.5f;
1550
1551 Matrix4 m = Matrix4.CreateFromQuaternion(part.RotationOffset);
1552 Vector3 a = m.AtAxis;
1553 a.X = Math.Abs(a.X);
1554 a.Y = Math.Abs(a.Y);
1555 a.Z = Math.Abs(a.Z);
1556
1557 float tmpS = Vector3.Dot(a, scale);
1558 float tmp = offset.X - tmpS;
1559 if (tmp < minX)
1560 minX = tmp;
1561
1562 tmp = offset.X + tmpS;
1563 if (tmp > maxX)
1564 maxX = tmp;
1565
1566 a = m.LeftAxis;
1567 a.X = Math.Abs(a.X);
1568 a.Y = Math.Abs(a.Y);
1569 a.Z = Math.Abs(a.Z);
1570 tmpS = Vector3.Dot(a, scale);
1571
1572 tmp = offset.Y - tmpS;
1573 if (tmp < minY)
1574 minY = tmp;
1575
1576 tmp = offset.Y + tmpS;
1577 if (tmp > maxY)
1578 maxY = tmp;
1579
1580 a = m.UpAxis;
1581 a.X = Math.Abs(a.X);
1582 a.Y = Math.Abs(a.Y);
1583 a.Z = Math.Abs(a.Z);
1584
1585 tmpS = Vector3.Dot(a, scale);
1586 tmp = offset.Z - tmpS;
1587 if (tmp < minZ)
1588 minZ = tmp;
1589
1590 tmp = offset.Z + tmpS;
1591 if (tmp > maxZ)
1592 maxZ = tmp;
1593 }
1594 }
1595 /// <summary>
1596 /// Gets a vector representing the size of the bounding box containing all the prims in the group
1597 /// Treats all prims as rectangular, so no shape (cut etc) is taken into account
1598 /// offsetHeight is the offset in the Z axis from the centre of the bounding box to the centre of the root prim
1599 /// </summary>
1600 /// <returns></returns>
1601 public void GetAxisAlignedBoundingBoxRaw(out float minX, out float maxX, out float minY, out float maxY, out float minZ, out float maxZ)
1517 { 1602 {
1518 maxX = float.MinValue; 1603 maxX = float.MinValue;
1519 maxY = float.MinValue; 1604 maxY = float.MinValue;
@@ -1522,238 +1607,57 @@ namespace OpenSim.Region.Framework.Scenes
1522 minY = float.MaxValue; 1607 minY = float.MaxValue;
1523 minZ = float.MaxValue; 1608 minZ = float.MaxValue;
1524 1609
1610 Vector3 absPos = AbsolutePosition;
1525 SceneObjectPart[] parts = m_parts.GetArray(); 1611 SceneObjectPart[] parts = m_parts.GetArray();
1526 foreach (SceneObjectPart part in parts) 1612 SceneObjectPart part;
1613 for(int i = 0; i< parts.Length; ++i)
1527 { 1614 {
1528 Vector3 worldPos = part.GetWorldPosition(); 1615 part = parts[i];
1529 Vector3 offset = worldPos - AbsolutePosition; 1616 Vector3 offset = part.GetWorldPosition() - absPos;
1530 Quaternion worldRot; 1617 Vector3 scale = part.Scale * 0.5f;
1531 if (part.ParentID == 0)
1532 {
1533 worldRot = part.RotationOffset;
1534 }
1535 else
1536 {
1537 worldRot = part.GetWorldRotation();
1538 }
1539 1618
1540 Vector3 frontTopLeft; 1619 Matrix4 m = Matrix4.CreateFromQuaternion(part.GetWorldRotation());
1541 Vector3 frontTopRight; 1620 Vector3 a = m.AtAxis;
1542 Vector3 frontBottomLeft; 1621 a.X = Math.Abs(a.X);
1543 Vector3 frontBottomRight; 1622 a.Y = Math.Abs(a.Y);
1544 1623 a.Z = Math.Abs(a.Z);
1545 Vector3 backTopLeft;
1546 Vector3 backTopRight;
1547 Vector3 backBottomLeft;
1548 Vector3 backBottomRight;
1549
1550 // Vector3[] corners = new Vector3[8];
1551
1552 Vector3 orig = Vector3.Zero;
1553
1554 frontTopLeft.X = orig.X - (part.Scale.X / 2);
1555 frontTopLeft.Y = orig.Y - (part.Scale.Y / 2);
1556 frontTopLeft.Z = orig.Z + (part.Scale.Z / 2);
1557
1558 frontTopRight.X = orig.X - (part.Scale.X / 2);
1559 frontTopRight.Y = orig.Y + (part.Scale.Y / 2);
1560 frontTopRight.Z = orig.Z + (part.Scale.Z / 2);
1561
1562 frontBottomLeft.X = orig.X - (part.Scale.X / 2);
1563 frontBottomLeft.Y = orig.Y - (part.Scale.Y / 2);
1564 frontBottomLeft.Z = orig.Z - (part.Scale.Z / 2);
1565
1566 frontBottomRight.X = orig.X - (part.Scale.X / 2);
1567 frontBottomRight.Y = orig.Y + (part.Scale.Y / 2);
1568 frontBottomRight.Z = orig.Z - (part.Scale.Z / 2);
1569
1570 backTopLeft.X = orig.X + (part.Scale.X / 2);
1571 backTopLeft.Y = orig.Y - (part.Scale.Y / 2);
1572 backTopLeft.Z = orig.Z + (part.Scale.Z / 2);
1573
1574 backTopRight.X = orig.X + (part.Scale.X / 2);
1575 backTopRight.Y = orig.Y + (part.Scale.Y / 2);
1576 backTopRight.Z = orig.Z + (part.Scale.Z / 2);
1577
1578 backBottomLeft.X = orig.X + (part.Scale.X / 2);
1579 backBottomLeft.Y = orig.Y - (part.Scale.Y / 2);
1580 backBottomLeft.Z = orig.Z - (part.Scale.Z / 2);
1581
1582 backBottomRight.X = orig.X + (part.Scale.X / 2);
1583 backBottomRight.Y = orig.Y + (part.Scale.Y / 2);
1584 backBottomRight.Z = orig.Z - (part.Scale.Z / 2);
1585
1586
1587
1588 //m_log.InfoFormat("pre corner 1 is {0} {1} {2}", frontTopLeft.X, frontTopLeft.Y, frontTopLeft.Z);
1589 //m_log.InfoFormat("pre corner 2 is {0} {1} {2}", frontTopRight.X, frontTopRight.Y, frontTopRight.Z);
1590 //m_log.InfoFormat("pre corner 3 is {0} {1} {2}", frontBottomRight.X, frontBottomRight.Y, frontBottomRight.Z);
1591 //m_log.InfoFormat("pre corner 4 is {0} {1} {2}", frontBottomLeft.X, frontBottomLeft.Y, frontBottomLeft.Z);
1592 //m_log.InfoFormat("pre corner 5 is {0} {1} {2}", backTopLeft.X, backTopLeft.Y, backTopLeft.Z);
1593 //m_log.InfoFormat("pre corner 6 is {0} {1} {2}", backTopRight.X, backTopRight.Y, backTopRight.Z);
1594 //m_log.InfoFormat("pre corner 7 is {0} {1} {2}", backBottomRight.X, backBottomRight.Y, backBottomRight.Z);
1595 //m_log.InfoFormat("pre corner 8 is {0} {1} {2}", backBottomLeft.X, backBottomLeft.Y, backBottomLeft.Z);
1596
1597 //for (int i = 0; i < 8; i++)
1598 //{
1599 // corners[i] = corners[i] * worldRot;
1600 // corners[i] += offset;
1601
1602 // if (corners[i].X > maxX)
1603 // maxX = corners[i].X;
1604 // if (corners[i].X < minX)
1605 // minX = corners[i].X;
1606
1607 // if (corners[i].Y > maxY)
1608 // maxY = corners[i].Y;
1609 // if (corners[i].Y < minY)
1610 // minY = corners[i].Y;
1611
1612 // if (corners[i].Z > maxZ)
1613 // maxZ = corners[i].Y;
1614 // if (corners[i].Z < minZ)
1615 // minZ = corners[i].Z;
1616 //}
1617
1618 frontTopLeft = frontTopLeft * worldRot;
1619 frontTopRight = frontTopRight * worldRot;
1620 frontBottomLeft = frontBottomLeft * worldRot;
1621 frontBottomRight = frontBottomRight * worldRot;
1622
1623 backBottomLeft = backBottomLeft * worldRot;
1624 backBottomRight = backBottomRight * worldRot;
1625 backTopLeft = backTopLeft * worldRot;
1626 backTopRight = backTopRight * worldRot;
1627
1628
1629 frontTopLeft += offset;
1630 frontTopRight += offset;
1631 frontBottomLeft += offset;
1632 frontBottomRight += offset;
1633
1634 backBottomLeft += offset;
1635 backBottomRight += offset;
1636 backTopLeft += offset;
1637 backTopRight += offset;
1638
1639 //m_log.InfoFormat("corner 1 is {0} {1} {2}", frontTopLeft.X, frontTopLeft.Y, frontTopLeft.Z);
1640 //m_log.InfoFormat("corner 2 is {0} {1} {2}", frontTopRight.X, frontTopRight.Y, frontTopRight.Z);
1641 //m_log.InfoFormat("corner 3 is {0} {1} {2}", frontBottomRight.X, frontBottomRight.Y, frontBottomRight.Z);
1642 //m_log.InfoFormat("corner 4 is {0} {1} {2}", frontBottomLeft.X, frontBottomLeft.Y, frontBottomLeft.Z);
1643 //m_log.InfoFormat("corner 5 is {0} {1} {2}", backTopLeft.X, backTopLeft.Y, backTopLeft.Z);
1644 //m_log.InfoFormat("corner 6 is {0} {1} {2}", backTopRight.X, backTopRight.Y, backTopRight.Z);
1645 //m_log.InfoFormat("corner 7 is {0} {1} {2}", backBottomRight.X, backBottomRight.Y, backBottomRight.Z);
1646 //m_log.InfoFormat("corner 8 is {0} {1} {2}", backBottomLeft.X, backBottomLeft.Y, backBottomLeft.Z);
1647
1648 if (frontTopRight.X > maxX)
1649 maxX = frontTopRight.X;
1650 if (frontTopLeft.X > maxX)
1651 maxX = frontTopLeft.X;
1652 if (frontBottomRight.X > maxX)
1653 maxX = frontBottomRight.X;
1654 if (frontBottomLeft.X > maxX)
1655 maxX = frontBottomLeft.X;
1656
1657 if (backTopRight.X > maxX)
1658 maxX = backTopRight.X;
1659 if (backTopLeft.X > maxX)
1660 maxX = backTopLeft.X;
1661 if (backBottomRight.X > maxX)
1662 maxX = backBottomRight.X;
1663 if (backBottomLeft.X > maxX)
1664 maxX = backBottomLeft.X;
1665
1666 if (frontTopRight.X < minX)
1667 minX = frontTopRight.X;
1668 if (frontTopLeft.X < minX)
1669 minX = frontTopLeft.X;
1670 if (frontBottomRight.X < minX)
1671 minX = frontBottomRight.X;
1672 if (frontBottomLeft.X < minX)
1673 minX = frontBottomLeft.X;
1674
1675 if (backTopRight.X < minX)
1676 minX = backTopRight.X;
1677 if (backTopLeft.X < minX)
1678 minX = backTopLeft.X;
1679 if (backBottomRight.X < minX)
1680 minX = backBottomRight.X;
1681 if (backBottomLeft.X < minX)
1682 minX = backBottomLeft.X;
1683 1624
1684 // 1625 float tmpS = Vector3.Dot(a, scale);
1685 if (frontTopRight.Y > maxY) 1626 float tmp = offset.X - tmpS;
1686 maxY = frontTopRight.Y; 1627 if (tmp < minX)
1687 if (frontTopLeft.Y > maxY) 1628 minX = tmp;
1688 maxY = frontTopLeft.Y;
1689 if (frontBottomRight.Y > maxY)
1690 maxY = frontBottomRight.Y;
1691 if (frontBottomLeft.Y > maxY)
1692 maxY = frontBottomLeft.Y;
1693
1694 if (backTopRight.Y > maxY)
1695 maxY = backTopRight.Y;
1696 if (backTopLeft.Y > maxY)
1697 maxY = backTopLeft.Y;
1698 if (backBottomRight.Y > maxY)
1699 maxY = backBottomRight.Y;
1700 if (backBottomLeft.Y > maxY)
1701 maxY = backBottomLeft.Y;
1702
1703 if (frontTopRight.Y < minY)
1704 minY = frontTopRight.Y;
1705 if (frontTopLeft.Y < minY)
1706 minY = frontTopLeft.Y;
1707 if (frontBottomRight.Y < minY)
1708 minY = frontBottomRight.Y;
1709 if (frontBottomLeft.Y < minY)
1710 minY = frontBottomLeft.Y;
1711
1712 if (backTopRight.Y < minY)
1713 minY = backTopRight.Y;
1714 if (backTopLeft.Y < minY)
1715 minY = backTopLeft.Y;
1716 if (backBottomRight.Y < minY)
1717 minY = backBottomRight.Y;
1718 if (backBottomLeft.Y < minY)
1719 minY = backBottomLeft.Y;
1720 1629
1721 // 1630 tmp = offset.X + tmpS;
1722 if (frontTopRight.Z > maxZ) 1631 if (tmp > maxX)
1723 maxZ = frontTopRight.Z; 1632 maxX = tmp;
1724 if (frontTopLeft.Z > maxZ) 1633
1725 maxZ = frontTopLeft.Z; 1634 a = m.LeftAxis;
1726 if (frontBottomRight.Z > maxZ) 1635 a.X = Math.Abs(a.X);
1727 maxZ = frontBottomRight.Z; 1636 a.Y = Math.Abs(a.Y);
1728 if (frontBottomLeft.Z > maxZ) 1637 a.Z = Math.Abs(a.Z);
1729 maxZ = frontBottomLeft.Z; 1638 tmpS = Vector3.Dot(a, scale);
1730 1639
1731 if (backTopRight.Z > maxZ) 1640 tmp = offset.Y - tmpS;
1732 maxZ = backTopRight.Z; 1641 if (tmp < minY)
1733 if (backTopLeft.Z > maxZ) 1642 minY = tmp;
1734 maxZ = backTopLeft.Z; 1643
1735 if (backBottomRight.Z > maxZ) 1644 tmp = offset.Y + tmpS;
1736 maxZ = backBottomRight.Z; 1645 if (tmp > maxY)
1737 if (backBottomLeft.Z > maxZ) 1646 maxY = tmp;
1738 maxZ = backBottomLeft.Z; 1647
1739 1648 a = m.UpAxis;
1740 if (frontTopRight.Z < minZ) 1649 a.X = Math.Abs(a.X);
1741 minZ = frontTopRight.Z; 1650 a.Y = Math.Abs(a.Y);
1742 if (frontTopLeft.Z < minZ) 1651 a.Z = Math.Abs(a.Z);
1743 minZ = frontTopLeft.Z; 1652
1744 if (frontBottomRight.Z < minZ) 1653 tmpS = Vector3.Dot(a, scale);
1745 minZ = frontBottomRight.Z; 1654 tmp = offset.Z - tmpS;
1746 if (frontBottomLeft.Z < minZ) 1655 if (tmp < minZ)
1747 minZ = frontBottomLeft.Z; 1656 minZ = tmp;
1748 1657
1749 if (backTopRight.Z < minZ) 1658 tmp = offset.Z + tmpS;
1750 minZ = backTopRight.Z; 1659 if (tmp > maxZ)
1751 if (backTopLeft.Z < minZ) 1660 maxZ = tmp;
1752 minZ = backTopLeft.Z;
1753 if (backBottomRight.Z < minZ)
1754 minZ = backBottomRight.Z;
1755 if (backBottomLeft.Z < minZ)
1756 minZ = backBottomLeft.Z;
1757 } 1661 }
1758 } 1662 }
1759 1663
@@ -1795,12 +1699,26 @@ namespace OpenSim.Region.Framework.Scenes
1795 } 1699 }
1796 1700
1797 private Vector3 m_boundsCenter; 1701 private Vector3 m_boundsCenter;
1798 public Vector3 getBoundsCenter() 1702 private Vector3 m_LastCenterOffset;
1703 private Vector3 last_boundsRot = new Vector3(-10, -10, -10);
1704 public Vector3 getCenterOffset()
1799 { 1705 {
1800 // math is done in GetBoundsRadius(); 1706 // math is done in GetBoundsRadius();
1801 if(m_boundsRadius == null) 1707 if(m_boundsRadius == null)
1802 GetBoundsRadius(); 1708 GetBoundsRadius();
1803 return m_boundsCenter; 1709
1710 Quaternion rot = m_rootPart.RotationOffset;
1711 if (last_boundsRot.X != rot.X ||
1712 last_boundsRot.Y != rot.Y ||
1713 last_boundsRot.Z != rot.Z)
1714 {
1715 m_LastCenterOffset = m_boundsCenter * rot;
1716 last_boundsRot.X = rot.X;
1717 last_boundsRot.Y = rot.Y;
1718 last_boundsRot.Z = rot.Z;
1719 }
1720
1721 return m_rootPart.GroupPosition + m_LastCenterOffset;
1804 } 1722 }
1805 1723
1806 private float m_areaFactor; 1724 private float m_areaFactor;
@@ -1819,14 +1737,10 @@ namespace OpenSim.Region.Framework.Scenes
1819 { 1737 {
1820 float res = 0; 1738 float res = 0;
1821 float areaF = 0; 1739 float areaF = 0;
1822 SceneObjectPart p;
1823 SceneObjectPart[] parts;
1824 float partR; 1740 float partR;
1825 Vector3 offset = Vector3.Zero; 1741 Vector3 offset = Vector3.Zero;
1826 lock (m_parts) 1742 SceneObjectPart p;
1827 { 1743 SceneObjectPart[] parts = m_parts.GetArray();
1828 parts = m_parts.GetArray();
1829 }
1830 1744
1831 int nparts = parts.Length; 1745 int nparts = parts.Length;
1832 for (int i = 0; i < nparts; i++) 1746 for (int i = 0; i < nparts; i++)
@@ -1846,11 +1760,10 @@ namespace OpenSim.Region.Framework.Scenes
1846 if(parts.Length > 1) 1760 if(parts.Length > 1)
1847 { 1761 {
1848 offset /= parts.Length; // basicly geometric center 1762 offset /= parts.Length; // basicly geometric center
1849 offset = offset * RootPart.RotationOffset;
1850 } 1763 }
1851 1764
1852 areaF = 10.0f / areaF; // scale it 1765 areaF = 0.5f / areaF; // scale it
1853 areaF = Util.Clamp(areaF, 0.001f, 1000f); // clamp it 1766 areaF = Util.Clamp(areaF, 0.05f, 100f); // clamp it
1854 1767
1855 m_areaFactor = (float)Math.Sqrt(areaF); 1768 m_areaFactor = (float)Math.Sqrt(areaF);
1856 m_boundsCenter = offset; 1769 m_boundsCenter = offset;
@@ -1872,16 +1785,9 @@ namespace OpenSim.Region.Framework.Scenes
1872 bool ComplexCost = false; 1785 bool ComplexCost = false;
1873 1786
1874 SceneObjectPart p; 1787 SceneObjectPart p;
1875 SceneObjectPart[] parts; 1788 SceneObjectPart[] parts = m_parts.GetArray();
1876
1877 lock (m_parts)
1878 {
1879 parts = m_parts.GetArray();
1880 }
1881 1789
1882 int nparts = parts.Length; 1790 int nparts = parts.Length;
1883
1884
1885 for (int i = 0; i < nparts; i++) 1791 for (int i = 0; i < nparts; i++)
1886 { 1792 {
1887 p = parts[i]; 1793 p = parts[i];
@@ -2478,7 +2384,6 @@ namespace OpenSim.Region.Framework.Scenes
2478 backup_group.RootPart.Velocity = RootPart.Velocity; 2384 backup_group.RootPart.Velocity = RootPart.Velocity;
2479 backup_group.RootPart.Acceleration = RootPart.Acceleration; 2385 backup_group.RootPart.Acceleration = RootPart.Acceleration;
2480 backup_group.RootPart.AngularVelocity = RootPart.AngularVelocity; 2386 backup_group.RootPart.AngularVelocity = RootPart.AngularVelocity;
2481 backup_group.RootPart.ParticleSystem = RootPart.ParticleSystem;
2482 HasGroupChanged = false; 2387 HasGroupChanged = false;
2483 GroupContainsForeignPrims = false; 2388 GroupContainsForeignPrims = false;
2484 2389
@@ -2588,30 +2493,10 @@ namespace OpenSim.Region.Framework.Scenes
2588 { 2493 {
2589 newPart = dupe.m_rootPart; 2494 newPart = dupe.m_rootPart;
2590 } 2495 }
2591/*
2592 bool isphys = ((newPart.Flags & PrimFlags.Physics) != 0);
2593 bool isphan = ((newPart.Flags & PrimFlags.Phantom) != 0);
2594 2496
2595 // Need to duplicate the physics actor as well
2596 if (userExposed && (isphys || !isphan || newPart.VolumeDetectActive))
2597 {
2598 PrimitiveBaseShape pbs = newPart.Shape;
2599 newPart.PhysActor
2600 = m_scene.PhysicsScene.AddPrimShape(
2601 string.Format("{0}/{1}", newPart.Name, newPart.UUID),
2602 pbs,
2603 newPart.AbsolutePosition,
2604 newPart.Scale,
2605 newPart.GetWorldRotation(),
2606 isphys,
2607 isphan,
2608 newPart.LocalId);
2609
2610 newPart.DoPhysicsPropertyUpdate(isphys, true);
2611 */
2612 if (userExposed) 2497 if (userExposed)
2613 newPart.ApplyPhysics((uint)newPart.Flags,newPart.VolumeDetectActive,true); 2498 newPart.ApplyPhysics((uint)newPart.Flags,newPart.VolumeDetectActive,true);
2614// } 2499
2615 // copy keyframemotion 2500 // copy keyframemotion
2616 if (part.KeyframeMotion != null) 2501 if (part.KeyframeMotion != null)
2617 newPart.KeyframeMotion = part.KeyframeMotion.Copy(dupe); 2502 newPart.KeyframeMotion = part.KeyframeMotion.Copy(dupe);
@@ -2619,8 +2504,6 @@ namespace OpenSim.Region.Framework.Scenes
2619 2504
2620 if (userExposed) 2505 if (userExposed)
2621 { 2506 {
2622// done above dupe.UpdateParentIDs();
2623
2624 if (dupe.m_rootPart.PhysActor != null) 2507 if (dupe.m_rootPart.PhysActor != null)
2625 dupe.m_rootPart.PhysActor.Building = false; // tell physics to finish building 2508 dupe.m_rootPart.PhysActor.Building = false; // tell physics to finish building
2626 2509
@@ -4015,7 +3898,7 @@ namespace OpenSim.Region.Framework.Scenes
4015 3898
4016 for (int i = 0; i < parts.Length; i++) 3899 for (int i = 0; i < parts.Length; i++)
4017 { 3900 {
4018 if (parts[i].LocalId != m_rootPart.LocalId) 3901 if (parts[i].UUID != m_rootPart.UUID)
4019 parts[i].UpdatePrimFlags(UsePhysics, SetTemporary, SetPhantom, SetVolumeDetect, true); 3902 parts[i].UpdatePrimFlags(UsePhysics, SetTemporary, SetPhantom, SetVolumeDetect, true);
4020 } 3903 }
4021 3904
diff --git a/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs b/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs
index 6f3c7e9..943141c 100644
--- a/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs
+++ b/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs
@@ -11240,50 +11240,33 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api
11240 } 11240 }
11241 11241
11242 part = World.GetSceneObjectPart(objID); 11242 part = World.GetSceneObjectPart(objID);
11243
11243 // Currently only works for single prims without a sitting avatar 11244 // Currently only works for single prims without a sitting avatar
11244 if (part != null) 11245 if (part == null)
11245 { 11246 {
11246 float minX; 11247 result.Add(new LSL_Vector());
11247 float maxX; 11248 result.Add(new LSL_Vector());
11248 float minY; 11249 return result;
11249 float maxY; 11250 }
11250 float minZ;
11251 float maxZ;
11252
11253 // This BBox is in sim coordinates, with the offset being
11254 // a contained point.
11255 Vector3[] offsets = Scene.GetCombinedBoundingBox(new List<SceneObjectGroup> { part.ParentGroup },
11256 out minX, out maxX, out minY, out maxY, out minZ, out maxZ);
11257
11258 minX -= offsets[0].X;
11259 maxX -= offsets[0].X;
11260 minY -= offsets[0].Y;
11261 maxY -= offsets[0].Y;
11262 minZ -= offsets[0].Z;
11263 maxZ -= offsets[0].Z;
11264
11265 LSL_Vector lower;
11266 LSL_Vector upper;
11267
11268 // Adjust to the documented error offsets (see LSL Wiki)
11269 lower = new LSL_Vector(minX + 0.05f, minY + 0.05f, minZ + 0.05f);
11270 upper = new LSL_Vector(maxX - 0.05f, maxY - 0.05f, maxZ - 0.05f);
11271
11272 if (lower.x > upper.x)
11273 lower.x = upper.x;
11274 if (lower.y > upper.y)
11275 lower.y = upper.y;
11276 if (lower.z > upper.z)
11277 lower.z = upper.z;
11278 11251
11279 result.Add(lower); 11252 SceneObjectGroup sog = part.ParentGroup;
11280 result.Add(upper); 11253 if(sog.IsDeleted)
11254 {
11255 result.Add(new LSL_Vector());
11256 result.Add(new LSL_Vector());
11281 return result; 11257 return result;
11282 } 11258 }
11283 11259
11284 // Not found so return empty values 11260 float minX;
11285 result.Add(new LSL_Vector()); 11261 float maxX;
11286 result.Add(new LSL_Vector()); 11262 float minY;
11263 float maxY;
11264 float minZ;
11265 float maxZ;
11266 sog.GetBoundingBox(out minX, out maxX, out minY, out maxY, out minZ, out maxZ);
11267
11268 result.Add(new LSL_Vector(minX, minY, minZ));
11269 result.Add(new LSL_Vector(maxX, maxY, maxZ));
11287 return result; 11270 return result;
11288 } 11271 }
11289 11272