summaryrefslogtreecommitdiff
path: root/indra/newview/llpanellandmedia.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'indra/newview/llpanellandmedia.cpp')
-rw-r--r--indra/newview/llpanellandmedia.cpp416
1 files changed, 208 insertions, 208 deletions
diff --git a/indra/newview/llpanellandmedia.cpp b/indra/newview/llpanellandmedia.cpp
index ca252d1455..9aff1661ff 100644
--- a/indra/newview/llpanellandmedia.cpp
+++ b/indra/newview/llpanellandmedia.cpp
@@ -6,21 +6,21 @@
* $LicenseInfo:firstyear=2007&license=viewerlgpl$
* Second Life Viewer Source Code
* Copyright (C) 2010, 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$
*/
@@ -57,18 +57,18 @@
//---------------------------------------------------------------------------
LLPanelLandMedia::LLPanelLandMedia(LLParcelSelectionHandle& parcel)
-: LLPanel(),
- mParcel(parcel),
- mMediaURLEdit(NULL),
- mMediaDescEdit(NULL),
- mMediaTypeCombo(NULL),
- mSetURLButton(NULL),
- mMediaHeightCtrl(NULL),
- mMediaWidthCtrl(NULL),
- mMediaSizeCtrlLabel(NULL),
- mMediaTextureCtrl(NULL),
- mMediaAutoScaleCheck(NULL),
- mMediaLoopCheck(NULL)
+: LLPanel(),
+ mParcel(parcel),
+ mMediaURLEdit(NULL),
+ mMediaDescEdit(NULL),
+ mMediaTypeCombo(NULL),
+ mSetURLButton(NULL),
+ mMediaHeightCtrl(NULL),
+ mMediaWidthCtrl(NULL),
+ mMediaSizeCtrlLabel(NULL),
+ mMediaTextureCtrl(NULL),
+ mMediaAutoScaleCheck(NULL),
+ mMediaLoopCheck(NULL)
{
}
@@ -81,249 +81,249 @@ LLPanelLandMedia::~LLPanelLandMedia()
BOOL LLPanelLandMedia::postBuild()
{
- mMediaTextureCtrl = getChild<LLTextureCtrl>("media texture");
- mMediaTextureCtrl->setCommitCallback( onCommitAny, this );
- mMediaTextureCtrl->setAllowNoTexture ( TRUE );
- mMediaTextureCtrl->setImmediateFilterPermMask(PERM_COPY | PERM_TRANSFER);
- mMediaTextureCtrl->setDnDFilterPermMask(PERM_COPY | PERM_TRANSFER);
+ mMediaTextureCtrl = getChild<LLTextureCtrl>("media texture");
+ mMediaTextureCtrl->setCommitCallback( onCommitAny, this );
+ mMediaTextureCtrl->setAllowNoTexture ( TRUE );
+ mMediaTextureCtrl->setImmediateFilterPermMask(PERM_COPY | PERM_TRANSFER);
+ mMediaTextureCtrl->setDnDFilterPermMask(PERM_COPY | PERM_TRANSFER);
- mMediaAutoScaleCheck = getChild<LLCheckBoxCtrl>("media_auto_scale");
- childSetCommitCallback("media_auto_scale", onCommitAny, this);
+ mMediaAutoScaleCheck = getChild<LLCheckBoxCtrl>("media_auto_scale");
+ childSetCommitCallback("media_auto_scale", onCommitAny, this);
- mMediaLoopCheck = getChild<LLCheckBoxCtrl>("media_loop");
- childSetCommitCallback("media_loop", onCommitAny, this );
+ mMediaLoopCheck = getChild<LLCheckBoxCtrl>("media_loop");
+ childSetCommitCallback("media_loop", onCommitAny, this );
- mMediaURLEdit = getChild<LLLineEditor>("media_url");
- childSetCommitCallback("media_url", onCommitAny, this );
+ mMediaURLEdit = getChild<LLLineEditor>("media_url");
+ childSetCommitCallback("media_url", onCommitAny, this );
- mMediaDescEdit = getChild<LLLineEditor>("url_description");
- childSetCommitCallback("url_description", onCommitAny, this);
+ mMediaDescEdit = getChild<LLLineEditor>("url_description");
+ childSetCommitCallback("url_description", onCommitAny, this);
- mMediaTypeCombo = getChild<LLComboBox>("media type");
- childSetCommitCallback("media type", onCommitType, this);
- populateMIMECombo();
+ mMediaTypeCombo = getChild<LLComboBox>("media type");
+ childSetCommitCallback("media type", onCommitType, this);
+ populateMIMECombo();
- mMediaWidthCtrl = getChild<LLSpinCtrl>("media_size_width");
- childSetCommitCallback("media_size_width", onCommitAny, this);
- mMediaHeightCtrl = getChild<LLSpinCtrl>("media_size_height");
- childSetCommitCallback("media_size_height", onCommitAny, this);
- mMediaSizeCtrlLabel = getChild<LLTextBox>("media_size");
+ mMediaWidthCtrl = getChild<LLSpinCtrl>("media_size_width");
+ childSetCommitCallback("media_size_width", onCommitAny, this);
+ mMediaHeightCtrl = getChild<LLSpinCtrl>("media_size_height");
+ childSetCommitCallback("media_size_height", onCommitAny, this);
+ mMediaSizeCtrlLabel = getChild<LLTextBox>("media_size");
- mSetURLButton = getChild<LLButton>("set_media_url");
- childSetAction("set_media_url", onSetBtn, this);
+ mSetURLButton = getChild<LLButton>("set_media_url");
+ childSetAction("set_media_url", onSetBtn, this);
- return TRUE;
+ return TRUE;
}
// public
void LLPanelLandMedia::refresh()
{
- LLParcel *parcel = mParcel->getParcel();
-
- if (!parcel)
- {
- clearCtrls();
- }
- else
- {
- // something selected, hooray!
-
- // Display options
- BOOL can_change_media = LLViewerParcelMgr::isParcelModifiableByAgent(parcel, GP_LAND_CHANGE_MEDIA);
-
- mMediaURLEdit->setText(parcel->getMediaURL());
- mMediaURLEdit->setEnabled( FALSE );
-
- getChild<LLUICtrl>("current_url")->setValue(parcel->getMediaCurrentURL());
-
- mMediaDescEdit->setText(parcel->getMediaDesc());
- mMediaDescEdit->setEnabled( can_change_media );
-
- std::string mime_type = parcel->getMediaType();
- if (mime_type.empty() || mime_type == LLMIMETypes::getDefaultMimeType())
- {
- mime_type = LLMIMETypes::getDefaultMimeTypeTranslation();
- }
- setMediaType(mime_type);
- mMediaTypeCombo->setEnabled( can_change_media );
- getChild<LLUICtrl>("mime_type")->setValue(mime_type);
-
- mMediaAutoScaleCheck->set( parcel->getMediaAutoScale () );
- mMediaAutoScaleCheck->setEnabled ( can_change_media );
-
- // Special code to disable looping checkbox for HTML MIME type
- // (DEV-10042 -- Parcel Media: "Loop Media" should be disabled for static media types)
- bool allow_looping = LLMIMETypes::findAllowLooping( mime_type );
- if ( allow_looping )
- mMediaLoopCheck->set( parcel->getMediaLoop () );
- else
- mMediaLoopCheck->set( false );
- mMediaLoopCheck->setEnabled ( can_change_media && allow_looping );
-
- // disallow media size change for mime types that don't allow it
- bool allow_resize = LLMIMETypes::findAllowResize( mime_type );
- if ( allow_resize )
- mMediaWidthCtrl->setValue( parcel->getMediaWidth() );
- else
- mMediaWidthCtrl->setValue( 0 );
- mMediaWidthCtrl->setEnabled ( can_change_media && allow_resize );
-
- if ( allow_resize )
- mMediaHeightCtrl->setValue( parcel->getMediaHeight() );
- else
- mMediaHeightCtrl->setValue( 0 );
- mMediaHeightCtrl->setEnabled ( can_change_media && allow_resize );
-
- // enable/disable for text label for completeness
- mMediaSizeCtrlLabel->setEnabled( can_change_media && allow_resize );
-
- mMediaTextureCtrl->setImageAssetID ( parcel->getMediaID() );
- mMediaTextureCtrl->setEnabled( can_change_media );
-
- mSetURLButton->setEnabled( can_change_media );
-
- }
+ LLParcel *parcel = mParcel->getParcel();
+
+ if (!parcel)
+ {
+ clearCtrls();
+ }
+ else
+ {
+ // something selected, hooray!
+
+ // Display options
+ BOOL can_change_media = LLViewerParcelMgr::isParcelModifiableByAgent(parcel, GP_LAND_CHANGE_MEDIA);
+
+ mMediaURLEdit->setText(parcel->getMediaURL());
+ mMediaURLEdit->setEnabled( FALSE );
+
+ getChild<LLUICtrl>("current_url")->setValue(parcel->getMediaCurrentURL());
+
+ mMediaDescEdit->setText(parcel->getMediaDesc());
+ mMediaDescEdit->setEnabled( can_change_media );
+
+ std::string mime_type = parcel->getMediaType();
+ if (mime_type.empty() || mime_type == LLMIMETypes::getDefaultMimeType())
+ {
+ mime_type = LLMIMETypes::getDefaultMimeTypeTranslation();
+ }
+ setMediaType(mime_type);
+ mMediaTypeCombo->setEnabled( can_change_media );
+ getChild<LLUICtrl>("mime_type")->setValue(mime_type);
+
+ mMediaAutoScaleCheck->set( parcel->getMediaAutoScale () );
+ mMediaAutoScaleCheck->setEnabled ( can_change_media );
+
+ // Special code to disable looping checkbox for HTML MIME type
+ // (DEV-10042 -- Parcel Media: "Loop Media" should be disabled for static media types)
+ bool allow_looping = LLMIMETypes::findAllowLooping( mime_type );
+ if ( allow_looping )
+ mMediaLoopCheck->set( parcel->getMediaLoop () );
+ else
+ mMediaLoopCheck->set( false );
+ mMediaLoopCheck->setEnabled ( can_change_media && allow_looping );
+
+ // disallow media size change for mime types that don't allow it
+ bool allow_resize = LLMIMETypes::findAllowResize( mime_type );
+ if ( allow_resize )
+ mMediaWidthCtrl->setValue( parcel->getMediaWidth() );
+ else
+ mMediaWidthCtrl->setValue( 0 );
+ mMediaWidthCtrl->setEnabled ( can_change_media && allow_resize );
+
+ if ( allow_resize )
+ mMediaHeightCtrl->setValue( parcel->getMediaHeight() );
+ else
+ mMediaHeightCtrl->setValue( 0 );
+ mMediaHeightCtrl->setEnabled ( can_change_media && allow_resize );
+
+ // enable/disable for text label for completeness
+ mMediaSizeCtrlLabel->setEnabled( can_change_media && allow_resize );
+
+ mMediaTextureCtrl->setImageAssetID ( parcel->getMediaID() );
+ mMediaTextureCtrl->setEnabled( can_change_media );
+
+ mSetURLButton->setEnabled( can_change_media );
+
+ }
}
void LLPanelLandMedia::populateMIMECombo()
{
- std::string default_mime_type = LLMIMETypes::getDefaultMimeType();
- std::string default_label;
- LLMIMETypes::mime_widget_set_map_t::const_iterator it;
- for (it = LLMIMETypes::sWidgetMap.begin(); it != LLMIMETypes::sWidgetMap.end(); ++it)
- {
- const std::string& mime_type = it->first;
- const LLMIMETypes::LLMIMEWidgetSet& info = it->second;
- if (info.mDefaultMimeType == default_mime_type)
- {
- // Add this label at the end to make UI look cleaner
- default_label = info.mLabel;
- }
- else
- {
- mMediaTypeCombo->add(info.mLabel, mime_type);
- }
- }
-
- mMediaTypeCombo->add( default_label, default_mime_type, ADD_BOTTOM );
+ std::string default_mime_type = LLMIMETypes::getDefaultMimeType();
+ std::string default_label;
+ LLMIMETypes::mime_widget_set_map_t::const_iterator it;
+ for (it = LLMIMETypes::sWidgetMap.begin(); it != LLMIMETypes::sWidgetMap.end(); ++it)
+ {
+ const std::string& mime_type = it->first;
+ const LLMIMETypes::LLMIMEWidgetSet& info = it->second;
+ if (info.mDefaultMimeType == default_mime_type)
+ {
+ // Add this label at the end to make UI look cleaner
+ default_label = info.mLabel;
+ }
+ else
+ {
+ mMediaTypeCombo->add(info.mLabel, mime_type);
+ }
+ }
+
+ mMediaTypeCombo->add( default_label, default_mime_type, ADD_BOTTOM );
}
void LLPanelLandMedia::setMediaType(const std::string& mime_type)
{
- LLParcel *parcel = mParcel->getParcel();
- if(parcel)
- parcel->setMediaType(mime_type);
-
- std::string media_key = LLMIMETypes::widgetType(mime_type);
- mMediaTypeCombo->setValue(media_key);
-
- std::string mime_str = mime_type;
- if(LLMIMETypes::getDefaultMimeType() == mime_type)
- {
- // Instead of showing predefined "none/none" we are going to show something
- // localizable - "none" for example (see EXT-6542)
- mime_str = LLMIMETypes::getDefaultMimeTypeTranslation();
- }
- getChild<LLUICtrl>("mime_type")->setValue(mime_str);
+ LLParcel *parcel = mParcel->getParcel();
+ if(parcel)
+ parcel->setMediaType(mime_type);
+
+ std::string media_key = LLMIMETypes::widgetType(mime_type);
+ mMediaTypeCombo->setValue(media_key);
+
+ std::string mime_str = mime_type;
+ if(LLMIMETypes::getDefaultMimeType() == mime_type)
+ {
+ // Instead of showing predefined "none/none" we are going to show something
+ // localizable - "none" for example (see EXT-6542)
+ mime_str = LLMIMETypes::getDefaultMimeTypeTranslation();
+ }
+ getChild<LLUICtrl>("mime_type")->setValue(mime_str);
}
void LLPanelLandMedia::setMediaURL(const std::string& media_url)
{
- mMediaURLEdit->setText(media_url);
- LLParcel *parcel = mParcel->getParcel();
- if(parcel)
- parcel->setMediaCurrentURL(media_url);
- // LLViewerMedia::navigateHome();
+ mMediaURLEdit->setText(media_url);
+ LLParcel *parcel = mParcel->getParcel();
+ if(parcel)
+ parcel->setMediaCurrentURL(media_url);
+ // LLViewerMedia::navigateHome();
- mMediaURLEdit->onCommit();
- // LLViewerParcelMedia::sendMediaNavigateMessage(media_url);
- getChild<LLUICtrl>("current_url")->setValue(media_url);
+ mMediaURLEdit->onCommit();
+ // LLViewerParcelMedia::sendMediaNavigateMessage(media_url);
+ getChild<LLUICtrl>("current_url")->setValue(media_url);
}
std::string LLPanelLandMedia::getMediaURL()
{
- return mMediaURLEdit->getText();
+ return mMediaURLEdit->getText();
}
// static
void LLPanelLandMedia::onCommitType(LLUICtrl *ctrl, void *userdata)
{
- LLPanelLandMedia *self = (LLPanelLandMedia *)userdata;
- std::string current_type = LLMIMETypes::widgetType(self->getChild<LLUICtrl>("mime_type")->getValue().asString());
- std::string new_type = self->mMediaTypeCombo->getValue();
- if(current_type != new_type)
- {
- self->getChild<LLUICtrl>("mime_type")->setValue(LLMIMETypes::findDefaultMimeType(new_type));
- }
- onCommitAny(ctrl, userdata);
+ LLPanelLandMedia *self = (LLPanelLandMedia *)userdata;
+ std::string current_type = LLMIMETypes::widgetType(self->getChild<LLUICtrl>("mime_type")->getValue().asString());
+ std::string new_type = self->mMediaTypeCombo->getValue();
+ if(current_type != new_type)
+ {
+ self->getChild<LLUICtrl>("mime_type")->setValue(LLMIMETypes::findDefaultMimeType(new_type));
+ }
+ onCommitAny(ctrl, userdata);
}
// static
void LLPanelLandMedia::onCommitAny(LLUICtrl*, void *userdata)
{
- LLPanelLandMedia *self = (LLPanelLandMedia *)userdata;
-
- LLParcel* parcel = self->mParcel->getParcel();
- if (!parcel)
- {
- return;
- }
-
- // Extract data from UI
- std::string media_url = self->mMediaURLEdit->getText();
- std::string media_desc = self->mMediaDescEdit->getText();
- std::string mime_type = self->getChild<LLUICtrl>("mime_type")->getValue().asString();
- U8 media_auto_scale = self->mMediaAutoScaleCheck->get();
- U8 media_loop = self->mMediaLoopCheck->get();
- S32 media_width = (S32)self->mMediaWidthCtrl->get();
- S32 media_height = (S32)self->mMediaHeightCtrl->get();
- LLUUID media_id = self->mMediaTextureCtrl->getImageAssetID();
-
-
- self->getChild<LLUICtrl>("mime_type")->setValue(mime_type);
-
- // Remove leading/trailing whitespace (common when copying/pasting)
- LLStringUtil::trim(media_url);
-
- // Push data into current parcel
- parcel->setMediaURL(media_url);
- parcel->setMediaType(mime_type);
- parcel->setMediaDesc(media_desc);
- parcel->setMediaWidth(media_width);
- parcel->setMediaHeight(media_height);
- parcel->setMediaID(media_id);
- parcel->setMediaAutoScale ( media_auto_scale );
- parcel->setMediaLoop ( media_loop );
-
- // Send current parcel data upstream to server
- LLViewerParcelMgr::getInstance()->sendParcelPropertiesUpdate( parcel );
-
- // Might have changed properties, so let's redraw!
- self->refresh();
+ LLPanelLandMedia *self = (LLPanelLandMedia *)userdata;
+
+ LLParcel* parcel = self->mParcel->getParcel();
+ if (!parcel)
+ {
+ return;
+ }
+
+ // Extract data from UI
+ std::string media_url = self->mMediaURLEdit->getText();
+ std::string media_desc = self->mMediaDescEdit->getText();
+ std::string mime_type = self->getChild<LLUICtrl>("mime_type")->getValue().asString();
+ U8 media_auto_scale = self->mMediaAutoScaleCheck->get();
+ U8 media_loop = self->mMediaLoopCheck->get();
+ S32 media_width = (S32)self->mMediaWidthCtrl->get();
+ S32 media_height = (S32)self->mMediaHeightCtrl->get();
+ LLUUID media_id = self->mMediaTextureCtrl->getImageAssetID();
+
+
+ self->getChild<LLUICtrl>("mime_type")->setValue(mime_type);
+
+ // Remove leading/trailing whitespace (common when copying/pasting)
+ LLStringUtil::trim(media_url);
+
+ // Push data into current parcel
+ parcel->setMediaURL(media_url);
+ parcel->setMediaType(mime_type);
+ parcel->setMediaDesc(media_desc);
+ parcel->setMediaWidth(media_width);
+ parcel->setMediaHeight(media_height);
+ parcel->setMediaID(media_id);
+ parcel->setMediaAutoScale ( media_auto_scale );
+ parcel->setMediaLoop ( media_loop );
+
+ // Send current parcel data upstream to server
+ LLViewerParcelMgr::getInstance()->sendParcelPropertiesUpdate( parcel );
+
+ // Might have changed properties, so let's redraw!
+ self->refresh();
}
// static
void LLPanelLandMedia::onSetBtn(void *userdata)
{
- LLPanelLandMedia *self = (LLPanelLandMedia *)userdata;
- self->mURLEntryFloater = LLFloaterURLEntry::show( self->getHandle(), self->getMediaURL() );
- LLFloater* parent_floater = gFloaterView->getParentFloater(self);
- if (parent_floater)
- {
- parent_floater->addDependentFloater(self->mURLEntryFloater.get());
- }
+ LLPanelLandMedia *self = (LLPanelLandMedia *)userdata;
+ self->mURLEntryFloater = LLFloaterURLEntry::show( self->getHandle(), self->getMediaURL() );
+ LLFloater* parent_floater = gFloaterView->getParentFloater(self);
+ if (parent_floater)
+ {
+ parent_floater->addDependentFloater(self->mURLEntryFloater.get());
+ }
}
// static
void LLPanelLandMedia::onResetBtn(void *userdata)
{
- LLPanelLandMedia *self = (LLPanelLandMedia *)userdata;
- LLParcel* parcel = self->mParcel->getParcel();
- // LLViewerMedia::navigateHome();
- self->refresh();
- self->getChild<LLUICtrl>("current_url")->setValue(parcel->getMediaURL());
- // LLViewerParcelMedia::sendMediaNavigateMessage(parcel->getMediaURL());
+ LLPanelLandMedia *self = (LLPanelLandMedia *)userdata;
+ LLParcel* parcel = self->mParcel->getParcel();
+ // LLViewerMedia::navigateHome();
+ self->refresh();
+ self->getChild<LLUICtrl>("current_url")->setValue(parcel->getMediaURL());
+ // LLViewerParcelMedia::sendMediaNavigateMessage(parcel->getMediaURL());
}