videoplayerapp/videoplayerengine/src/videoservices.cpp
branchRCL_3
changeset 56 839377eedc2b
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/videoplayerapp/videoplayerengine/src/videoservices.cpp	Tue Aug 31 15:15:55 2010 +0300
@@ -0,0 +1,400 @@
+/*
+* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
+* All rights reserved.
+* This component and the accompanying materials are made available
+* under the terms of "Eclipse Public License v1.0"
+* which accompanies this distribution, and is available
+* at the URL "http://www.eclipse.org/legal/epl-v10.html".
+*
+* Initial Contributors:
+* Nokia Corporation - initial contribution.
+*
+* Contributors:
+*
+* Description:  Implementation of VideoServices
+*
+*/
+
+// Version : %version: da1mmcf#10 %
+
+#include "videoplayerengine.h"
+#include "videoservices.h"
+#include "videoserviceurifetch.h"
+#include "videoserviceplay.h"
+#include "videoserviceview.h"
+#include "videoservicebrowse.h"
+#include "videoserviceuri.h"
+#include "mpxvideo_debug.h"
+#include <xqaiwdecl.h>
+#include <xqserviceutil.h>
+
+VideoServices *VideoServices::mInstance = 0;
+
+// -------------------------------------------------------------------------------------------------
+// VideoServices::instance()
+// -------------------------------------------------------------------------------------------------
+//
+VideoServices* VideoServices::instance( VideoPlayerEngine* engine )
+{
+    MPX_ENTER_EXIT(_L("VideoServices::instance()"));
+    
+    if ( ! mInstance )
+    {
+        mInstance = new VideoServices(engine);
+    }
+    else if ( engine && ! mInstance->engine() )
+    {
+    	mInstance->setEngine(engine);
+    }
+
+    mInstance->mReferenceCount++;
+    return mInstance;
+}
+
+// -------------------------------------------------------------------------------------------------
+// VideoServices::decreaseReferenceCount()
+// -------------------------------------------------------------------------------------------------
+//
+void VideoServices::decreaseReferenceCount()
+{
+    MPX_ENTER_EXIT(_L("VideoServices::decreaseReferenceCount()"));
+    
+    if ( mInstance )
+    {
+        if ( --mInstance->mReferenceCount == 0 )
+        {
+            delete mInstance;
+            mInstance = NULL;
+        }
+    }
+}
+
+// -------------------------------------------------------------------------------------------------
+// setEngine()
+// -------------------------------------------------------------------------------------------------
+//
+void VideoServices::setEngine( VideoPlayerEngine* engine )
+{
+    MPX_ENTER_EXIT(_L("VideoServices::setEngine()"));
+    
+    if ( mServicePlay )
+    {
+    	mEngine = engine;
+    	mServicePlay->setEngine(engine);
+    }
+    
+    if ( mServiceView )
+    {
+    	mEngine = engine;
+    	mServiceView->setEngine(engine);    	
+    }
+    
+    if ( mServiceUriView )
+    {
+        mEngine = engine;
+        mServiceUriView->setEngine(engine);  
+    }
+    		
+}
+
+// -------------------------------------------------------------------------------------------------
+// engine()
+// -------------------------------------------------------------------------------------------------
+//
+VideoPlayerEngine* VideoServices::engine()
+{
+    MPX_DEBUG(_L("VideoServices::engine"));
+	
+    return mEngine;
+}
+
+// -------------------------------------------------------------------------------------------------
+// VideoServices()
+// -------------------------------------------------------------------------------------------------
+//
+VideoServices::VideoServices( VideoPlayerEngine* engine ) 
+    : mReferenceCount( 0 )
+    , mEngine( engine )
+    , mCurrentService( VideoServices::ENoService )
+    , mFetchSelected( false )
+{
+    MPX_ENTER_EXIT(_L("VideoServices::VideoServices()"));
+   
+    // New service, new interface
+    mServicePlay = new VideoServicePlay( this, engine, 
+                                 QLatin1String("videoplayer.com.nokia.symbian.IVideoView") );  
+
+    // New service, new interface
+    mServiceView = new VideoServiceView( this, engine, 
+                                 QLatin1String("videoplayer.com.nokia.symbian.IFileView") ); 
+          
+    // New service, new interface
+    mServiceUriFetch = new VideoServiceUriFetch( this, 
+                                 QLatin1String("videoplayer.com.nokia.symbian.IVideoFetch") ); 
+
+    // New service, new interface
+    mServiceBrowse = new VideoServiceBrowse( this, 
+                                 QLatin1String("videoplayer.com.nokia.symbian.IVideoBrowse") ); 
+
+    // New service, old interface
+    mServicePlayDeprecatedNewService = new VideoServicePlay( this, engine, 
+                                                      QLatin1String("videoplayer.IVideoView") ); 
+
+    // Old service, old interface
+    mServicePlayDeprecatedOldService = new VideoServicePlay( this, engine, 
+                                                      QLatin1String("com.nokia.Videos.IVideoView") );    
+    
+    // New service, old interface
+    mServiceViewDeprecatedNewService = new VideoServiceView( this, engine, 
+                                                      QLatin1String("videoplayer.IFileView") ); 
+
+    // Old service, old interface 
+    mServiceViewDeprecatedOldService = new VideoServiceView( this, engine, 
+                                                      QLatin1String("com.nokia.Videos.IFileView") );     
+    
+    // New service, old interface
+    mServiceUriFetchDeprecatedNewService = new VideoServiceUriFetch( this, 
+                                                      QLatin1String("videoplayer.IVideoFetch") ); 
+
+    // Old service, old interface
+    mServiceUriFetchDeprecatedOldService = new VideoServiceUriFetch( this, 
+                                                      QLatin1String("com.nokia.Videos.IVideoFetch") );     
+
+    // New service, old interface
+    mServiceBrowseDeprecatedNewService = new VideoServiceBrowse( this, 
+                                                      QLatin1String("videoplayer.IVideoBrowse")) ; 
+
+    // Old service, old interface
+    mServiceBrowseDeprecatedOldService = new VideoServiceBrowse( this, 
+                                                      QLatin1String("com.nokia.Videos.IVideoBrowse") ); 
+	
+    // new service, new interface
+    mServiceUriView = new VideoServiceUri(  this, engine, QLatin1String("videoplayer.com.nokia.symbian.IUriView"));	
+    
+	
+}
+
+// -------------------------------------------------------------------------------------------------
+// ~VideoServices()
+// -------------------------------------------------------------------------------------------------
+//
+VideoServices::~VideoServices()
+{
+    MPX_ENTER_EXIT(_L("VideoServices::~VideoServices()"));
+    
+    delete mServiceUriFetch;
+    delete mServicePlay;
+    delete mServiceView;
+    delete mServiceBrowse;
+    delete mServicePlayDeprecatedNewService;
+    delete mServicePlayDeprecatedOldService;
+    delete mServiceViewDeprecatedNewService;
+    delete mServiceViewDeprecatedOldService;
+    delete mServiceBrowseDeprecatedNewService;
+    delete mServiceUriFetchDeprecatedNewService;
+    delete mServiceBrowseDeprecatedOldService;
+    delete mServiceUriFetchDeprecatedOldService;
+    delete mServiceUriView;
+}
+
+// -------------------------------------------------------------------------------------------------
+// currentService()
+// -------------------------------------------------------------------------------------------------
+//
+VideoServices::TVideoService VideoServices::currentService()
+{
+    MPX_DEBUG(_L("VideoServices::currentService() ret %d"), mCurrentService );
+	
+    return mCurrentService;
+}
+
+// -------------------------------------------------------------------------------------------------
+// getBrowseCategory()
+// -------------------------------------------------------------------------------------------------
+//
+int VideoServices::getBrowseCategory() const
+{
+    MPX_DEBUG(_L("VideoServices::getBrowseCategory()"));
+	
+    int category = 0;
+
+    if ( mServiceBrowse && ( XQServiceUtil::interfaceName().contains("symbian") ) )
+    {
+        category = mServiceBrowse->getBrowseCategory();
+    }
+    else if ( mServiceBrowseDeprecatedNewService && 
+              mServiceBrowseDeprecatedOldService && 
+              ! ( XQServiceUtil::interfaceName().contains("symbian") ) )
+    {
+    	if ( mServiceBrowseDeprecatedNewService->isActive() )
+    	{
+            category = mServiceBrowseDeprecatedNewService->getBrowseCategory();
+    	}
+    	else
+    	{
+            category = mServiceBrowseDeprecatedOldService->getBrowseCategory();
+    	}
+    }
+
+    return category;
+}
+
+// -------------------------------------------------------------------------------------------------
+// setCurrentService()
+// -------------------------------------------------------------------------------------------------
+//
+void VideoServices::setCurrentService(VideoServices::TVideoService service)
+{
+    MPX_DEBUG(_L("VideoServices::setCurrentService(%d)"), service );
+	
+    mCurrentService = service;	
+}
+
+// -------------------------------------------------------------------------------------------------
+// contextTitle()
+// -------------------------------------------------------------------------------------------------
+//
+QString VideoServices::contextTitle() const
+{
+    MPX_DEBUG(_L("VideoServices::contextTitle()") );
+	
+    QString title;
+
+    if ( mCurrentService == VideoServices::EUriFetcher )
+    {
+    	if ( mServiceUriFetch && ( XQServiceUtil::interfaceName().contains("symbian") ) )
+    	{
+            title = mServiceUriFetch->contextTitle();
+    	}
+    	else if ( mServiceUriFetchDeprecatedNewService && 
+                  mServiceUriFetchDeprecatedOldService && 
+                  ! ( XQServiceUtil::interfaceName().contains("symbian") ) )
+    	{
+
+            if ( mServiceUriFetchDeprecatedNewService->isActive() )
+    	    {
+    	        title = mServiceUriFetchDeprecatedNewService->contextTitle();
+            }
+    	    else
+    	    {
+    	        title = mServiceUriFetchDeprecatedOldService->contextTitle();
+    	    }
+    	}
+    }
+    else if ( mCurrentService == VideoServices::EBrowse )
+    {
+    	if ( mServiceBrowse && ( XQServiceUtil::interfaceName().contains("symbian") ) )
+        {
+            title = mServiceBrowse->contextTitle();
+        }
+    	else if ( mServiceBrowseDeprecatedNewService && 
+                  mServiceBrowseDeprecatedOldService && 
+                  ! ( XQServiceUtil::interfaceName().contains("symbian") ) )
+        {
+            if ( mServiceBrowseDeprecatedNewService->isActive() )
+            {
+                title = mServiceBrowseDeprecatedNewService->contextTitle();
+            }
+            else
+            {
+                title = mServiceBrowseDeprecatedOldService->contextTitle();
+            }
+        }
+    }
+    
+    return title;
+}
+
+// -------------------------------------------------------------------------------------------------
+// sortRole()
+// -------------------------------------------------------------------------------------------------
+//
+int VideoServices::sortRole() const
+{
+    MPX_ENTER_EXIT(_L("VideoServices::sortType()"));
+    
+    int sortRole = 0;
+
+    if ( mCurrentService == EBrowse )
+    {
+    	if ( mServiceBrowse && ( XQServiceUtil::interfaceName().contains("symbian") ) )
+        {
+            sortRole = mServiceBrowse->sortRole();
+        }
+    	else if ( mServiceBrowseDeprecatedNewService && 
+                  mServiceBrowseDeprecatedOldService && 
+                  ! ( XQServiceUtil::interfaceName().contains("symbian") ) )
+        {
+            if ( mServiceBrowseDeprecatedNewService->isActive() )
+            {
+                sortRole = mServiceBrowseDeprecatedNewService->sortRole();
+            }
+            else
+            {
+                sortRole = mServiceBrowseDeprecatedOldService->sortRole();
+            }
+        }
+    }
+    
+    return sortRole;
+}
+
+// -------------------------------------------------------------------------------------------------
+// itemSelected()
+// -------------------------------------------------------------------------------------------------
+//
+void VideoServices::itemSelected(const QString& item)
+{
+    MPX_ENTER_EXIT(_L("VideoServices::itemSelected()"),
+                   _L("item = %s"), item.data() );
+    
+    QStringList list;
+    list.append( item );
+
+    if( mServiceUriFetch && ( XQServiceUtil::interfaceName().contains("symbian") ) )
+    {
+    	mServiceUriFetch->complete( list );
+    }
+    else if ( mServiceUriFetchDeprecatedNewService && mServiceUriFetchDeprecatedOldService )
+    {
+    	if ( mServiceUriFetchDeprecatedNewService->isActive() )
+    	{
+            mServiceUriFetchDeprecatedNewService->complete( list );
+    	}
+    	else
+    	{
+            mServiceUriFetchDeprecatedOldService->complete( list );
+    	}
+    }
+
+    mFetchSelected = true;
+}
+
+// -------------------------------------------------------------------------------------------------
+// browsingEnded()
+// -------------------------------------------------------------------------------------------------
+//
+void VideoServices::browsingEnded()
+{
+    MPX_ENTER_EXIT(_L("VideoServices::browsingEnded()"));
+
+    if ( mServiceBrowse && ( XQServiceUtil::interfaceName().contains("symbian") ) )
+    {
+        mServiceBrowse->complete();
+    }
+    else if ( mServiceBrowseDeprecatedNewService && 
+              mServiceBrowseDeprecatedOldService && 
+              ! ( XQServiceUtil::interfaceName().contains("symbian") ) )
+    {
+        if ( mServiceBrowseDeprecatedNewService->isActive() )
+    	{
+            mServiceBrowseDeprecatedNewService->complete();
+    	}
+    	else
+    	{
+            mServiceBrowseDeprecatedOldService->complete();
+    	}
+    }
+}
+
+// End of file