callcontinuity/vcchotrigger/inc/vccgsmsignallevelhandler.h
author Pat Downey <patd@symbian.org>
Wed, 01 Sep 2010 12:29:57 +0100
branchRCL_3
changeset 22 d38647835c2e
parent 0 a4daefaec16c
permissions -rw-r--r--
Revert incorrect RCL_3 drop: Revision: 201033 Kit: 201035

/*
* 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:   ?Description
*
*/



#ifndef C_VCCGSMSIGNALLEVELHANDLER_H
#define C_VCCGSMSIGNALLEVELHANDLER_H

#include <e32base.h>
#include <etel.h>

#include "vccsignallevelhandler.h"
#include "vccsignallevelobserver.h"
#include "vccgsmnotifications.h"
#include "vccunittesting.h"

/**
 *  VCC GSM signal level handler.
 *
 *  @code
 *  void CExampleClass::ConstructL()
 *      {
 *      //Scan time for low and high 5 sec, low strength -85, high -70 dBm
 *      TSignalLevelParams params = { 5e6, 5e6, 85, 70 };
 *
 *      //
 *      iGsmHandler = CVccGsmSignalLevelHandler::NewL( *this, params );
 *      }
 *
 *  void CExampleClass::StartMonitoringL()
 *      {
 *      // Start monitoring gsm signal levels.
 *      iGsmHandler->StartL();
 *      }
 *
 *  void CExampleClass::StopMonitoringL()
 *      {
 *      // Stop monitoring.
 *      iGsmHandler->StopL();
 *      }
 *
 *  // Called when signal level changes.
 *  void CExampleClass::SignalLevelL(
 *      const CVccSignalLevelHandler* aHandlerInstance,
 *      TInt32 aSignalStrength,
 *      TSignalStrengthClass aClass )
 *      {
 *      if ( iGsmHandler == aHandlerInstance )
 *          {
 *          // GSM signal changed, do whatever is needed
 *          MakeHandoverDecision( aSignalStrength, aClass );
 *          }
 *      }
 *
 *
 *  @endcode
 *
 *  @lib vcchotrigger.dll
 *  @since S60 v3.2
 */
class CVccGsmSignalLevelHandler : public CVccSignalLevelHandler,
                                  public MVccGsmNotifications
    {
public:

    /**
     * Two-phased constructor.
     * @param aObserver Observer of this signal handler
     * @param aParams Parameters for signal monitoring
     */
    static CVccGsmSignalLevelHandler * NewL( MVccSignalLevelObserver & aObserver,
    const TSignalLevelParams& aParams );

    /**
     * Two-phased constructor.
     * @param aObserver Observer of this signal handler
     * @param aParams Parameters for signal monitoring
     */
    static CVccGsmSignalLevelHandler * NewLC(
        MVccSignalLevelObserver & aObserver,
        const TSignalLevelParams& aParams );

    /**
    * Destructor.
    */
    virtual ~CVccGsmSignalLevelHandler();

private:

    /**
     * C++ constructor
     * @param aObserver Reference to signal level observer
     * @param aParams Reference to signal level parameters
     */
    CVccGsmSignalLevelHandler( MVccSignalLevelObserver & aObserver,
                               const TSignalLevelParams& aParams );

    /**
     * Symbian second-phase constructor
     */
    void ConstructL();

private:

// from base class CVccSignalLevelHandler

    /**
    * @see CVccSignalLevelHandler::GetStrength()
    */
    void GetStrength();

    /**
    * @see CVccSignalLevelHandler::EnableNotificationsL()
    */
    void EnableNotificationsL();

    /**
    * @see CVccSignalLevelHandler::DisableNotifications()
    */
    void DisableNotifications();

    /**
    * @see CVccSignalLevelHandler::CancelGetStrength()
    */
    void CancelGetStrength();

    /**
    * @see CVccSignalLevelHandler::NotifyChanges()
    */
    void NotifyChanges( TInt32 aSignalStrength,
                        MVccSignalLevelObserver::TSignalStrengthClass aClass );
    
// from base class MVccGsmNotifications

    /**
    * @see MVccGsmNotifications::GsmStrengthChanged()
    */
    void GsmStrengthChanged( TInt32 aStrength );


private: // data
     
    /**
     * Etel server
     * Own.
     */
    RTelServer iEtelServer;
    
    /**
     * Phone based functionality
     * Own.
     */
    RMobilePhone iPhone;
    
    /**
     * Gsm signal level notifier 
     * Own.
     */
    CVccGsmNotifications* iGsmNotifications;
    
    /** Value of the GSM indication bar */
    TInt8 iBar;
    
    VCC_UNITTEST( UT_CVccGsmSignalLevelHandler )
    };

#endif  // C_VCCGSMSIGNALLEVELHANDLER_H