aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/newview/llpanelobject.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'linden/indra/newview/llpanelobject.cpp')
-rw-r--r--linden/indra/newview/llpanelobject.cpp109
1 files changed, 89 insertions, 20 deletions
diff --git a/linden/indra/newview/llpanelobject.cpp b/linden/indra/newview/llpanelobject.cpp
index 7024691..9022c14 100644
--- a/linden/indra/newview/llpanelobject.cpp
+++ b/linden/indra/newview/llpanelobject.cpp
@@ -99,7 +99,7 @@ enum {
99}; 99};
100 100
101//*TODO:translate (depricated, so very low priority) 101//*TODO:translate (depricated, so very low priority)
102static const LLString LEGACY_FULLBRIGHT_DESC("Fullbright (Legacy)"); 102static const std::string LEGACY_FULLBRIGHT_DESC("Fullbright (Legacy)");
103 103
104BOOL LLPanelObject::postBuild() 104BOOL LLPanelObject::postBuild()
105{ 105{
@@ -289,9 +289,12 @@ BOOL LLPanelObject::postBuild()
289 } 289 }
290 290
291 mLabelSculptType = getChild<LLTextBox>("label sculpt type"); 291 mLabelSculptType = getChild<LLTextBox>("label sculpt type");
292 mCtrlSculptType = getChild<LLComboBox>( "sculpt type control"); 292 mCtrlSculptType = getChild<LLComboBox>("sculpt type control");
293 childSetCommitCallback("sculpt type control", onCommitSculptType, this); 293 childSetCommitCallback("sculpt type control", onCommitSculptType, this);
294 294 mCtrlSculptMirror = getChild<LLCheckBoxCtrl>("sculpt mirror control");
295 childSetCommitCallback("sculpt mirror control", onCommitSculptType, this);
296 mCtrlSculptInvert = getChild<LLCheckBoxCtrl>("sculpt invert control");
297 childSetCommitCallback("sculpt invert control", onCommitSculptType, this);
295 298
296 // Start with everyone disabled 299 // Start with everyone disabled
297 clearCtrls(); 300 clearCtrls();
@@ -429,7 +432,7 @@ void LLPanelObject::getState( )
429 432
430 BOOL owners_identical; 433 BOOL owners_identical;
431 LLUUID owner_id; 434 LLUUID owner_id;
432 LLString owner_name; 435 std::string owner_name;
433 owners_identical = LLSelectMgr::getInstance()->selectGetOwner(owner_id, owner_name); 436 owners_identical = LLSelectMgr::getInstance()->selectGetOwner(owner_id, owner_name);
434 437
435 // BUG? Check for all objects being editable? 438 // BUG? Check for all objects being editable?
@@ -538,7 +541,7 @@ void LLPanelObject::getState( )
538 mComboMaterial->remove(LEGACY_FULLBRIGHT_DESC); 541 mComboMaterial->remove(LEGACY_FULLBRIGHT_DESC);
539 } 542 }
540 // *TODO:Translate 543 // *TODO:Translate
541 mComboMaterial->setSimple(LLString(LLMaterialTable::basic.getName(material_code))); 544 mComboMaterial->setSimple(std::string(LLMaterialTable::basic.getName(material_code)));
542 } 545 }
543 } 546 }
544 else 547 else
@@ -1057,6 +1060,8 @@ void LLPanelObject::getState( )
1057 mCtrlSculptTexture->setVisible(sculpt_texture_visible); 1060 mCtrlSculptTexture->setVisible(sculpt_texture_visible);
1058 mLabelSculptType->setVisible(sculpt_texture_visible); 1061 mLabelSculptType->setVisible(sculpt_texture_visible);
1059 mCtrlSculptType->setVisible(sculpt_texture_visible); 1062 mCtrlSculptType->setVisible(sculpt_texture_visible);
1063 mCtrlSculptMirror->setVisible(sculpt_texture_visible);
1064 mCtrlSculptInvert->setVisible(sculpt_texture_visible);
1060 1065
1061 1066
1062 // sculpt texture 1067 // sculpt texture
@@ -1086,12 +1091,29 @@ void LLPanelObject::getState( )
1086 mTextureCtrl->setImageAssetID(LLUUID::null); 1091 mTextureCtrl->setImageAssetID(LLUUID::null);
1087 } 1092 }
1088 1093
1094 U8 sculpt_type = sculpt_params->getSculptType();
1095 U8 sculpt_stitching = sculpt_type & LL_SCULPT_TYPE_MASK;
1096 BOOL sculpt_invert = sculpt_type & LL_SCULPT_FLAG_INVERT;
1097 BOOL sculpt_mirror = sculpt_type & LL_SCULPT_FLAG_MIRROR;
1098
1089 if (mCtrlSculptType) 1099 if (mCtrlSculptType)
1090 { 1100 {
1091 mCtrlSculptType->setCurrentByIndex(sculpt_params->getSculptType()); 1101 mCtrlSculptType->setCurrentByIndex(sculpt_stitching);
1092 mCtrlSculptType->setEnabled(editable); 1102 mCtrlSculptType->setEnabled(editable);
1093 } 1103 }
1094 1104
1105 if (mCtrlSculptMirror)
1106 {
1107 mCtrlSculptMirror->set(sculpt_mirror);
1108 mCtrlSculptMirror->setEnabled(editable);
1109 }
1110
1111 if (mCtrlSculptInvert)
1112 {
1113 mCtrlSculptInvert->set(sculpt_invert);
1114 mCtrlSculptInvert->setEnabled(editable);
1115 }
1116
1095 if (mLabelSculptType) 1117 if (mLabelSculptType)
1096 { 1118 {
1097 mLabelSculptType->setEnabled(TRUE); 1119 mLabelSculptType->setEnabled(TRUE);
@@ -1191,10 +1213,10 @@ void LLPanelObject::onCommitMaterial( LLUICtrl* ctrl, void* userdata )
1191 if (box) 1213 if (box)
1192 { 1214 {
1193 // apply the currently selected material to the object 1215 // apply the currently selected material to the object
1194 const LLString& material_name = box->getSimple(); 1216 const std::string& material_name = box->getSimple();
1195 if (material_name != LEGACY_FULLBRIGHT_DESC) 1217 if (material_name != LEGACY_FULLBRIGHT_DESC)
1196 { 1218 {
1197 U8 material_code = LLMaterialTable::basic.getMCode(material_name.c_str()); 1219 U8 material_code = LLMaterialTable::basic.getMCode(material_name);
1198 LLSelectMgr::getInstance()->selectionSetMaterial(material_code); 1220 LLSelectMgr::getInstance()->selectionSetMaterial(material_code);
1199 } 1221 }
1200 } 1222 }
@@ -1546,7 +1568,7 @@ void LLPanelObject::getVolumeParams(LLVolumeParams& volume_params)
1546} 1568}
1547 1569
1548// BUG: Make work with multiple objects 1570// BUG: Make work with multiple objects
1549void LLPanelObject::sendRotation() 1571void LLPanelObject::sendRotation(BOOL btn_down)
1550{ 1572{
1551 if (mObject.isNull()) return; 1573 if (mObject.isNull()) return;
1552 1574
@@ -1570,16 +1592,34 @@ void LLPanelObject::sendRotation()
1570 { 1592 {
1571 rotation = rotation * ~mRootObject->getRotationRegion(); 1593 rotation = rotation * ~mRootObject->getRotationRegion();
1572 } 1594 }
1595 std::vector<LLVector3>& child_positions = mObject->mUnselectedChildrenPositions ;
1596 std::vector<LLQuaternion> child_rotations;
1597 if (mObject->isRootEdit())
1598 {
1599 mObject->saveUnselectedChildrenRotation(child_rotations) ;
1600 mObject->saveUnselectedChildrenPosition(child_positions) ;
1601 }
1573 1602
1574 mObject->setRotation(rotation, TRUE ); 1603 mObject->setRotation(rotation);
1604 LLManip::rebuild(mObject) ;
1575 1605
1576 LLSelectMgr::getInstance()->sendMultipleUpdate(UPD_ROTATION); 1606 // for individually selected roots, we need to counterrotate all the children
1607 if (mObject->isRootEdit())
1608 {
1609 mObject->resetChildrenRotationAndPosition(child_rotations, child_positions) ;
1610 }
1611
1612 if(!btn_down)
1613 {
1614 child_positions.clear() ;
1615 LLSelectMgr::getInstance()->sendMultipleUpdate(UPD_ROTATION | UPD_POSITION);
1616 }
1577 } 1617 }
1578} 1618}
1579 1619
1580 1620
1581// BUG: Make work with multiple objects 1621// BUG: Make work with multiple objects
1582void LLPanelObject::sendScale() 1622void LLPanelObject::sendScale(BOOL btn_down)
1583{ 1623{
1584 if (mObject.isNull()) return; 1624 if (mObject.isNull()) return;
1585 1625
@@ -1599,7 +1639,11 @@ void LLPanelObject::sendScale()
1599 } 1639 }
1600 1640
1601 mObject->setScale(newscale, TRUE); 1641 mObject->setScale(newscale, TRUE);
1602 LLSelectMgr::getInstance()->sendMultipleUpdate(UPD_SCALE | UPD_POSITION); 1642
1643 if(!btn_down)
1644 {
1645 LLSelectMgr::getInstance()->sendMultipleUpdate(UPD_SCALE | UPD_POSITION);
1646 }
1603 1647
1604 LLSelectMgr::getInstance()->adjustTexturesByScale(TRUE, !dont_stretch_textures); 1648 LLSelectMgr::getInstance()->adjustTexturesByScale(TRUE, !dont_stretch_textures);
1605// llinfos << "scale sent" << llendl; 1649// llinfos << "scale sent" << llendl;
@@ -1611,7 +1655,7 @@ void LLPanelObject::sendScale()
1611} 1655}
1612 1656
1613 1657
1614void LLPanelObject::sendPosition() 1658void LLPanelObject::sendPosition(BOOL btn_down)
1615{ 1659{
1616 if (mObject.isNull()) return; 1660 if (mObject.isNull()) return;
1617 1661
@@ -1654,7 +1698,7 @@ void LLPanelObject::sendPosition()
1654 LLVector3d delta = new_pos_global - old_pos_global; 1698 LLVector3d delta = new_pos_global - old_pos_global;
1655 // moved more than 1/2 millimeter 1699 // moved more than 1/2 millimeter
1656 if (delta.magVec() >= 0.0005f) 1700 if (delta.magVec() >= 0.0005f)
1657 { 1701 {
1658 if (mRootObject != mObject) 1702 if (mRootObject != mObject)
1659 { 1703 {
1660 newpos = newpos - mRootObject->getPositionRegion(); 1704 newpos = newpos - mRootObject->getPositionRegion();
@@ -1664,8 +1708,21 @@ void LLPanelObject::sendPosition()
1664 else 1708 else
1665 { 1709 {
1666 mObject->setPositionEdit(newpos); 1710 mObject->setPositionEdit(newpos);
1711 }
1712
1713 LLManip::rebuild(mObject) ;
1714
1715 // for individually selected roots, we need to counter-translate all unselected children
1716 if (mObject->isRootEdit())
1717 {
1718 // only offset by parent's translation
1719 mObject->resetChildrenPosition(LLVector3(-delta), TRUE) ;
1720 }
1721
1722 if(!btn_down)
1723 {
1724 LLSelectMgr::getInstance()->sendMultipleUpdate(UPD_POSITION);
1667 } 1725 }
1668 LLSelectMgr::getInstance()->sendMultipleUpdate(UPD_POSITION);
1669 1726
1670 LLSelectMgr::getInstance()->updateSelectionCenter(); 1727 LLSelectMgr::getInstance()->updateSelectionCenter();
1671 } 1728 }
@@ -1690,9 +1747,18 @@ void LLPanelObject::sendSculpt()
1690 if (mCtrlSculptTexture) 1747 if (mCtrlSculptTexture)
1691 sculpt_params.setSculptTexture(mCtrlSculptTexture->getImageAssetID()); 1748 sculpt_params.setSculptTexture(mCtrlSculptTexture->getImageAssetID());
1692 1749
1750 U8 sculpt_type = 0;
1751
1693 if (mCtrlSculptType) 1752 if (mCtrlSculptType)
1694 sculpt_params.setSculptType(mCtrlSculptType->getCurrentIndex()); 1753 sculpt_type |= mCtrlSculptType->getCurrentIndex();
1754
1755 if ((mCtrlSculptMirror) && (mCtrlSculptMirror->get()))
1756 sculpt_type |= LL_SCULPT_FLAG_MIRROR;
1757
1758 if ((mCtrlSculptInvert) && (mCtrlSculptInvert->get()))
1759 sculpt_type |= LL_SCULPT_FLAG_INVERT;
1695 1760
1761 sculpt_params.setSculptType(sculpt_type);
1696 mObject->setParameterEntry(LLNetworkData::PARAMS_SCULPT, sculpt_params, TRUE); 1762 mObject->setParameterEntry(LLNetworkData::PARAMS_SCULPT, sculpt_params, TRUE);
1697} 1763}
1698 1764
@@ -1846,21 +1912,24 @@ void LLPanelObject::onCommitLock(LLUICtrl *ctrl, void *data)
1846void LLPanelObject::onCommitPosition( LLUICtrl* ctrl, void* userdata ) 1912void LLPanelObject::onCommitPosition( LLUICtrl* ctrl, void* userdata )
1847{ 1913{
1848 LLPanelObject* self = (LLPanelObject*) userdata; 1914 LLPanelObject* self = (LLPanelObject*) userdata;
1849 self->sendPosition(); 1915 BOOL btn_down = ((LLSpinCtrl*)ctrl)->isMouseHeldDown() ;
1916 self->sendPosition(btn_down);
1850} 1917}
1851 1918
1852// static 1919// static
1853void LLPanelObject::onCommitScale( LLUICtrl* ctrl, void* userdata ) 1920void LLPanelObject::onCommitScale( LLUICtrl* ctrl, void* userdata )
1854{ 1921{
1855 LLPanelObject* self = (LLPanelObject*) userdata; 1922 LLPanelObject* self = (LLPanelObject*) userdata;
1856 self->sendScale(); 1923 BOOL btn_down = ((LLSpinCtrl*)ctrl)->isMouseHeldDown() ;
1924 self->sendScale(btn_down);
1857} 1925}
1858 1926
1859// static 1927// static
1860void LLPanelObject::onCommitRotation( LLUICtrl* ctrl, void* userdata ) 1928void LLPanelObject::onCommitRotation( LLUICtrl* ctrl, void* userdata )
1861{ 1929{
1862 LLPanelObject* self = (LLPanelObject*) userdata; 1930 LLPanelObject* self = (LLPanelObject*) userdata;
1863 self->sendRotation(); 1931 BOOL btn_down = ((LLSpinCtrl*)ctrl)->isMouseHeldDown() ;
1932 self->sendRotation(btn_down);
1864} 1933}
1865 1934
1866// static 1935// static