diff options
Diffstat (limited to 'indra/newview/llpanelsnapshot.cpp')
-rw-r--r-- | indra/newview/llpanelsnapshot.cpp | 202 |
1 files changed, 102 insertions, 100 deletions
diff --git a/indra/newview/llpanelsnapshot.cpp b/indra/newview/llpanelsnapshot.cpp index c3524a8c87..32c9f6f402 100644 --- a/indra/newview/llpanelsnapshot.cpp +++ b/indra/newview/llpanelsnapshot.cpp @@ -1,25 +1,25 @@ -/** +/** * @file llpanelsnapshot.cpp * @brief Snapshot panel base class * * $LicenseInfo:firstyear=2011&license=viewerlgpl$ * Second Life Viewer Source Code * Copyright (C) 2011, Linden Research, Inc. - * + * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; * version 2.1 of the License only. - * + * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. - * + * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA - * + * * Linden Research, Inc., 945 Battery Street, San Francisco, CA 94111 USA * $/LicenseInfo$ */ @@ -41,28 +41,30 @@ #include "llagentbenefits.h" -const S32 MAX_TEXTURE_SIZE = 512 ; //max upload texture size 512 * 512 +constexpr S32 MAX_TEXTURE_SIZE = 2048 ; //max upload texture size 2048 * 2048 S32 power_of_two(S32 sz, S32 upper) { - S32 res = upper; - while( upper >= sz) - { - res = upper; - upper >>= 1; - } - return res; + S32 res = upper; + while( upper >= sz) + { + res = upper; + upper >>= 1; + } + return res; } LLPanelSnapshot::LLPanelSnapshot() - : mSnapshotFloater(NULL) + : mSnapshotFloater(NULL) {} // virtual -BOOL LLPanelSnapshot::postBuild() +bool LLPanelSnapshot::postBuild() { - getChild<LLUICtrl>("save_btn")->setLabelArg("[UPLOAD_COST]", std::to_string(LLAgentBenefitsMgr::current().getTextureUploadCost())); - getChild<LLUICtrl>(getImageSizeComboName())->setCommitCallback(boost::bind(&LLPanelSnapshot::onResolutionComboCommit, this, _1)); + S32 w = getTypedPreviewWidth(); + S32 h = getTypedPreviewHeight(); + getChild<LLUICtrl>("save_btn")->setLabelArg("[UPLOAD_COST]", std::to_string(LLAgentBenefitsMgr::current().getTextureUploadCost(w, h))); + getChild<LLUICtrl>(getImageSizeComboName())->setCommitCallback(boost::bind(&LLPanelSnapshot::onResolutionComboCommit, this, _1)); if (!getWidthSpinnerName().empty()) { getChild<LLUICtrl>(getWidthSpinnerName())->setCommitCallback(boost::bind(&LLPanelSnapshot::onCustomResolutionCommit, this)); @@ -75,56 +77,56 @@ BOOL LLPanelSnapshot::postBuild() { getChild<LLUICtrl>(getAspectRatioCBName())->setCommitCallback(boost::bind(&LLPanelSnapshot::onKeepAspectRatioCommit, this, _1)); } - updateControls(LLSD()); + updateControls(LLSD()); - mSnapshotFloater = getParentByType<LLFloaterSnapshotBase>(); - return TRUE; + mSnapshotFloater = getParentByType<LLFloaterSnapshotBase>(); + return true; } // virtual void LLPanelSnapshot::onOpen(const LLSD& key) { - S32 old_format = gSavedSettings.getS32("SnapshotFormat"); - S32 new_format = (S32) getImageFormat(); + S32 old_format = gSavedSettings.getS32("SnapshotFormat"); + S32 new_format = (S32) getImageFormat(); - gSavedSettings.setS32("SnapshotFormat", new_format); - setCtrlsEnabled(true); + gSavedSettings.setS32("SnapshotFormat", new_format); + setCtrlsEnabled(true); - // Switching panels will likely change image format. - // Not updating preview right away may lead to errors, - // e.g. attempt to send a large BMP image by email. - if (old_format != new_format) - { + // Switching panels will likely change image format. + // Not updating preview right away may lead to errors, + // e.g. attempt to send a large BMP image by email. + if (old_format != new_format) + { getParentByType<LLFloater>()->notify(LLSD().with("image-format-change", true)); - } + } } LLSnapshotModel::ESnapshotFormat LLPanelSnapshot::getImageFormat() const { - return LLSnapshotModel::SNAPSHOT_FORMAT_JPEG; + return LLSnapshotModel::SNAPSHOT_FORMAT_JPEG; } -void LLPanelSnapshot::enableControls(BOOL enable) +void LLPanelSnapshot::enableControls(bool enable) { - setCtrlsEnabled(enable); + setCtrlsEnabled(enable); } LLSpinCtrl* LLPanelSnapshot::getWidthSpinner() { llassert(!getWidthSpinnerName().empty()); - return getChild<LLSpinCtrl>(getWidthSpinnerName()); + return getChild<LLSpinCtrl>(getWidthSpinnerName()); } LLSpinCtrl* LLPanelSnapshot::getHeightSpinner() { llassert(!getHeightSpinnerName().empty()); - return getChild<LLSpinCtrl>(getHeightSpinnerName()); + return getChild<LLSpinCtrl>(getHeightSpinnerName()); } S32 LLPanelSnapshot::getTypedPreviewWidth() const { llassert(!getWidthSpinnerName().empty()); - return getChild<LLUICtrl>(getWidthSpinnerName())->getValue().asInteger(); + return getChild<LLUICtrl>(getWidthSpinnerName())->getValue().asInteger(); } S32 LLPanelSnapshot::getTypedPreviewHeight() const @@ -133,7 +135,7 @@ S32 LLPanelSnapshot::getTypedPreviewHeight() const return getChild<LLUICtrl>(getHeightSpinnerName())->getValue().asInteger(); } -void LLPanelSnapshot::enableAspectRatioCheckbox(BOOL enable) +void LLPanelSnapshot::enableAspectRatioCheckbox(bool enable) { llassert(!getAspectRatioCBName().empty()); getChild<LLUICtrl>(getAspectRatioCBName())->setEnabled(enable); @@ -141,96 +143,96 @@ void LLPanelSnapshot::enableAspectRatioCheckbox(BOOL enable) LLSideTrayPanelContainer* LLPanelSnapshot::getParentContainer() { - LLSideTrayPanelContainer* parent = dynamic_cast<LLSideTrayPanelContainer*>(getParent()); - if (!parent) - { - LL_WARNS() << "Cannot find panel container" << LL_ENDL; - return NULL; - } + LLSideTrayPanelContainer* parent = dynamic_cast<LLSideTrayPanelContainer*>(getParent()); + if (!parent) + { + LL_WARNS() << "Cannot find panel container" << LL_ENDL; + return NULL; + } - return parent; + return parent; } void LLPanelSnapshot::updateImageQualityLevel() { - LLSliderCtrl* quality_slider = getChild<LLSliderCtrl>("image_quality_slider"); - S32 quality_val = llfloor((F32) quality_slider->getValue().asReal()); - - std::string quality_lvl; - - if (quality_val < 20) - { - quality_lvl = LLTrans::getString("snapshot_quality_very_low"); - } - else if (quality_val < 40) - { - quality_lvl = LLTrans::getString("snapshot_quality_low"); - } - else if (quality_val < 60) - { - quality_lvl = LLTrans::getString("snapshot_quality_medium"); - } - else if (quality_val < 80) - { - quality_lvl = LLTrans::getString("snapshot_quality_high"); - } - else - { - quality_lvl = LLTrans::getString("snapshot_quality_very_high"); - } - - getChild<LLTextBox>("image_quality_level")->setTextArg("[QLVL]", quality_lvl); + LLSliderCtrl* quality_slider = getChild<LLSliderCtrl>("image_quality_slider"); + S32 quality_val = llfloor((F32) quality_slider->getValue().asReal()); + + std::string quality_lvl; + + if (quality_val < 20) + { + quality_lvl = LLTrans::getString("snapshot_quality_very_low"); + } + else if (quality_val < 40) + { + quality_lvl = LLTrans::getString("snapshot_quality_low"); + } + else if (quality_val < 60) + { + quality_lvl = LLTrans::getString("snapshot_quality_medium"); + } + else if (quality_val < 80) + { + quality_lvl = LLTrans::getString("snapshot_quality_high"); + } + else + { + quality_lvl = LLTrans::getString("snapshot_quality_very_high"); + } + + getChild<LLTextBox>("image_quality_level")->setTextArg("[QLVL]", quality_lvl); } void LLPanelSnapshot::goBack() { - LLSideTrayPanelContainer* parent = getParentContainer(); - if (parent) - { - parent->openPreviousPanel(); - parent->getCurrentPanel()->onOpen(LLSD()); - } + LLSideTrayPanelContainer* parent = getParentContainer(); + if (parent) + { + parent->openPreviousPanel(); + parent->getCurrentPanel()->onOpen(LLSD()); + } } void LLPanelSnapshot::cancel() { - goBack(); + goBack(); getParentByType<LLFloater>()->notify(LLSD().with("set-ready", true)); } void LLPanelSnapshot::onCustomResolutionCommit() { - LLSD info; + LLSD info; std::string widthSpinnerName = getWidthSpinnerName(); std::string heightSpinnerName = getHeightSpinnerName(); llassert(!widthSpinnerName.empty() && !heightSpinnerName.empty()); LLSpinCtrl *widthSpinner = getChild<LLSpinCtrl>(widthSpinnerName); LLSpinCtrl *heightSpinner = getChild<LLSpinCtrl>(heightSpinnerName); - if (getName() == "panel_snapshot_inventory") - { - S32 width = widthSpinner->getValue().asInteger(); - width = power_of_two(width, MAX_TEXTURE_SIZE); - info["w"] = width; - widthSpinner->setIncrement(width >> 1); - widthSpinner->forceSetValue(width); - S32 height = heightSpinner->getValue().asInteger(); - height = power_of_two(height, MAX_TEXTURE_SIZE); - heightSpinner->setIncrement(height >> 1); - heightSpinner->forceSetValue(height); - info["h"] = height; - } - else - { - info["w"] = widthSpinner->getValue().asInteger(); - info["h"] = heightSpinner->getValue().asInteger(); - } + if (getName() == "panel_snapshot_inventory") + { + S32 width = widthSpinner->getValue().asInteger(); + width = power_of_two(width, MAX_TEXTURE_SIZE); + info["w"] = width; + widthSpinner->setIncrement((F32)(width >> 1)); + widthSpinner->forceSetValue(width); + S32 height = heightSpinner->getValue().asInteger(); + height = power_of_two(height, MAX_TEXTURE_SIZE); + heightSpinner->setIncrement((F32)(height >> 1)); + heightSpinner->forceSetValue((F32)height); + info["h"] = height; + } + else + { + info["w"] = widthSpinner->getValue().asInteger(); + info["h"] = heightSpinner->getValue().asInteger(); + } getParentByType<LLFloater>()->notify(LLSD().with("custom-res-change", info)); } void LLPanelSnapshot::onResolutionComboCommit(LLUICtrl* ctrl) { - LLSD info; - info["combo-res-change"]["control-name"] = ctrl->getName(); + LLSD info; + info["combo-res-change"]["control-name"] = ctrl->getName(); getParentByType<LLFloater>()->notify(info); } @@ -241,5 +243,5 @@ void LLPanelSnapshot::onKeepAspectRatioCommit(LLUICtrl* ctrl) LLSnapshotModel::ESnapshotType LLPanelSnapshot::getSnapshotType() { - return LLSnapshotModel::SNAPSHOT_WEB; + return LLSnapshotModel::SNAPSHOT_WEB; } |