mds_plat/location_manager_api/inc/reversegeocoderplugin.h
author hgs
Wed, 06 Oct 2010 15:08:08 +0300
changeset 60 79f826a55db2
parent 51 87e65c44ff3a
permissions -rw-r--r--
201039
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
51
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies). 
hgs
parents:
diff changeset
     3
* All rights reserved.
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
hgs
parents:
diff changeset
     8
*
hgs
parents:
diff changeset
     9
* Initial Contributors:
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
hgs
parents:
diff changeset
    11
*
hgs
parents:
diff changeset
    12
* Contributors:
hgs
parents:
diff changeset
    13
*
hgs
parents:
diff changeset
    14
* Description:	The header file for ReverseGeoCoderPlugin that creates the ReverseGeocoder
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
hgs
parents:
diff changeset
    19
#ifndef __REVERSEGEOCODERPLUGIN_H__
hgs
parents:
diff changeset
    20
#define __REVERSEGEOCODERPLUGIN_H__
hgs
parents:
diff changeset
    21
hgs
parents:
diff changeset
    22
// INCLUDES
hgs
parents:
diff changeset
    23
hgs
parents:
diff changeset
    24
#include <e32base.h> 
hgs
parents:
diff changeset
    25
#include <lbsposition.h> 
hgs
parents:
diff changeset
    26
#include <etel.h>
hgs
parents:
diff changeset
    27
#include <etelmm.h>
hgs
parents:
diff changeset
    28
#include <geotagobserver.h>
hgs
parents:
diff changeset
    29
hgs
parents:
diff changeset
    30
const TUid KReversegeocodeInterfaceUid = {0x2002DD13};
hgs
parents:
diff changeset
    31
hgs
parents:
diff changeset
    32
hgs
parents:
diff changeset
    33
/*
hgs
parents:
diff changeset
    34
 * Data class to get the address details. An handle to this type will be given to the
hgs
parents:
diff changeset
    35
 * user through MReverseGeocodeObserver::ReverseGeocodeComplete callback, through which
hgs
parents:
diff changeset
    36
 * user can retrieve the address details using the following interfaces.
hgs
parents:
diff changeset
    37
 *
hgs
parents:
diff changeset
    38
 **/
hgs
parents:
diff changeset
    39
class MAddressInfo
hgs
parents:
diff changeset
    40
    {
hgs
parents:
diff changeset
    41
    public:
hgs
parents:
diff changeset
    42
    /*
hgs
parents:
diff changeset
    43
     * Gets the reference to the country name. Scope of this returned reference is limited to
hgs
parents:
diff changeset
    44
     * this perticular call. User has to store it for their further processing.
hgs
parents:
diff changeset
    45
     * 
hgs
parents:
diff changeset
    46
     *  @return reference to the String which holds the Country Name. 
hgs
parents:
diff changeset
    47
     */
hgs
parents:
diff changeset
    48
    virtual TDesC& GetCountryName()= 0;
hgs
parents:
diff changeset
    49
    
hgs
parents:
diff changeset
    50
    /*
hgs
parents:
diff changeset
    51
     * Gets the reference to the State. Scope of this returned reference is limited to
hgs
parents:
diff changeset
    52
     * this perticular call. User has to store it for their further processing.
hgs
parents:
diff changeset
    53
     * 
hgs
parents:
diff changeset
    54
     *  @return reference to the String which holds the State name. 
hgs
parents:
diff changeset
    55
     */
hgs
parents:
diff changeset
    56
    virtual TDesC& GetState()= 0;
hgs
parents:
diff changeset
    57
    
hgs
parents:
diff changeset
    58
    /*
hgs
parents:
diff changeset
    59
     * Gets the reference to the City. Scope of this returned reference is limited to
hgs
parents:
diff changeset
    60
     * this perticular call. User has to store it for their further processing.
hgs
parents:
diff changeset
    61
     * 
hgs
parents:
diff changeset
    62
     *  @return reference to the String which holds the City Name. 
hgs
parents:
diff changeset
    63
     */
hgs
parents:
diff changeset
    64
    virtual TDesC& GetCity()= 0;
hgs
parents:
diff changeset
    65
    
hgs
parents:
diff changeset
    66
    /*
hgs
parents:
diff changeset
    67
     * Gets the reference to the District name. Scope of this returned reference is limited to
hgs
parents:
diff changeset
    68
     * this perticular call. User has to store it for their further processing.
hgs
parents:
diff changeset
    69
     * 
hgs
parents:
diff changeset
    70
     *  @return reference to the String which holds the District Name. 
hgs
parents:
diff changeset
    71
     */
hgs
parents:
diff changeset
    72
    virtual TDesC& GetDistrict()= 0;
hgs
parents:
diff changeset
    73
    
hgs
parents:
diff changeset
    74
    /*
hgs
parents:
diff changeset
    75
     * Gets the reference to the postal code. Scope of this returned reference is limited to
hgs
parents:
diff changeset
    76
     * this perticular call. User has to store it for their further processing.
hgs
parents:
diff changeset
    77
     * 
hgs
parents:
diff changeset
    78
     *  @return reference to the String which holds the postal code. 
hgs
parents:
diff changeset
    79
     */
hgs
parents:
diff changeset
    80
    virtual TDesC& GetPincode()= 0;
hgs
parents:
diff changeset
    81
    
hgs
parents:
diff changeset
    82
    /*
hgs
parents:
diff changeset
    83
     * Gets the reference to the thoroughfare name. Scope of this returned reference is limited to
hgs
parents:
diff changeset
    84
     * this perticular call. User has to store it for their further processing.
hgs
parents:
diff changeset
    85
     * 
hgs
parents:
diff changeset
    86
     *  @return reference to the String which holds the thoroughfare name. 
hgs
parents:
diff changeset
    87
     */
hgs
parents:
diff changeset
    88
    virtual TDesC& GetThoroughfareName()= 0;
hgs
parents:
diff changeset
    89
    
hgs
parents:
diff changeset
    90
    /*
hgs
parents:
diff changeset
    91
     * Gets the reference to the thoroughfare number. Scope of this returned reference is limited to
hgs
parents:
diff changeset
    92
     * this perticular call. User has to store it for their further processing.
hgs
parents:
diff changeset
    93
     * 
hgs
parents:
diff changeset
    94
     *  @return reference to the String which holds the thoroughfare number. 
hgs
parents:
diff changeset
    95
     */
hgs
parents:
diff changeset
    96
    virtual TDesC& GetThoroughfareNumber() = 0;
hgs
parents:
diff changeset
    97
    };
