vtuis/videotelui/inc/cvtuidtmfbuffer.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Wed, 13 Oct 2010 14:34:55 +0300
branchRCL_3
changeset 49 8e703580edd3
parent 37 590f6f022902
permissions -rw-r--r--
Revision: 201038 Kit: 201041

/*
* Copyright (c) 2007 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:  DTMF buffer definition.
*
*/


#ifndef C_VTUIDTMFBUFFER_H
#define C_VTUIDTMFBUFFER_H

#include <e32base.h>
#include "mvtuinumbersource.h"

class CCoeEnv;
class TKeyEvent;

// Maximum size of the DTMF buffer
const TInt KVtUiDTMFBufferSize = 64;

/**
*  MVtUiDTMFBufferObserver
*
*  Observer of DTMF chaning.
*/

class MVtUiDTMFBufferObserver
    {
public:
    /*
     * Buffer changed callback
     */
    virtual void NotifyDTMFBufferChangedL() = 0;
    };
    
/**
*  CVtUiDTMFBuffer
*
*  Base componentstate definition.
*
*  @since S60 v5.0
*/

class CVtUiDTMFBuffer : public CActive, public MVtUiNumberSource
    {

public:

    /**
    * Static construction method.
    * @param aCoeEnv Reference to CoeEnv object.
    * @return Pointer to newly created instance of CVtUiDTMFBuffer.
    */
    static CVtUiDTMFBuffer* NewL( const CCoeEnv& aCoeEnv );

    /**
    * Static construction method.
    * @param aCoeEnv Reference to CoeEnv object.
    * @param aObserver Pointer to buffer observer
    * @return Pointer to newly created instance of CVtUiDTMFBuffer.
    */
    static CVtUiDTMFBuffer* NewL( const CCoeEnv& aCoeEnv, MVtUiDTMFBufferObserver* aObserver );

    /**
    * C++ destructor.
    */
    ~CVtUiDTMFBuffer();

    /**
    * Append one character to DTMF buffer.
    * @param aChar Character to append.
    * @return ETrue if the given character was appended (i.e. it is a DTMF)
    */
    TBool Append( TChar aChar );

    /**
    * Clears the contents of the DTMF buffer.
    */
    void Reset();

    /**
    * Promote this instance as current number source.
    */
    void Activate();

    /**
    * Demote this instance from current number source position.
    */
    void Deactivate();

public: // from MVtUiNumberSource

    /**
    * @see MVtUiNumberSource::GetContents
    */
    void GetContents( TDes& aContents ) const;

private: // from CActive

    /**
    * @see CActive::DoCancel
    */
    void DoCancel();

    /**
    * @see CActive::RunL
    */
    void RunL();

private:

    /**
    * C++ constructor
    */
    CVtUiDTMFBuffer( const CCoeEnv& aCoeEnv );
    
    /**
    * C++ constructor
    */
    CVtUiDTMFBuffer( const CCoeEnv& aCoeEnv, MVtUiDTMFBufferObserver* aObserver );

    /**
    * 2nd constructor, may leave.
    */
    void ConstructL();

    /**
    * Starts buffer modification monitoring timer. If this timer expires,
    * buffer will be reset. Timer is restarted when new character is added to
    * the buffer.
    */
    void StartTimer();

    /**
    * Called when buffer modification monitoring timer has expired.
    */
    void TimerExpired( TInt aError );

    /**
    * Clears the contents of the DTMF buffer.
    */
    void ResetBuffer();

private:

    // Reference to coeenv
    const CCoeEnv& iCoeEnv;

    // Timer instance
    RTimer iTimer;

    // DTMF buffer
    TBuf< KVtUiDTMFBufferSize > iBuffer;
    
    // DTMF buffer observer
    MVtUiDTMFBufferObserver* iObserver;

    };

#endif // C_VTUIDTMFBUFFER_H