diff options
| -rw-r--r-- | indra/newview/llappviewer.cpp | 2 | ||||
| -rw-r--r-- | indra/newview/llviewermedia.cpp | 27 | ||||
| -rw-r--r-- | indra/newview/llviewermedia.h | 3 | ||||
| -rw-r--r-- | indra/newview/llviewertexturelist.cpp | 4 | ||||
| -rw-r--r-- | indra/newview/llviewerwindow.cpp | 4 | 
5 files changed, 31 insertions, 9 deletions
| diff --git a/indra/newview/llappviewer.cpp b/indra/newview/llappviewer.cpp index eb08707b61..84843138bf 100644 --- a/indra/newview/llappviewer.cpp +++ b/indra/newview/llappviewer.cpp @@ -899,6 +899,8 @@ bool LLAppViewer::init()  		loadEventHostModule(gSavedSettings.getS32("QAModeEventHostPort"));  	} +	LLViewerMedia::initClass(); +	  	return true;  } diff --git a/indra/newview/llviewermedia.cpp b/indra/newview/llviewermedia.cpp index d5fd23ac51..095430dcfc 100644 --- a/indra/newview/llviewermedia.cpp +++ b/indra/newview/llviewermedia.cpp @@ -45,6 +45,9 @@  #include "llviewertexturelist.h"  #include "llvovolume.h"  #include "llpluginclassmedia.h" +#include "llviewerwindow.h" +#include "llfocusmgr.h" +#include "llcallbacklist.h"  #include "llevent.h"		// LLSimpleListener  #include "llnotificationsutil.h" @@ -625,7 +628,7 @@ static bool proximity_comparitor(const LLViewerMediaImpl* i1, const LLViewerMedi  //////////////////////////////////////////////////////////////////////////////////////////  // static -void LLViewerMedia::updateMedia() +void LLViewerMedia::updateMedia(void *dummy_arg)  {  	impl_list::iterator iter = sViewerMediaImplList.begin();  	impl_list::iterator end = sViewerMediaImplList.end(); @@ -747,6 +750,19 @@ void LLViewerMedia::updateMedia()  			impl_count_total++;  		} +		// Overrides if the window is minimized or we lost focus (taking care +		// not to accidentally "raise" the priority either) +		if (!gViewerWindow->getActive() /* viewer window minimized? */  +			&& new_priority > LLPluginClassMedia::PRIORITY_HIDDEN) +		{ +			new_priority = LLPluginClassMedia::PRIORITY_HIDDEN; +		} +		else if (!gFocusMgr.getAppHasFocus() /* viewer window lost focus? */ +				 && new_priority > LLPluginClassMedia::PRIORITY_LOW) +		{ +			new_priority = LLPluginClassMedia::PRIORITY_LOW; +		} +		  		pimpl->setPriority(new_priority);  		if(pimpl->getUsedInUI()) @@ -785,9 +801,16 @@ void LLViewerMedia::updateMedia()  //////////////////////////////////////////////////////////////////////////////////////////  // static +void LLViewerMedia::initClass() +{ +	gIdleCallbacks.addFunction(LLViewerMedia::updateMedia, NULL); +} + +////////////////////////////////////////////////////////////////////////////////////////// +// static  void LLViewerMedia::cleanupClass()  { -	// This is no longer necessary, since sViewerMediaImplList is no longer smart pointers. +	gIdleCallbacks.deleteFunction(LLViewerMedia::updateMedia, NULL);  }  ////////////////////////////////////////////////////////////////////////////////////////// diff --git a/indra/newview/llviewermedia.h b/indra/newview/llviewermedia.h index e2d159304f..24e7154805 100644 --- a/indra/newview/llviewermedia.h +++ b/indra/newview/llviewermedia.h @@ -96,9 +96,10 @@ class LLViewerMedia  		static bool textureHasMedia(const LLUUID& texture_id);  		static void setVolume(F32 volume); -		static void updateMedia(); +		static void updateMedia(void* dummy_arg = NULL);  		static bool isMusicPlaying(); +		static void initClass();  		static void cleanupClass();  		static void toggleMusicPlay(void*); diff --git a/indra/newview/llviewertexturelist.cpp b/indra/newview/llviewertexturelist.cpp index dbcf563010..5be7f2945f 100644 --- a/indra/newview/llviewertexturelist.cpp +++ b/indra/newview/llviewertexturelist.cpp @@ -614,10 +614,6 @@ void LLViewerTextureList::updateImages(F32 max_time)  			didone = image->doLoadedCallbacks();  		}  	} -	if (!gNoRender && !gGLManager.mIsDisabled) -	{ -		LLViewerMedia::updateMedia(); -	}  	updateImagesUpdateStats();  } diff --git a/indra/newview/llviewerwindow.cpp b/indra/newview/llviewerwindow.cpp index 9ba056a17c..8529a93527 100644 --- a/indra/newview/llviewerwindow.cpp +++ b/indra/newview/llviewerwindow.cpp @@ -1011,6 +1011,7 @@ BOOL LLViewerWindow::handleActivate(LLWindow *window, BOOL activated)  	else  	{  		mActive = FALSE; +				  		if (gSavedSettings.getBOOL("AllowIdleAFK"))  		{  			gAgent.setAFK(); @@ -3244,8 +3245,7 @@ LLPickInfo LLViewerWindow::pickImmediate(S32 x, S32 y_from_bot,  BOOL pick_trans  	}  	else  	{ -		llwarns << "List of last picks is empty" << llendl; -		llwarns << "Using stub pick" << llendl; +		lldebugs << "List of last picks is empty: Using stub pick" << llendl;  		mLastPick = LLPickInfo();  	} | 