hgs
parents:
diff changeset
    98
/*
hgs
parents:
diff changeset
    99
 * Observer class which exposes callbacks to notify the completion of reversegeocoding event.
hgs
parents:
diff changeset
   100
 *
hgs
parents:
diff changeset
   101
 **/
hgs
parents:
diff changeset
   102
class MReverseGeocodeObserver
hgs
parents:
diff changeset
   103
    {
hgs
parents:
diff changeset
   104
    public:
hgs
parents:
diff changeset
   105
    /*
hgs
parents:
diff changeset
   106
     * Callback function which notifys the completion of reverse geocode event. This signals the completion
hgs
parents:
diff changeset
   107
     * of the asynchronous function CReverseGeoCode::GetAddressByCoordinate.
hgs
parents:
diff changeset
   108
     * 
hgs
parents:
diff changeset
   109
     *  @param aErrorcode Error status KErrNone in case of success or other system specific errorcodes
hgs
parents:
diff changeset
   110
     *                    in case of failures.
hgs
parents:
diff changeset
   111
     *                       
hgs
parents:
diff changeset
   112
     *  @param aAddressInfo refrence to the address stucture, through which user can access the
hgs
parents:
diff changeset
   113
     *                      address information. 
hgs
parents:
diff changeset
   114
     */
hgs
parents:
diff changeset
   115
hgs
parents:
diff changeset
   116
    virtual void ReverseGeocodeComplete( TInt& aErrorcode, MAddressInfo& aAddressInfo ) =0;
hgs
parents:
diff changeset
   117
hgs
parents:
diff changeset
   118
    /*
hgs
parents:
diff changeset
   119
    * Get registrer network country code
hgs
parents:
diff changeset
   120
    *
hgs
parents:
diff changeset
   121
    * @return current register n/w info
hgs
parents:
diff changeset
   122
    */
hgs
parents:
diff changeset
   123
    virtual RMobilePhone::TMobilePhoneNetworkInfoV2& GetCurrentRegisterNw() = 0;
hgs
parents:
diff changeset
   124
hgs
parents:
diff changeset
   125
    
hgs
parents:
diff changeset
   126
    /*
hgs
parents:
diff changeset
   127
    * UE is registered to home network?
hgs
parents:
diff changeset
   128
    *
hgs
parents:
diff changeset
   129
    * @return ETrue if UE is registered at home network else EFalse
hgs
parents:
diff changeset
   130
    */
hgs
parents:
diff changeset
   131
    virtual TBool IsRegisteredAtHomeNetwork() = 0;
hgs
parents:
diff changeset
   132
hgs
parents:
diff changeset
   133
    /*
hgs
parents:
diff changeset
   134
    * Get home network country code
hgs
parents:
diff changeset
   135
    * @param aHomeNwInfoAvailableFlag ETrue if home n/w info available else EFalse
hgs
parents:
diff changeset
   136
    * @return user home n/w info
hgs
parents:
diff changeset
   137
    */
hgs
parents:
diff changeset
   138
    virtual const RMobilePhone::TMobilePhoneNetworkInfoV1& 
hgs
parents:
diff changeset
   139
        GetHomeNetworkInfo(TBool& aHomeNwInfoAvailableFlag) = 0;
hgs
parents:
diff changeset
   140
    };
