tvout/src/glxtvconnectionmonitor.cpp
changeset 26 c499df2dbb33
parent 24 99ad1390cd33
child 27 0d818da5a659
child 29 2c833fc9e98f
child 40 112f0ac2d1f0
equal deleted inserted replaced
24:99ad1390cd33 26:c499df2dbb33
     1 /*
       
     2 * Copyright (c) 2008-2009 Nokia Corporation and/or its subsidiary(-ies). 
       
     3 * All rights reserved.
       
     4 * This component and the accompanying materials are made available
       
     5 * under the terms of "Eclipse Public License v1.0"
       
     6 * which accompanies this distribution, and is available
       
     7 * at the URL "http://www.eclipse.org/legal/epl-v10.html".
       
     8 *
       
     9 * Initial Contributors:
       
    10 * Nokia Corporation - initial contribution.
       
    11 *
       
    12 * Contributors:
       
    13 *
       
    14 * Description:    Monitors the Tv Out Connection
       
    15 *
       
    16 */
       
    17 
       
    18 
       
    19 
       
    20 /**
       
    21  * @internal reviewed 24/08/2007 by D Holland
       
    22  */
       
    23 
       
    24 //  CLASS HEADER
       
    25 #include "glxtvconnectionmonitor.h"
       
    26 
       
    27 //  EXTERNAL INCLUDES
       
    28 
       
    29 //  INTERNAL INCLUDES
       
    30 
       
    31 #include <glxlog.h>
       
    32 #include <glxpanic.h>
       
    33 #include "glxtv.h"
       
    34 
       
    35 
       
    36 //-----------------------------------------------------------------------------
       
    37 // Return new object
       
    38 //-----------------------------------------------------------------------------
       
    39 //
       
    40 CGlxTvConnectionMonitor* CGlxTvConnectionMonitor::NewL(
       
    41                                MGlxTvConnectionObserver& aConnectionObserver ) 
       
    42     {
       
    43     GLX_LOG_INFO("CGlxTvConnectionMonitor::NewL");
       
    44     CGlxTvConnectionMonitor* self = new (ELeave) 
       
    45                 CGlxTvConnectionMonitor( aConnectionObserver );
       
    46     CleanupStack::PushL( self );
       
    47     self->ConstructL();
       
    48     CleanupStack::Pop( self );
       
    49     return self;
       
    50     }
       
    51     
       
    52 
       
    53 //-----------------------------------------------------------------------------
       
    54 // Destructor
       
    55 //-----------------------------------------------------------------------------
       
    56 //
       
    57 CGlxTvConnectionMonitor::~CGlxTvConnectionMonitor()
       
    58     {
       
    59     GLX_LOG_INFO("~CGlxTvConnectionMonitor");
       
    60     Cancel();
       
    61     iTvAccServer.Disconnect();
       
    62     }
       
    63 
       
    64 
       
    65 //-----------------------------------------------------------------------------
       
    66 // Default C++ constructor
       
    67 //-----------------------------------------------------------------------------
       
    68 //
       
    69 CGlxTvConnectionMonitor::CGlxTvConnectionMonitor
       
    70                            ( MGlxTvConnectionObserver& aConnectionObserver ) 
       
    71                             :CActive(EPriorityStandard), 
       
    72                              iConnectionObserver ( aConnectionObserver )
       
    73     {
       
    74     GLX_LOG_INFO("CGlxTvConnectionMonitor");
       
    75     CActiveScheduler::Add( this );
       
    76     }
       
    77 
       
    78 
       
    79 //-----------------------------------------------------------------------------
       
    80 // Symbian second phase constructor
       
    81 //-----------------------------------------------------------------------------
       
    82 //
       
    83 void CGlxTvConnectionMonitor::ConstructL()
       
    84     {
       
    85     GLX_LOG_INFO("CGlxTvConnectionMonitor::ConstructL");
       
    86     User::LeaveIfError( iTvAccServer.Connect() );
       
    87     User::LeaveIfError( iTvAccMode.CreateSubSession( iTvAccServer ) );
       
    88     User::LeaveIfError( iTvAccMode.GetAccessoryMode( iCurrentAccMode ) );
       
    89     iTvOutConnectionState = ( iCurrentAccMode.iAccessoryMode == EAccModeTVOut);
       
    90     iHDMIConnectionState = ( iCurrentAccMode.iAccessoryMode == EAccModeHDMI);
       
    91     
       
    92     IssueRequest();  
       
    93     }
       
    94 
       
    95 //-----------------------------------------------------------------------------
       
    96 // From class CActive.
       
    97 // Receive notification of change in the connection state
       
    98 //-----------------------------------------------------------------------------
       
    99 //
       
   100 void CGlxTvConnectionMonitor::RunL()
       
   101     {
       
   102     GLX_LOG_INFO("CGlxTvConnectionMonitor::RunL");
       
   103     // Check for errors
       
   104     User::LeaveIfError( iStatus.Int() );
       
   105     // Notify observers
       
   106     IssueNotificationL();
       
   107     // Request the next event
       
   108     IssueRequest();  
       
   109     }
       
   110 
       
   111 
       
   112 //-----------------------------------------------------------------------------
       
   113 // From class CActive.
       
   114 // DoCancel
       
   115 //-----------------------------------------------------------------------------
       
   116 //
       
   117 void CGlxTvConnectionMonitor::DoCancel()
       
   118     {
       
   119     GLX_LOG_INFO("CGlxTvConnectionMonitor::DoCancel");
       
   120     iTvAccMode.CancelNotifyAccessoryModeChanged();
       
   121     }
       
   122 
       
   123 
       
   124 
       
   125 //-----------------------------------------------------------------------------
       
   126 // From class CActive.
       
   127 // RunError
       
   128 //-----------------------------------------------------------------------------
       
   129 //
       
   130 TInt CGlxTvConnectionMonitor::RunError(TInt aError)
       
   131     {
       
   132     GLX_LOG_INFO1("CGlxTvConnectionMonitor::RunError - %d", aError);
       
   133     return KErrNone;
       
   134     }
       
   135 
       
   136 //-----------------------------------------------------------------------------
       
   137 // Is the TV out cable connected
       
   138 // IsConnected
       
   139 //-----------------------------------------------------------------------------
       
   140 //
       
   141 TBool CGlxTvConnectionMonitor::IsConnected() const
       
   142     {
       
   143     GLX_LOG_INFO("CGlxTvConnectionMonitor::IsConnected");
       
   144     return iTvOutConnectionState;
       
   145     }
       
   146 
       
   147 //-----------------------------------------------------------------------------
       
   148 // Is the TV out cable connected
       
   149 // IsConnected
       
   150 //-----------------------------------------------------------------------------
       
   151 //
       
   152 TBool CGlxTvConnectionMonitor::IsHDMIConnected() const
       
   153     {
       
   154     GLX_LOG_INFO("CGlxTvConnectionMonitor::IsHDMIConnected");
       
   155     return iHDMIConnectionState;
       
   156     }
       
   157 
       
   158 //-----------------------------------------------------------------------------
       
   159 // Request accessory server events
       
   160 //-----------------------------------------------------------------------------
       
   161 //
       
   162 void CGlxTvConnectionMonitor::IssueRequest()
       
   163     {
       
   164     GLX_LOG_INFO("CGlxTvConnectionMonitor::IssueRequest");
       
   165     if (!IsActive()) // required for testing
       
   166         {
       
   167         iTvAccMode.NotifyAccessoryModeChanged( iStatus, iCurrentAccMode ); 
       
   168         SetActive(); 
       
   169         }
       
   170     }
       
   171 
       
   172 
       
   173 //-----------------------------------------------------------------------------
       
   174 // Sends notification to observers if TV Out is connected
       
   175 //-----------------------------------------------------------------------------
       
   176 //
       
   177 void CGlxTvConnectionMonitor::IssueNotificationL()
       
   178     {
       
   179     GLX_LOG_INFO("CGlxTvConnectionMonitor::IssueNotificationL");
       
   180     TBool previousTvState = iTvOutConnectionState;
       
   181     TBool previousHDMIState = iHDMIConnectionState;
       
   182     GLX_LOG_INFO2("previousTvState = %d , previousHDMIState = %d",
       
   183             previousTvState,previousHDMIState);
       
   184     iTvOutConnectionState = ( iCurrentAccMode.iAccessoryMode == EAccModeTVOut);
       
   185     iHDMIConnectionState = ( iCurrentAccMode.iAccessoryMode == EAccModeHDMI);
       
   186     // Call Statuschnage only if actually TvState or HDMIState has changed.
       
   187     if ( previousTvState!= iTvOutConnectionState ||
       
   188             previousHDMIState != iHDMIConnectionState)
       
   189         {
       
   190         GLX_LOG_INFO("CGlxTvConnectionMonitor::IssueNotificationL -"
       
   191                 " TvConnectionStatusChanged");
       
   192         iConnectionObserver.HandleTvConnectionStatusChangedL();
       
   193         }
       
   194     }
       
   195 
       
   196 
       
   197 
       
   198