aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/newview/llmediaremotectrl.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'linden/indra/newview/llmediaremotectrl.cpp')
-rw-r--r--linden/indra/newview/llmediaremotectrl.cpp112
1 files changed, 79 insertions, 33 deletions
diff --git a/linden/indra/newview/llmediaremotectrl.cpp b/linden/indra/newview/llmediaremotectrl.cpp
index b37e5e8..777cbc4 100644
--- a/linden/indra/newview/llmediaremotectrl.cpp
+++ b/linden/indra/newview/llmediaremotectrl.cpp
@@ -12,12 +12,12 @@
12 * ("GPL"), unless you have obtained a separate licensing agreement 12 * ("GPL"), unless you have obtained a separate licensing agreement
13 * ("Other License"), formally executed by you and Linden Lab. Terms of 13 * ("Other License"), formally executed by you and Linden Lab. Terms of
14 * the GPL can be found in doc/GPL-license.txt in this distribution, or 14 * the GPL can be found in doc/GPL-license.txt in this distribution, or
15 * online at http://secondlife.com/developers/opensource/gplv2 15 * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2
16 * 16 *
17 * There are special exceptions to the terms and conditions of the GPL as 17 * There are special exceptions to the terms and conditions of the GPL as
18 * it is applied to this Source Code. View the full text of the exception 18 * it is applied to this Source Code. View the full text of the exception
19 * in the file doc/FLOSS-exception.txt in this software distribution, or 19 * in the file doc/FLOSS-exception.txt in this software distribution, or
20 * online at http://secondlife.com/developers/opensource/flossexception 20 * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception
21 * 21 *
22 * By copying, modifying or distributing this software, you acknowledge 22 * By copying, modifying or distributing this software, you acknowledge
23 * that you have read and understood your obligations described above, 23 * that you have read and understood your obligations described above,
@@ -36,63 +36,109 @@
36#include "lloverlaybar.h" 36#include "lloverlaybar.h"
37#include "llvieweruictrlfactory.h" 37#include "llvieweruictrlfactory.h"
38#include "llpanelaudiovolume.h" 38#include "llpanelaudiovolume.h"
39#include "llviewercontrol.h"
40#include "llbutton.h"
39 41
40//////////////////////////////////////////////////////////////////////////////// 42////////////////////////////////////////////////////////////////////////////////
41// 43//
42// 44//
43LLMediaRemoteCtrl::LLMediaRemoteCtrl ( const LLString& name, 45LLMediaRemoteCtrl::LLMediaRemoteCtrl()
44 const LLString& label,
45 const LLRect& rect,
46 const LLString& xml_file ) :
47 LLPanel ( name, rect, FALSE )
48{ 46{
49 setIsChrome(TRUE); 47 setIsChrome(TRUE);
48 mIsFocusRoot = TRUE;
50 49
51 gUICtrlFactory->buildPanel(this, xml_file); 50 mFactoryMap["Volume Panel"] = LLCallbackMap(createVolumePanel, NULL);
51 build();
52}
52 53
53 mIsFocusRoot = TRUE; 54void LLMediaRemoteCtrl::build()
55{
56 //HACK: only works because we don't have any implicit children (i.e. titlebars, close button, etc)
57 deleteAllChildren();
58 if (gSavedSettings.getBOOL("ShowVolumeSettingsPopup"))
59 {
60 gUICtrlFactory->buildPanel(this, "panel_media_remote_expanded.xml", &getFactoryMap());
61 }
62 else
63 {
64 gUICtrlFactory->buildPanel(this, "panel_media_remote.xml", &getFactoryMap());
65 }
54} 66}
55 67
56BOOL LLMediaRemoteCtrl::postBuild() 68BOOL LLMediaRemoteCtrl::postBuild()
57{ 69{
58 childSetAction("media_play",LLOverlayBar::mediaPlay,this); 70 childSetAction("media_play",LLOverlayBar::mediaPlay,this);
59 childSetAction("media_stop",LLOverlayBar::mediaStop,this);
60 childSetAction("media_pause",LLOverlayBar::mediaPause,this);
61
62 childSetAction("music_play",LLOverlayBar::musicPlay,this); 71 childSetAction("music_play",LLOverlayBar::musicPlay,this);
63 childSetAction("music_stop",LLOverlayBar::musicStop,this);
64 childSetAction("music_pause",LLOverlayBar::musicPause,this);
65 72
66 childSetAction("volume",LLOverlayBar::toggleAudioVolumeFloater,this); 73 childSetAction("expand", onClickExpandBtn, this);
67
68 return TRUE; 74 return TRUE;
69} 75}
70 76
71LLMediaRemoteCtrl::~LLMediaRemoteCtrl () 77void LLMediaRemoteCtrl::draw()
72{ 78{
79 LLButton* music_play_btn = LLUICtrlFactory::getButtonByName(this, "music_play");
80 if (music_play_btn)
81 {
82 if (gOverlayBar->musicPlaying())
83 {
84 music_play_btn->setValue(TRUE);
85 music_play_btn->setImageOverlay("icn_music-pause.tga");
86 }
87 else
88 {
89 music_play_btn->setValue(FALSE);
90 music_play_btn->setImageOverlay("icn_music-play.tga");
91 }
92 }
93
94 LLButton* media_play_btn = LLUICtrlFactory::getButtonByName(this, "media_play");
95 if (media_play_btn)
96 {
97 if (gOverlayBar->mediaPlaying())
98 {
99 media_play_btn->setValue(TRUE);
100 media_play_btn->setImageOverlay("icn_media-pause.tga");
101 }
102 else
103 {
104 media_play_btn->setValue(FALSE);
105 media_play_btn->setImageOverlay("icn_media-play.tga");
106 }
107 }
108
109 LLButton* expand_button = LLUICtrlFactory::getButtonByName(this, "expand");
110 if (expand_button)
111 {
112 if (expand_button->getToggleState())
113 {
114 expand_button->setImageOverlay("arrow_down.tga");
115 }
116 else
117 {
118 expand_button->setImageOverlay("arrow_up.tga");
119 }
120 }
121
122 LLPanel::draw();
73} 123}
74 124
75//////////////////////////////////////////////////////////////////////////////// 125LLMediaRemoteCtrl::~LLMediaRemoteCtrl ()
76//
77//
78EWidgetType LLMediaRemoteCtrl::getWidgetType() const
79{ 126{
80 return WIDGET_TYPE_MEDIA_REMOTE;
81} 127}
82 128
83LLString LLMediaRemoteCtrl::getWidgetTag() const 129//static
130void LLMediaRemoteCtrl::onClickExpandBtn(void* user_data)
84{ 131{
85 return LL_MEDIA_REMOTE_CTRL_TAG; 132 LLMediaRemoteCtrl* remotep = (LLMediaRemoteCtrl*)user_data;
133
134 remotep->build();
135 gOverlayBar->layoutButtons();
136
86} 137}
87 138
88//////////////////////////////////////////////////////////////////////////////// 139//static
89// 140void* LLMediaRemoteCtrl::createVolumePanel(void* data)
90//
91void LLMediaRemoteCtrl::draw()
92{ 141{
93 LLOverlayBar::enableMusicButtons(this); 142 LLPanelAudioVolume* panel = new LLPanelAudioVolume();
94 LLOverlayBar::enableMediaButtons(this); 143 return panel;
95 LLPanel::draw();
96 // make volume button reflect of volume floater
97 childSetValue("volume", LLFloaterAudioVolume::instanceVisible(LLSD()));
98} 144}