diff options
Diffstat (limited to 'indra')
| -rw-r--r-- | indra/newview/llbottomtray.cpp | 36 | ||||
| -rw-r--r-- | indra/newview/llbottomtray.h | 7 | ||||
| -rw-r--r-- | indra/newview/llnearbychatbar.cpp | 30 | ||||
| -rw-r--r-- | indra/newview/llnearbychatbar.h | 10 | ||||
| -rw-r--r-- | indra/newview/llspeakbutton.cpp | 10 | ||||
| -rw-r--r-- | indra/newview/llspeakbutton.h | 5 | ||||
| -rw-r--r-- | indra/newview/skins/default/xui/en/panel_bottomtray.xml | 6 | 
7 files changed, 60 insertions, 44 deletions
| diff --git a/indra/newview/llbottomtray.cpp b/indra/newview/llbottomtray.cpp index 832694873f..9ea8b53d3d 100644 --- a/indra/newview/llbottomtray.cpp +++ b/indra/newview/llbottomtray.cpp @@ -40,6 +40,7 @@  #include "llimfloater.h" // for LLIMFloater  #include "lllayoutstack.h"  #include "llnearbychatbar.h" +#include "llspeakbutton.h"  #include "llsplitbutton.h"  #include "llsyswellwindow.h"  #include "llfloatercamera.h" @@ -181,6 +182,28 @@ void LLBottomTray::sessionIDUpdated(const LLUUID& old_session_id, const LLUUID&  	}  } +// virtual +void LLBottomTray::onChange(EStatusType status, const std::string &channelURI, bool proximal) +{ +	// Time it takes to connect to voice channel might be pretty long, +	// so don't expect user login or STATUS_VOICE_ENABLED to be followed by STATUS_JOINED. +	BOOL enable = FALSE; + +	switch (status) +	{ +	// Do not add STATUS_VOICE_ENABLED because voice chat is  +	// inactive until STATUS_JOINED +	case STATUS_JOINED: +		enable = TRUE; +		break; +	default: +		enable = FALSE; +		break; +	} + +	mSpeakBtn->setEnabled(enable); +} +  //virtual  void LLBottomTray::onFocusLost()  { @@ -275,6 +298,19 @@ BOOL LLBottomTray::postBuild()  	mSnapshotPanel = getChild<LLPanel>("snapshot_panel");  	setRightMouseDownCallback(boost::bind(&LLBottomTray::showBottomTrayContextMenu,this, _2, _3,_4)); +	mSpeakBtn = getChild<LLSpeakButton>("talk"); + +	// Speak button should be initially disabled because +	// it takes some time between logging in to world and connecting to voice channel. +	mSpeakBtn->setEnabled(FALSE); + +	// Localization tool doesn't understand custom buttons like <talk_button> +	mSpeakBtn->setSpeakToolTip( getString("SpeakBtnToolTip") ); +	mSpeakBtn->setShowToolTip( getString("VoiceControlBtnToolTip") ); + +	// Registering Chat Bar to receive Voice client status change notifications. +	gVoiceClient->addObserver(this); +  	if (mChicletPanel && mToolbarStack && mNearbyChatBar)  	{  		verifyChildControlsSizes(); diff --git a/indra/newview/llbottomtray.h b/indra/newview/llbottomtray.h index 02588a1975..3f6d0756de 100644 --- a/indra/newview/llbottomtray.h +++ b/indra/newview/llbottomtray.h @@ -33,7 +33,7 @@  #ifndef LL_LLBOTTOMPANEL_H  #define LL_LLBOTTOMPANEL_H -#include <llmenugl.h> +#include "llmenugl.h"  #include "llpanel.h"  #include "llimview.h" @@ -51,6 +51,7 @@ class LLBottomTray  	: public LLSingleton<LLBottomTray>  	, public LLPanel  	, public LLIMSessionObserver +	, public LLVoiceClientStatusObserver  {  	friend class LLSingleton<LLBottomTray>;  public: @@ -74,6 +75,10 @@ public:  	virtual void onFocusLost();  	virtual void setVisible(BOOL visible); +	// Implements LLVoiceClientStatusObserver::onChange() to enable the speak +	// button when voice is available +	/*virtual*/ void onChange(EStatusType status, const std::string &channelURI, bool proximal); +  	void showBottomTrayContextMenu(S32 x, S32 y, MASK mask);  	void showGestureButton(BOOL visible); diff --git a/indra/newview/llnearbychatbar.cpp b/indra/newview/llnearbychatbar.cpp index d54545971b..dfeade2e4d 100644 --- a/indra/newview/llnearbychatbar.cpp +++ b/indra/newview/llnearbychatbar.cpp @@ -36,7 +36,6 @@  #include "lltrans.h"  #include "llnearbychatbar.h" -#include "llspeakbutton.h"  #include "llbottomtray.h"  #include "llagent.h"  #include "llgesturemgr.h" @@ -234,14 +233,6 @@ BOOL LLNearbyChatBar::postBuild()  	mOutputMonitor = getChild<LLOutputMonitorCtrl>("chat_zone_indicator");  	mOutputMonitor->setVisible(FALSE); -	mSpeakBtn = getParent()->getChild<LLSpeakButton>("talk"); - -	// Speak button should be initially disabled because -	// it takes some time between logging in to world and connecting to voice channel. -	mSpeakBtn->setEnabled(FALSE); - -	// Registering Chat Bar to receive Voice client status change notifications. -	gVoiceClient->addObserver(this);  	return TRUE;  } @@ -730,27 +721,6 @@ public:  	}  }; -void LLNearbyChatBar::onChange(EStatusType status, const std::string &channelURI, bool proximal) -{ -	// Time it takes to connect to voice channel might be pretty long, -	// so don't expect user login or STATUS_VOICE_ENABLED to be followed by STATUS_JOINED. -	BOOL enable = FALSE; - -	switch (status) -	{ -	// Do not add STATUS_VOICE_ENABLED because voice chat is  -	// inactive until STATUS_JOINED -	case STATUS_JOINED: -		enable = TRUE; -		break; -	default: -		enable = FALSE; -		break; -	} - -	mSpeakBtn->setEnabled(enable); -} -  // Creating the object registers with the dispatcher.  LLChatHandler gChatHandler; diff --git a/indra/newview/llnearbychatbar.h b/indra/newview/llnearbychatbar.h index 56ee706a97..224118e088 100644 --- a/indra/newview/llnearbychatbar.h +++ b/indra/newview/llnearbychatbar.h @@ -42,9 +42,6 @@  #include "llspeakers.h" -class LLSpeakButton; - -  class LLGestureComboBox  	: public LLComboBox  	, public LLGestureManagerObserver @@ -76,7 +73,6 @@ protected:  class LLNearbyChatBar  :	public LLPanel -,   public LLVoiceClientStatusObserver  {  public:  	// constructor for inline chat-bars (e.g. hosted in chat history window) @@ -105,11 +101,6 @@ public:  	S32 getMinWidth() const;  	S32 getMaxWidth() const; -	/** -	 * Implements LLVoiceClientStatusObserver::onChange() -	 */ -	/*virtual*/ void onChange(EStatusType status, const std::string &channelURI, bool proximal); -  protected:  	static BOOL matchChatTypeTrigger(const std::string& in_str, std::string* out_str);  	static void onChatBoxKeystroke(LLLineEditor* caller, void* userdata); @@ -127,7 +118,6 @@ protected:  	static S32 sLastSpecialChatChannel;  	LLLineEditor*		mChatBox; -	LLSpeakButton*		mSpeakBtn;  	LLOutputMonitorCtrl* mOutputMonitor;  	LLLocalSpeakerMgr*  mSpeakerMgr;  }; diff --git a/indra/newview/llspeakbutton.cpp b/indra/newview/llspeakbutton.cpp index 57ea018f25..51d53b2674 100644 --- a/indra/newview/llspeakbutton.cpp +++ b/indra/newview/llspeakbutton.cpp @@ -133,6 +133,16 @@ LLSpeakButton::~LLSpeakButton()  	LLTransientFloaterMgr::getInstance()->removeControlView(mShowBtn);  } +void LLSpeakButton::setSpeakToolTip(const std::string& msg) +{ +	mSpeakBtn->setToolTip(msg); +} + +void LLSpeakButton::setShowToolTip(const std::string& msg) +{ +	mShowBtn->setToolTip(msg); +} +  void LLSpeakButton::onMouseDown_SpeakBtn()  {  	bool down = true; diff --git a/indra/newview/llspeakbutton.h b/indra/newview/llspeakbutton.h index e213c562dd..02c8ab3890 100644 --- a/indra/newview/llspeakbutton.h +++ b/indra/newview/llspeakbutton.h @@ -62,6 +62,11 @@ public:  	/*virtual*/ ~LLSpeakButton();  	/*virtual*/ void draw(); +	// *HACK: Need to put tooltips in a translatable location, +	// the panel that contains this button. +	void setSpeakToolTip(const std::string& msg); +	void setShowToolTip(const std::string& msg); +  protected:  	friend class LLUICtrlFactory;  	LLSpeakButton(const Params& p); diff --git a/indra/newview/skins/default/xui/en/panel_bottomtray.xml b/indra/newview/skins/default/xui/en/panel_bottomtray.xml index 3fbc8e1afd..e96d3a152f 100644 --- a/indra/newview/skins/default/xui/en/panel_bottomtray.xml +++ b/indra/newview/skins/default/xui/en/panel_bottomtray.xml @@ -13,6 +13,8 @@   chrome="true"   border_visible="false"   width="1000"> +  <string name="SpeakBtnToolTip">Turns microphone on/off</string> +  <string name="VoiceControlBtnToolTip">Shows/hides voice control panel</string>      <layout_stack       mouse_opaque="false"       border_size="0" @@ -70,9 +72,7 @@             left="0"             name="talk"             top="3" -          width="100" -          speak_button.tool_tip="Turns microphone on/off" -          show_button.tool_tip="Shows/hides voice control panel" /> +          width="100" />          </layout_panel>          <icon              auto_resize="false" | 
