tvout/tvoutengine/src/glxtvconnectionmonitor.cpp
changeset 26 c499df2dbb33
child 29 2c833fc9e98f
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/tvout/tvoutengine/src/glxtvconnectionmonitor.cpp	Mon May 03 12:31:32 2010 +0300
@@ -0,0 +1,252 @@
+/*
+* Copyright (c) 2008-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:    Monitors the Tv Out Connection
+*
+*/
+
+
+
+/**
+ * @internal reviewed 24/08/2007 by D Holland
+ */
+
+//  CLASS HEADER
+#include "glxtvconnectionmonitor.h"
+
+//  EXTERNAL INCLUDES
+
+//  INTERNAL INCLUDES
+
+#include <glxlog.h>
+#include <glxpanic.h>
+#include "glxtv.h"
+#include <AccPolGenericIdDefinitions.h>
+#include <AccPolSubblockNameArray.h>
+//-----------------------------------------------------------------------------
+// Return new object
+//-----------------------------------------------------------------------------
+//
+CGlxTvConnectionMonitor* CGlxTvConnectionMonitor::NewL(
+                               MGlxTvConnectionObserver& aConnectionObserver ) 
+    {
+    GLX_LOG_INFO("CGlxTvConnectionMonitor::NewL");
+    CGlxTvConnectionMonitor* self = new (ELeave) 
+                CGlxTvConnectionMonitor( aConnectionObserver );
+    CleanupStack::PushL( self );
+    self->ConstructL();
+    CleanupStack::Pop( self );
+    return self;
+    }
+    
+
+//-----------------------------------------------------------------------------
+// Destructor
+//-----------------------------------------------------------------------------
+//
+CGlxTvConnectionMonitor::~CGlxTvConnectionMonitor()
+    {
+    GLX_LOG_INFO("~CGlxTvConnectionMonitor");
+    Cancel();
+    iTvAccCon.CloseSubSession();
+    iTvAccServer.Disconnect();
+    }
+
+
+//-----------------------------------------------------------------------------
+// Default C++ constructor
+//-----------------------------------------------------------------------------
+//
+CGlxTvConnectionMonitor::CGlxTvConnectionMonitor
+                           ( MGlxTvConnectionObserver& aConnectionObserver ) 
+                            :CActive(EPriorityStandard), 
+                             iConnectionObserver ( aConnectionObserver )
+    {
+    GLX_LOG_INFO("CGlxTvConnectionMonitor");
+    CActiveScheduler::Add( this );
+    }
+
+
+//-----------------------------------------------------------------------------
+// Symbian second phase constructor
+//-----------------------------------------------------------------------------
+//
+void CGlxTvConnectionMonitor::ConstructL()
+    {
+    GLX_LOG_INFO("CGlxTvConnectionMonitor::ConstructL");
+    User::LeaveIfError(iTvAccServer.Connect());
+	User::LeaveIfError(iTvAccCon.CreateSubSession(iTvAccServer));
+	User::LeaveIfError(iTvAccCon.GetAccessoryConnectionStatus(iCurrentAccArray));
+	for (int i = 0; i < iCurrentAccArray.Count(); i++)
+		{
+		iTvOutConnectionState
+				= (iCurrentAccArray.GetGenericIDL(i).PhysicalConnectionCaps()
+						== KPCWired);
+		iHDMIConnectionState
+				= (iCurrentAccArray.GetGenericIDL(i).PhysicalConnectionCaps()
+						== KPCHDMI);
+		}
+    IssueRequest();  
+    }
+
+//-----------------------------------------------------------------------------
+// From class CActive.
+// Receive notification of change in the connection state
+//-----------------------------------------------------------------------------
+//
+void CGlxTvConnectionMonitor::RunL()
+    {
+    GLX_LOG_INFO("CGlxTvConnectionMonitor::RunL");
+    // Check for errors
+    User::LeaveIfError( iStatus.Int() );
+    // Notify observers
+    IssueNotificationL();
+    // Request the next event
+    IssueRequest();  
+    }
+
+
+//-----------------------------------------------------------------------------
+// From class CActive.
+// DoCancel
+//-----------------------------------------------------------------------------
+//
+void CGlxTvConnectionMonitor::DoCancel()
+    {
+    GLX_LOG_INFO("CGlxTvConnectionMonitor::DoCancel");
+    iTvAccCon.CancelGetAccessoryConnectionStatus();
+    iTvAccCon.CancelNotifyAccessoryConnectionStatusChanged();
+    }
+
+
+
+//-----------------------------------------------------------------------------
+// From class CActive.
+// RunError
+//-----------------------------------------------------------------------------
+//
+TInt CGlxTvConnectionMonitor::RunError(TInt aError)
+    {
+    GLX_LOG_INFO1("CGlxTvConnectionMonitor::RunError - %d", aError);
+    return KErrNone;
+    }
+
+//-----------------------------------------------------------------------------
+// Is the TV out cable connected
+// IsConnected
+//-----------------------------------------------------------------------------
+//
+TBool CGlxTvConnectionMonitor::IsConnected() const
+    {
+    GLX_LOG_INFO("CGlxTvConnectionMonitor::IsConnected");
+    GLX_LOG_INFO1("CGlxTvConnectionMonitor::IsConnected iTvOutConnectionState=%d",iTvOutConnectionState);
+    return iTvOutConnectionState;
+    }
+
+//-----------------------------------------------------------------------------
+// Is the TV out cable connected
+// IsConnected
+//-----------------------------------------------------------------------------
+//
+TBool CGlxTvConnectionMonitor::IsHDMIConnected() const
+    {
+    GLX_LOG_INFO("CGlxTvConnectionMonitor::IsHDMIConnected");
+    GLX_LOG_INFO1("CGlxTvConnectionMonitor::IsHDMIConnected iHDMIConnectionState=%d",iHDMIConnectionState);
+    return iHDMIConnectionState;
+    }
+
+//-----------------------------------------------------------------------------
+// Request accessory server events
+//-----------------------------------------------------------------------------
+//
+void CGlxTvConnectionMonitor::IssueRequest()
+    {
+    GLX_LOG_INFO("CGlxTvConnectionMonitor::IssueRequest");
+    if (!IsActive()) // required for testing
+        {
+        iTvAccCon.NotifyAccessoryConnectionStatusChanged(iStatus,iCurrentAccArray);
+        SetActive(); 
+        }
+    }
+
+
+//-----------------------------------------------------------------------------
+// Sends notification to observers if TV Out is connected
+//-----------------------------------------------------------------------------
+//
+void CGlxTvConnectionMonitor::IssueNotificationL()
+    {
+	GLX_LOG_INFO("CGlxTvConnectionMonitor::IssueNotificationL");
+	TBool previousTvState = iTvOutConnectionState;
+	TBool previousHDMIState = iHDMIConnectionState;
+	GLX_LOG_INFO2("previousTvState = %d , previousHDMIState = %d",
+			previousTvState,previousHDMIState);
+
+	//gets the TV status in to the iCurrentAccArray and haves the Latest Accesory in 0-index
+	User::LeaveIfError(iTvAccCon.GetAccessoryConnectionStatus(iCurrentAccArray));
+
+	CAccPolSubblockNameArray* nameArray = CAccPolSubblockNameArray::NewL();
+	CleanupStack::PushL(nameArray);
+
+	//
+	//  Get the number of currently connected accessories
+	//  Loop through each connected accessory looking for
+	//  the desired capabilities
+	//
+	iTvOutConnectionState = EFalse;
+	iHDMIConnectionState = EFalse;
+	const TInt count = iCurrentAccArray.Count();
+	for (TInt index = 0; index < count; index++)
+		{
+		TAccPolGenericID genId = iCurrentAccArray.GetGenericIDL(index);
+		//  Get all supported capabilities for this connected accessory.
+		iTvAccCon.GetSubblockNameArrayL(genId, *nameArray);
+		//  Check if this connected accessory supports TV-Out capabality.
+		if (nameArray->HasName(KAccVideoOut))
+			{
+			GLX_LOG_INFO("TV-Out Capabilities Exist");
+			TAccPolNameRecord nameRecord;
+			nameRecord.SetNameL(KAccVideoOut);
+			TAccValueTypeTInt value;
+			iTvAccCon.GetValueL(genId, nameRecord, value);
+			if (value.iValue == EAccVideoOutEHDMI)
+				{
+				GLX_LOG_INFO("HDMI is connected Capabilities Exist");
+				iHDMIConnectionState = ETrue;
+				break;
+				}
+			else if (value.iValue == EAccVideoOutCVideo)
+				{
+				GLX_LOG_INFO("TV is connected Capabilities Exist");
+				iTvOutConnectionState = ETrue;
+				break;
+				}
+			}
+
+		}
+	CleanupStack::PopAndDestroy(nameArray);
+
+	if (previousTvState != iTvOutConnectionState || previousHDMIState
+			!= iHDMIConnectionState)
+        {
+        GLX_LOG_INFO("CGlxTvConnectionMonitor::IssueNotificationL -"
+                " TvConnectionStatusChanged");
+        GLX_LOG_INFO2("CurrentTvState = %d , CurrentHDMIState = %d",
+                iTvOutConnectionState,iHDMIConnectionState);
+        iConnectionObserver.HandleTvConnectionStatusChangedL();
+        }
+    }
+
+
+
+