devicesrv_pub/haptics_api/inc/hwrmhapticsobserver.h
author William Roberts <williamr@symbian.org>
Fri, 28 May 2010 14:18:28 +0100
changeset 13 51d936fe0d0c
parent 0 4e1aa6a622a0
permissions -rw-r--r--
Re-merge workaround for bug 2620

/*
* Copyright (c) 2008 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:  This file contains the header of the 
*                MHWRMHapticsObserver class.
*
*/


#ifndef M_HWRMHAPTICSOBSERVER_H
#define M_HWRMHAPTICSOBSERVER_H

#include <e32base.h>

/**
* MHWRMHapticsObserver observer class.
*
* A client should derive from this abstract class to receive haptics 
* status notifications and notification of effect completion. 
*
* @since S60 5.1
*/
class MHWRMHapticsObserver
    {
public:
    
    /**
    * Haptics status.
    */
    enum THWRMHapticsStatus 
        {
        /**
         * Haptics is available for the observing client.
         */
        EHWRMHapticsStatusAvailable = 0,

        /**
         * Haptics is reserved for another client. The client making 
         * the active reservation does not receive this notification, but
         * a success code for the reservation command.
         */
        EHWRMHapticsStatusReserved,

        /**
         * Haptics has been suspended for this client. This occurs, when
         * another client with higher priority makes reservation for 
         * haptics, or when this client is making reservation and haptics 
         * has already been reserved for a client with higher priority.
         *
         * In suspended state, haptics effects are not played for the
         * suspended client, but other commands are executed as normal.
         */
        EHWRMHapticsStatusSuspended
        };
        
    /** 
    * Called when the device's haptics feature state changes
    *
    * @param aStatus Indicates haptics status.
    *
    * @since S60 5.1
    *
    * @see CHWRMHaptics::THWRMHapticsStatus
    */
    virtual void HapticsStatusChangedL( THWRMHapticsStatus aStatus ) = 0;
        
    /** 
    * Called when effect has completed playing. 
    * 
    * Method reserved for future use.
    *
    * @param aError Reason of completion.
    * @param aEffectHandle The associated effectHandle to the effect.
    *
    * @since S60 5.1
    */
    virtual void EffectCompletedL( TInt aError, TInt aEffectHandle ) = 0;
    };

#endif // M_HWRMHAPTICSOBSERVER_H