summaryrefslogtreecommitdiff
path: root/indra/newview/llfloaterobjectweights.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'indra/newview/llfloaterobjectweights.cpp')
-rw-r--r--indra/newview/llfloaterobjectweights.cpp336
1 files changed, 168 insertions, 168 deletions
diff --git a/indra/newview/llfloaterobjectweights.cpp b/indra/newview/llfloaterobjectweights.cpp
index ed1ad4426f..090b0657d1 100644
--- a/indra/newview/llfloaterobjectweights.cpp
+++ b/indra/newview/llfloaterobjectweights.cpp
@@ -39,43 +39,43 @@
// virtual
bool LLCrossParcelFunctor::apply(LLViewerObject* obj)
{
- // Add the root object box.
- mBoundingBox.addBBoxAgent(LLBBox(obj->getPositionRegion(), obj->getRotationRegion(), obj->getScale() * -0.5f, obj->getScale() * 0.5f).getAxisAligned());
-
- // Extend the bounding box across all the children.
- LLViewerObject::const_child_list_t children = obj->getChildren();
- for (LLViewerObject::const_child_list_t::const_iterator iter = children.begin();
- iter != children.end(); iter++)
- {
- LLViewerObject* child = *iter;
- mBoundingBox.addBBoxAgent(LLBBox(child->getPositionRegion(), child->getRotationRegion(), child->getScale() * -0.5f, child->getScale() * 0.5f).getAxisAligned());
- }
-
- bool result = false;
-
- LLViewerRegion* region = obj->getRegion();
- if (region)
- {
- std::vector<LLBBox> boxes;
- boxes.push_back(mBoundingBox);
- result = region->objectsCrossParcel(boxes);
- }
-
- return result;
+ // Add the root object box.
+ mBoundingBox.addBBoxAgent(LLBBox(obj->getPositionRegion(), obj->getRotationRegion(), obj->getScale() * -0.5f, obj->getScale() * 0.5f).getAxisAligned());
+
+ // Extend the bounding box across all the children.
+ LLViewerObject::const_child_list_t children = obj->getChildren();
+ for (LLViewerObject::const_child_list_t::const_iterator iter = children.begin();
+ iter != children.end(); iter++)
+ {
+ LLViewerObject* child = *iter;
+ mBoundingBox.addBBoxAgent(LLBBox(child->getPositionRegion(), child->getRotationRegion(), child->getScale() * -0.5f, child->getScale() * 0.5f).getAxisAligned());
+ }
+
+ bool result = false;
+
+ LLViewerRegion* region = obj->getRegion();
+ if (region)
+ {
+ std::vector<LLBBox> boxes;
+ boxes.push_back(mBoundingBox);
+ result = region->objectsCrossParcel(boxes);
+ }
+
+ return result;
}
LLFloaterObjectWeights::LLFloaterObjectWeights(const LLSD& key)
-: LLFloater(key),
- mSelectedObjects(NULL),
- mSelectedPrims(NULL),
- mSelectedDownloadWeight(NULL),
- mSelectedPhysicsWeight(NULL),
- mSelectedServerWeight(NULL),
- mSelectedDisplayWeight(NULL),
- mSelectedOnLand(NULL),
- mRezzedOnLand(NULL),
- mRemainingCapacity(NULL),
- mTotalCapacity(NULL)
+: LLFloater(key),
+ mSelectedObjects(NULL),
+ mSelectedPrims(NULL),
+ mSelectedDownloadWeight(NULL),
+ mSelectedPhysicsWeight(NULL),
+ mSelectedServerWeight(NULL),
+ mSelectedDisplayWeight(NULL),
+ mSelectedOnLand(NULL),
+ mRezzedOnLand(NULL),
+ mRemainingCapacity(NULL),
+ mTotalCapacity(NULL)
{
}
@@ -86,189 +86,189 @@ LLFloaterObjectWeights::~LLFloaterObjectWeights()
// virtual
BOOL LLFloaterObjectWeights::postBuild()
{
- mSelectedObjects = getChild<LLTextBox>("objects");
- mSelectedPrims = getChild<LLTextBox>("prims");
+ mSelectedObjects = getChild<LLTextBox>("objects");
+ mSelectedPrims = getChild<LLTextBox>("prims");
- mSelectedDownloadWeight = getChild<LLTextBox>("download");
- mSelectedPhysicsWeight = getChild<LLTextBox>("physics");
- mSelectedServerWeight = getChild<LLTextBox>("server");
- mSelectedDisplayWeight = getChild<LLTextBox>("display");
+ mSelectedDownloadWeight = getChild<LLTextBox>("download");
+ mSelectedPhysicsWeight = getChild<LLTextBox>("physics");
+ mSelectedServerWeight = getChild<LLTextBox>("server");
+ mSelectedDisplayWeight = getChild<LLTextBox>("display");
- mSelectedOnLand = getChild<LLTextBox>("selected");
- mRezzedOnLand = getChild<LLTextBox>("rezzed_on_land");
- mRemainingCapacity = getChild<LLTextBox>("remaining_capacity");
- mTotalCapacity = getChild<LLTextBox>("total_capacity");
+ mSelectedOnLand = getChild<LLTextBox>("selected");
+ mRezzedOnLand = getChild<LLTextBox>("rezzed_on_land");
+ mRemainingCapacity = getChild<LLTextBox>("remaining_capacity");
+ mTotalCapacity = getChild<LLTextBox>("total_capacity");
- return TRUE;
+ return TRUE;
}
// virtual
void LLFloaterObjectWeights::onOpen(const LLSD& key)
{
- refresh();
- updateLandImpacts(LLViewerParcelMgr::getInstance()->getFloatingParcelSelection()->getParcel());
+ refresh();
+ updateLandImpacts(LLViewerParcelMgr::getInstance()->getFloatingParcelSelection()->getParcel());
}
// virtual
void LLFloaterObjectWeights::onWeightsUpdate(const SelectionCost& selection_cost)
{
- mSelectedDownloadWeight->setText(llformat("%.1f", selection_cost.mNetworkCost));
- mSelectedPhysicsWeight->setText(llformat("%.1f", selection_cost.mPhysicsCost));
- mSelectedServerWeight->setText(llformat("%.1f", selection_cost.mSimulationCost));
+ mSelectedDownloadWeight->setText(llformat("%.1f", selection_cost.mNetworkCost));
+ mSelectedPhysicsWeight->setText(llformat("%.1f", selection_cost.mPhysicsCost));
+ mSelectedServerWeight->setText(llformat("%.1f", selection_cost.mSimulationCost));
- S32 render_cost = LLSelectMgr::getInstance()->getSelection()->getSelectedObjectRenderCost();
- mSelectedDisplayWeight->setText(llformat("%d", render_cost));
+ S32 render_cost = LLSelectMgr::getInstance()->getSelection()->getSelectedObjectRenderCost();
+ mSelectedDisplayWeight->setText(llformat("%d", render_cost));
- toggleWeightsLoadingIndicators(false);
+ toggleWeightsLoadingIndicators(false);
}
//virtual
void LLFloaterObjectWeights::setErrorStatus(S32 status, const std::string& reason)
{
- const std::string text = getString("nothing_selected");
+ const std::string text = getString("nothing_selected");
- mSelectedDownloadWeight->setText(text);
- mSelectedPhysicsWeight->setText(text);
- mSelectedServerWeight->setText(text);
- mSelectedDisplayWeight->setText(text);
+ mSelectedDownloadWeight->setText(text);
+ mSelectedPhysicsWeight->setText(text);
+ mSelectedServerWeight->setText(text);
+ mSelectedDisplayWeight->setText(text);
- toggleWeightsLoadingIndicators(false);
+ toggleWeightsLoadingIndicators(false);
}
void LLFloaterObjectWeights::updateLandImpacts(const LLParcel* parcel)
{
- if (!parcel || LLSelectMgr::getInstance()->getSelection()->isEmpty())
- {
- updateIfNothingSelected();
- }
- else
- {
- S32 rezzed_prims = parcel->getSimWidePrimCount();
- S32 total_capacity = parcel->getSimWideMaxPrimCapacity();
- // Can't have more than region max tasks, regardless of parcel
- // object bonus factor.
- LLViewerRegion* region = LLViewerParcelMgr::getInstance()->getSelectionRegion();
- if (region)
- {
- S32 max_tasks_per_region = (S32)region->getMaxTasks();
- total_capacity = llmin(total_capacity, max_tasks_per_region);
- }
-
- mRezzedOnLand->setText(llformat("%d", rezzed_prims));
- mRemainingCapacity->setText(llformat("%d", total_capacity - rezzed_prims));
- mTotalCapacity->setText(llformat("%d", total_capacity));
-
- toggleLandImpactsLoadingIndicators(false);
- }
+ if (!parcel || LLSelectMgr::getInstance()->getSelection()->isEmpty())
+ {
+ updateIfNothingSelected();
+ }
+ else
+ {
+ S32 rezzed_prims = parcel->getSimWidePrimCount();
+ S32 total_capacity = parcel->getSimWideMaxPrimCapacity();
+ // Can't have more than region max tasks, regardless of parcel
+ // object bonus factor.
+ LLViewerRegion* region = LLViewerParcelMgr::getInstance()->getSelectionRegion();
+ if (region)
+ {
+ S32 max_tasks_per_region = (S32)region->getMaxTasks();
+ total_capacity = llmin(total_capacity, max_tasks_per_region);
+ }
+
+ mRezzedOnLand->setText(llformat("%d", rezzed_prims));
+ mRemainingCapacity->setText(llformat("%d", total_capacity - rezzed_prims));
+ mTotalCapacity->setText(llformat("%d", total_capacity));
+
+ toggleLandImpactsLoadingIndicators(false);
+ }
}
void LLFloaterObjectWeights::refresh()
{
- LLSelectMgr* sel_mgr = LLSelectMgr::getInstance();
-
- if (sel_mgr->getSelection()->isEmpty())
- {
- updateIfNothingSelected();
- }
- else
- {
- S32 prim_count = sel_mgr->getSelection()->getObjectCount();
- S32 link_count = sel_mgr->getSelection()->getRootObjectCount();
- F32 prim_equiv = sel_mgr->getSelection()->getSelectedLinksetCost();
-
- mSelectedObjects->setText(llformat("%d", link_count));
- mSelectedPrims->setText(llformat("%d", prim_count));
- mSelectedOnLand->setText(llformat("%.1d", (S32)prim_equiv));
-
- LLCrossParcelFunctor func;
- if (sel_mgr->getSelection()->applyToRootObjects(&func, true))
- {
- // Some of the selected objects cross parcel bounds.
- // We don't display object weights and land impacts in this case.
- const std::string text = getString("nothing_selected");
-
- mRezzedOnLand->setText(text);
- mRemainingCapacity->setText(text);
- mTotalCapacity->setText(text);
-
- toggleLandImpactsLoadingIndicators(false);
- }
-
- LLViewerRegion* region = gAgent.getRegion();
- if (region && region->capabilitiesReceived())
- {
- for (LLObjectSelection::valid_root_iterator iter = sel_mgr->getSelection()->valid_root_begin();
- iter != sel_mgr->getSelection()->valid_root_end(); ++iter)
- {
- LLAccountingCostManager::getInstance()->addObject((*iter)->getObject()->getID());
- }
-
- std::string url = region->getCapability("ResourceCostSelected");
- if (!url.empty())
- {
- // Update the transaction id before the new fetch request
- generateTransactionID();
-
- LLAccountingCostManager::getInstance()->fetchCosts(Roots, url, getObserverHandle());
- toggleWeightsLoadingIndicators(true);
- }
- }
- else
- {
- LL_WARNS() << "Failed to get region capabilities" << LL_ENDL;
- }
- }
+ LLSelectMgr* sel_mgr = LLSelectMgr::getInstance();
+
+ if (sel_mgr->getSelection()->isEmpty())
+ {
+ updateIfNothingSelected();
+ }
+ else
+ {
+ S32 prim_count = sel_mgr->getSelection()->getObjectCount();
+ S32 link_count = sel_mgr->getSelection()->getRootObjectCount();
+ F32 prim_equiv = sel_mgr->getSelection()->getSelectedLinksetCost();
+
+ mSelectedObjects->setText(llformat("%d", link_count));
+ mSelectedPrims->setText(llformat("%d", prim_count));
+ mSelectedOnLand->setText(llformat("%.1d", (S32)prim_equiv));
+
+ LLCrossParcelFunctor func;
+ if (sel_mgr->getSelection()->applyToRootObjects(&func, true))
+ {
+ // Some of the selected objects cross parcel bounds.
+ // We don't display object weights and land impacts in this case.
+ const std::string text = getString("nothing_selected");
+
+ mRezzedOnLand->setText(text);
+ mRemainingCapacity->setText(text);
+ mTotalCapacity->setText(text);
+
+ toggleLandImpactsLoadingIndicators(false);
+ }
+
+ LLViewerRegion* region = gAgent.getRegion();
+ if (region && region->capabilitiesReceived())
+ {
+ for (LLObjectSelection::valid_root_iterator iter = sel_mgr->getSelection()->valid_root_begin();
+ iter != sel_mgr->getSelection()->valid_root_end(); ++iter)
+ {
+ LLAccountingCostManager::getInstance()->addObject((*iter)->getObject()->getID());
+ }
+
+ std::string url = region->getCapability("ResourceCostSelected");
+ if (!url.empty())
+ {
+ // Update the transaction id before the new fetch request
+ generateTransactionID();
+
+ LLAccountingCostManager::getInstance()->fetchCosts(Roots, url, getObserverHandle());
+ toggleWeightsLoadingIndicators(true);
+ }
+ }
+ else
+ {
+ LL_WARNS() << "Failed to get region capabilities" << LL_ENDL;
+ }
+ }
}
// virtual
void LLFloaterObjectWeights::generateTransactionID()
{
- mTransactionID.generate();
+ mTransactionID.generate();
}
void LLFloaterObjectWeights::toggleWeightsLoadingIndicators(bool visible)
{
- childSetVisible("download_loading_indicator", visible);
- childSetVisible("physics_loading_indicator", visible);
- childSetVisible("server_loading_indicator", visible);
- childSetVisible("display_loading_indicator", visible);
-
- mSelectedDownloadWeight->setVisible(!visible);
- mSelectedPhysicsWeight->setVisible(!visible);
- mSelectedServerWeight->setVisible(!visible);
- mSelectedDisplayWeight->setVisible(!visible);
+ childSetVisible("download_loading_indicator", visible);
+ childSetVisible("physics_loading_indicator", visible);
+ childSetVisible("server_loading_indicator", visible);
+ childSetVisible("display_loading_indicator", visible);
+
+ mSelectedDownloadWeight->setVisible(!visible);
+ mSelectedPhysicsWeight->setVisible(!visible);
+ mSelectedServerWeight->setVisible(!visible);
+ mSelectedDisplayWeight->setVisible(!visible);
}
void LLFloaterObjectWeights::toggleLandImpactsLoadingIndicators(bool visible)
{
- childSetVisible("selected_loading_indicator", visible);
- childSetVisible("rezzed_on_land_loading_indicator", visible);
- childSetVisible("remaining_capacity_loading_indicator", visible);
- childSetVisible("total_capacity_loading_indicator", visible);
-
- mSelectedOnLand->setVisible(!visible);
- mRezzedOnLand->setVisible(!visible);
- mRemainingCapacity->setVisible(!visible);
- mTotalCapacity->setVisible(!visible);
+ childSetVisible("selected_loading_indicator", visible);
+ childSetVisible("rezzed_on_land_loading_indicator", visible);
+ childSetVisible("remaining_capacity_loading_indicator", visible);
+ childSetVisible("total_capacity_loading_indicator", visible);
+
+ mSelectedOnLand->setVisible(!visible);
+ mRezzedOnLand->setVisible(!visible);
+ mRemainingCapacity->setVisible(!visible);
+ mTotalCapacity->setVisible(!visible);
}
void LLFloaterObjectWeights::updateIfNothingSelected()
{
- const std::string text = getString("nothing_selected");
+ const std::string text = getString("nothing_selected");
- mSelectedObjects->setText(text);
- mSelectedPrims->setText(text);
+ mSelectedObjects->setText(text);
+ mSelectedPrims->setText(text);
- mSelectedDownloadWeight->setText(text);
- mSelectedPhysicsWeight->setText(text);
- mSelectedServerWeight->setText(text);
- mSelectedDisplayWeight->setText(text);
+ mSelectedDownloadWeight->setText(text);
+ mSelectedPhysicsWeight->setText(text);
+ mSelectedServerWeight->setText(text);
+ mSelectedDisplayWeight->setText(text);
- mSelectedOnLand->setText(text);
- mRezzedOnLand->setText(text);
- mRemainingCapacity->setText(text);
- mTotalCapacity->setText(text);
+ mSelectedOnLand->setText(text);
+ mRezzedOnLand->setText(text);
+ mRemainingCapacity->setText(text);
+ mTotalCapacity->setText(text);
- toggleWeightsLoadingIndicators(false);
- toggleLandImpactsLoadingIndicators(false);
+ toggleWeightsLoadingIndicators(false);
+ toggleLandImpactsLoadingIndicators(false);
}