hgs
parents:
diff changeset
   141
hgs
parents:
diff changeset
   142
hgs
parents:
diff changeset
   143
/**
hgs
parents:
diff changeset
   144
 * CReverseGeoCoderPlugin
hgs
parents:
diff changeset
   145
 *
hgs
parents:
diff changeset
   146
 * An implementation of the CReverseGeoCoderPlugin definition. 
hgs
parents:
diff changeset
   147
 *              Encapsulates the reverse goecoding functionality
hgs
parents:
diff changeset
   148
 *              This is concrete class, instance of which
hgs
parents:
diff changeset
   149
 *              ECOM framework gives to ECOM clients.
hgs
parents:
diff changeset
   150
 */
hgs
parents:
diff changeset
   151
class CReverseGeoCoderPlugin : public CBase
hgs
parents:
diff changeset
   152
	{
hgs
parents:
diff changeset
   153
public:
hgs
parents:
diff changeset
   154
	
hgs
parents:
diff changeset
   155
	/**
hgs
parents:
diff changeset
   156
	* Create instance of concrete implementation. 
hgs
parents:
diff changeset
   157
	* @return: Instance of this class.
hgs
parents:
diff changeset
   158
	*/
hgs
parents:
diff changeset
   159
	static CReverseGeoCoderPlugin* NewL();
hgs
parents:
diff changeset
   160
hgs
parents:
diff changeset
   161
hgs
parents:
diff changeset
   162
	/**
hgs
parents:
diff changeset
   163
	* Destructor.
hgs
parents:
diff changeset
   164
	*/
hgs
parents:
diff changeset
   165
	virtual ~CReverseGeoCoderPlugin();
hgs
parents:
diff changeset
   166
hgs
parents:
diff changeset
   167
hgs
parents:
diff changeset
   168
public:
hgs
parents:
diff changeset
   169
	
hgs
parents:
diff changeset
   170
	/**
hgs
parents:
diff changeset
   171
	 * Creates the instance of Reverse Geocoder
hgs
parents:
diff changeset
   172
	 * 
hgs
parents:
diff changeset
   173
	 */
hgs
parents:
diff changeset
   174
	virtual void CreateReverseGeoCoderL() = 0;
hgs
parents:
diff changeset
   175
hgs
parents:
diff changeset
   176
	/**
hgs
parents:
diff changeset
   177
	 * Initializes the ReverseGeoCodeObserver
hgs
parents:
diff changeset
   178
	 * @param: aObserver The observer class instance that is to be notified when reverse geocoding completes
hgs
parents:
diff changeset
   179
	 * 
hgs
parents:
diff changeset
   180
	 */
hgs
parents:
diff changeset
   181
    virtual void AddObserverL(MReverseGeocodeObserver& aObserver)=0;
hgs
parents:
diff changeset
   182
hgs
parents:
diff changeset
   183
	/**
hgs
parents:
diff changeset
   184
	 * A wrapper API to fetch the address from geocoordinates
hgs
parents:
diff changeset
   185
	 * Internally calls the ReverseGeoCoder
hgs
parents:
diff changeset
   186
	 * @param aLocality A TLocality object that contains the geocoordinate information
hgs
parents:
diff changeset
   187
	 * @param aOption Indicates if the connection is silent connection or not
hgs
parents:
diff changeset
   188
	 * 
hgs
parents:
diff changeset
   189
	 */
hgs
parents:
diff changeset
   190
    virtual void GetAddressByCoordinateL( TLocality aLocality,const TConnectionOption aOption )=0;
hgs
parents:
diff changeset
   191
hgs
parents:
diff changeset
   192
	/**
hgs
parents:
diff changeset
   193
	 * Wrapper API to check if the ReverseGeoCoder allows a silent connection
hgs
parents:
diff changeset
   194
	 * @return:TBool Indicates if a silent connection is allowed
hgs
parents:
diff changeset
   195
	 * 
hgs
parents:
diff changeset
   196
	 */
hgs
parents:
diff changeset
   197
	  virtual TBool SilentConnectionAllowed() = 0;
hgs
parents:
diff changeset
   198
	
hgs
parents:
diff changeset
   199
private:
hgs
parents:
diff changeset
   200
	
hgs
parents:
diff changeset
   201
	TUid iDtorKey;
hgs
parents:
diff changeset
   202
hgs
parents:
diff changeset
   203
	};
hgs
parents:
diff changeset
   204
#include "reversegeocoderplugin.inl"
hgs
parents:
diff changeset
   205
hgs
parents:
diff changeset
   206
#endif //__REVERSEGEOCODERPLUGIN_H__
hgs
parents:
diff changeset
   207
hgs
parents:
diff changeset
   208
//End of file
hgs
parents:
diff changeset
   209