aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/newview/llfloateractivespeakers.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'linden/indra/newview/llfloateractivespeakers.cpp')
-rw-r--r--linden/indra/newview/llfloateractivespeakers.cpp41
1 files changed, 29 insertions, 12 deletions
diff --git a/linden/indra/newview/llfloateractivespeakers.cpp b/linden/indra/newview/llfloateractivespeakers.cpp
index be0e88f..0a19fb2 100644
--- a/linden/indra/newview/llfloateractivespeakers.cpp
+++ b/linden/indra/newview/llfloateractivespeakers.cpp
@@ -547,7 +547,8 @@ void LLPanelActiveSpeakers::refreshSpeakers()
547 && gVoiceClient->getVoiceEnabled(selected_id) 547 && gVoiceClient->getVoiceEnabled(selected_id)
548 && selected_id.notNull() 548 && selected_id.notNull()
549 && selected_id != gAgent.getID() 549 && selected_id != gAgent.getID()
550 && (selected_speakerp.notNull() && selected_speakerp->mType == LLSpeaker::SPEAKER_AGENT)); 550 && (selected_speakerp.notNull() && (selected_speakerp->mType == LLSpeaker::SPEAKER_AGENT || selected_speakerp->mType == LLSpeaker::SPEAKER_EXTERNAL)));
551
551 } 552 }
552 if (mMuteTextCtrl) 553 if (mMuteTextCtrl)
553 { 554 {
@@ -555,6 +556,7 @@ void LLPanelActiveSpeakers::refreshSpeakers()
555 mMuteTextCtrl->setEnabled(selected_id.notNull() 556 mMuteTextCtrl->setEnabled(selected_id.notNull()
556 && selected_id != gAgent.getID() 557 && selected_id != gAgent.getID()
557 && selected_speakerp.notNull() 558 && selected_speakerp.notNull()
559 && selected_speakerp->mType != LLSpeaker::SPEAKER_EXTERNAL
558 && !LLMuteList::getInstance()->isLinden(selected_speakerp->mDisplayName)); 560 && !LLMuteList::getInstance()->isLinden(selected_speakerp->mDisplayName));
559 } 561 }
560 childSetValue("speaker_volume", gVoiceClient->getUserVolume(selected_id)); 562 childSetValue("speaker_volume", gVoiceClient->getUserVolume(selected_id));
@@ -562,7 +564,7 @@ void LLPanelActiveSpeakers::refreshSpeakers()
562 && gVoiceClient->getVoiceEnabled(selected_id) 564 && gVoiceClient->getVoiceEnabled(selected_id)
563 && selected_id.notNull() 565 && selected_id.notNull()
564 && selected_id != gAgent.getID() 566 && selected_id != gAgent.getID()
565 && (selected_speakerp.notNull() && selected_speakerp->mType == LLSpeaker::SPEAKER_AGENT)); 567 && (selected_speakerp.notNull() && (selected_speakerp->mType == LLSpeaker::SPEAKER_AGENT || selected_speakerp->mType == LLSpeaker::SPEAKER_EXTERNAL)));
566 568
567 childSetEnabled( 569 childSetEnabled(
568 "moderator_controls_label", 570 "moderator_controls_label",
@@ -580,7 +582,7 @@ void LLPanelActiveSpeakers::refreshSpeakers()
580 582
581 if (mProfileBtn) 583 if (mProfileBtn)
582 { 584 {
583 mProfileBtn->setEnabled(selected_id.notNull()); 585 mProfileBtn->setEnabled(selected_id.notNull() && (selected_speakerp.notNull() && selected_speakerp->mType != LLSpeaker::SPEAKER_EXTERNAL) );
584 } 586 }
585 587
586 // show selected user name in large font 588 // show selected user name in large font
@@ -1034,9 +1036,17 @@ void LLSpeakerMgr::update(BOOL resort_ok)
1034 // speaker no longer registered in voice channel, demote to text only 1036 // speaker no longer registered in voice channel, demote to text only
1035 else if (speakerp->mStatus != LLSpeaker::STATUS_NOT_IN_CHANNEL) 1037 else if (speakerp->mStatus != LLSpeaker::STATUS_NOT_IN_CHANNEL)
1036 { 1038 {
1037 speakerp->mStatus = LLSpeaker::STATUS_TEXT_ONLY; 1039 if(speakerp->mType == LLSpeaker::SPEAKER_EXTERNAL)
1038 speakerp->mSpeechVolume = 0.f; 1040 {
1039 speakerp->mDotColor = ACTIVE_COLOR; 1041 // external speakers should be timed out when they leave the voice channel (since they only exist via SLVoice)
1042 speakerp->mStatus = LLSpeaker::STATUS_NOT_IN_CHANNEL;
1043 }
1044 else
1045 {
1046 speakerp->mStatus = LLSpeaker::STATUS_TEXT_ONLY;
1047 speakerp->mSpeechVolume = 0.f;
1048 speakerp->mDotColor = ACTIVE_COLOR;
1049 }
1040 } 1050 }
1041 } 1051 }
1042 1052
@@ -1088,13 +1098,16 @@ void LLSpeakerMgr::updateSpeakerList()
1088 if ((!mVoiceChannel && gVoiceClient->inProximalChannel()) || (mVoiceChannel && mVoiceChannel->isActive())) 1098 if ((!mVoiceChannel && gVoiceClient->inProximalChannel()) || (mVoiceChannel && mVoiceChannel->isActive()))
1089 { 1099 {
1090 LLVoiceClient::participantMap* participants = gVoiceClient->getParticipantList(); 1100 LLVoiceClient::participantMap* participants = gVoiceClient->getParticipantList();
1091 LLVoiceClient::participantMap::iterator participant_it; 1101 if(participants)
1092
1093 // add new participants to our list of known speakers
1094 for (participant_it = participants->begin(); participant_it != participants->end(); ++participant_it)
1095 { 1102 {
1096 LLVoiceClient::participantState* participantp = participant_it->second; 1103 LLVoiceClient::participantMap::iterator participant_it;
1097 setSpeaker(participantp->mAvatarID, LLStringUtil::null, LLSpeaker::STATUS_VOICE_ACTIVE); 1104
1105 // add new participants to our list of known speakers
1106 for (participant_it = participants->begin(); participant_it != participants->end(); ++participant_it)
1107 {
1108 LLVoiceClient::participantState* participantp = participant_it->second;
1109 setSpeaker(participantp->mAvatarID, participantp->mDisplayName, LLSpeaker::STATUS_VOICE_ACTIVE, (participantp->mAvatarIDValid?LLSpeaker::SPEAKER_AGENT:LLSpeaker::SPEAKER_EXTERNAL));
1110 }
1098 } 1111 }
1099 } 1112 }
1100} 1113}
@@ -1167,6 +1180,10 @@ void LLIMSpeakerMgr::updateSpeakerList()
1167{ 1180{
1168 // don't do normal updates which are pulled from voice channel 1181 // don't do normal updates which are pulled from voice channel
1169 // rely on user list reported by sim 1182 // rely on user list reported by sim
1183
1184 // We need to do this to allow PSTN callers into group chats to show in the list.
1185 LLSpeakerMgr::updateSpeakerList();
1186
1170 return; 1187 return;
1171} 1188}
1172 1189