classicui_plat/editors_api/inc/AknLocationEd.h
author hgs
Tue, 31 Aug 2010 21:12:01 +0800
changeset 54 4e76f14a5917
parent 45 667edd0b8678
permissions -rw-r--r--
201035
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
45
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2006-2007 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:  Location editors 
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
#ifndef AKNLOCATIONED_H
hgs
parents:
diff changeset
    19
#define AKNLOCATIONED_H
hgs
parents:
diff changeset
    20
hgs
parents:
diff changeset
    21
#include <eikmfne.h>
hgs
parents:
diff changeset
    22
hgs
parents:
diff changeset
    23
class TPosition;
hgs
parents:
diff changeset
    24
class CLocationStrings;
hgs
parents:
diff changeset
    25
/**
hgs
parents:
diff changeset
    26
 * Editor for TPosition type; latitude and longitude editor
hgs
parents:
diff changeset
    27
 *
hgs
parents:
diff changeset
    28
 * There exists two ways to construct CAknLocationEditor:
hgs
parents:
diff changeset
    29
 *
hgs
parents:
diff changeset
    30
 * @code
hgs
parents:
diff changeset
    31
 * CAknLocationEditor *editor = CAknLocationEditor::NewL(pos, context);
hgs
parents:
diff changeset
    32
 * @endcode
hgs
parents:
diff changeset
    33
 * 
hgs
parents:
diff changeset
    34
 * Using resources:
hgs
parents:
diff changeset
    35
 *
hgs
parents:
diff changeset
    36
 * @code
hgs
parents:
diff changeset
    37
 * CAknLocationEditor *editor = new (ELeave) CAknLocationEditor
hgs
parents:
diff changeset
    38
 * TResourceReader reader;
hgs
parents:
diff changeset
    39
 * iCoeEnv->CreateResourceReaderLC(reader,R_RES_ID_FOR_EDITOR);
hgs
parents:
diff changeset
    40
 * editor->ConstructFromResourceL(reader);
hgs
parents:
diff changeset
    41
 * editor->Set(pos);
hgs
parents:
diff changeset
    42
 * CleanupStack::PopAndDestroy();
hgs
parents:
diff changeset
    43
 * @endcode
hgs
parents:
diff changeset
    44
 * 
hgs
parents:
diff changeset
    45
 * Resource file format is as follows:
hgs
parents:
diff changeset
    46
 * @code
hgs
parents:
diff changeset
    47
 *     LATITUDE_EDITOR
hgs
parents:
diff changeset
    48
 *        {
hgs
parents:
diff changeset
    49
 *	      flags = ELocationEdFlagLatitude;
hgs
parents:
diff changeset
    50
 *		  latlongresourceid = R_EIK_LATITUDE_AND_LONGITUDE;
hgs
parents:
diff changeset
    51
 *        };
hgs
parents:
diff changeset
    52
 * @endcode
hgs
parents:
diff changeset
    53
 *  or:
hgs
parents:
diff changeset
    54
 * @code
hgs
parents:
diff changeset
    55
 *      LONGITUDE_EDITOR
hgs
parents:
diff changeset
    56
 *        {
hgs
parents:
diff changeset
    57
 *		  flags = ELocationEdFlagLongitude;
hgs
parents:
diff changeset
    58
 *		  latlongresourceid = R_EIK_LATITUDE_AND_LONGITUDE;
hgs
parents:
diff changeset
    59
 *        };
hgs
parents:
diff changeset
    60
 * @endcode
hgs
parents:
diff changeset
    61
 *
hgs
parents:
diff changeset
    62
 *  @lib eikctl.lib
hgs
parents:
diff changeset
    63
 *  @lib lbs.lib (for TPosition class)
hgs
parents:
diff changeset
    64
 *  @since 3.2
hgs
parents:
diff changeset
    65
 *  @see TPosition
hgs
parents:
diff changeset
    66
 */
hgs
parents:
diff changeset
    67
class CAknLocationEditor : public CEikMfne
hgs
parents:
diff changeset
    68
	{
hgs
parents:
diff changeset
    69
public:
hgs
parents:
diff changeset
    70
	/**
hgs
parents:
diff changeset
    71
	 * TLocationContext determines what part of TPosition class is used for this editor.
hgs
parents:
diff changeset
    72
     *  ELongitudeOnly means only longitude part of TPosition is used.
hgs
parents:
diff changeset
    73
     *  ELatitudeOnly means only latitude part of TPosition is used.
hgs
parents:
diff changeset
    74
	 */
hgs
parents:
diff changeset
    75
	enum TLocationContext
hgs
parents:
diff changeset
    76
		{
hgs
parents:
diff changeset
    77
		ELongitudeOnly = 0x1,
hgs
parents:
diff changeset
    78
		ELatitudeOnly  = 0x2
hgs
parents:
diff changeset
    79
		};
hgs
parents:
diff changeset
    80
    /**
hgs
parents:
diff changeset
    81
     * Constructor
hgs
parents:
diff changeset
    82
     */
hgs
parents:
diff changeset
    83
	IMPORT_C CAknLocationEditor();
hgs
parents:
diff changeset
    84
    /**
hgs
parents:
diff changeset
    85
     * Destructor
hgs
parents:
diff changeset
    86
     */
hgs
parents:
diff changeset
    87
	IMPORT_C ~CAknLocationEditor();
hgs
parents:
diff changeset
    88
    /**
hgs
parents:
diff changeset
    89
     * NewL()
hgs
parents:
diff changeset
    90
     *    Creates location editor and initializes it's value to value determined by the aValue parameter.
hgs
parents:
diff changeset
    91
	 *
hgs
parents:
diff changeset
    92
     * @param aValue Initial value for location editor.
hgs
parents:
diff changeset
    93
     * @param aContext Which part of the TPosition is used for this location editor
hgs
parents:
diff changeset
    94
     */
hgs
parents:
diff changeset
    95
	IMPORT_C static CAknLocationEditor* NewL( TPosition &aValue, TLocationContext aContext );
hgs
parents:
diff changeset
    96
hgs
parents:
diff changeset
    97
	/**
hgs
parents:
diff changeset
    98
	 * ConstructFromResourceL
hgs
parents:
diff changeset
    99
     *     Constructs location editor using information from resource files
hgs
parents:
diff changeset
   100
     *
hgs
parents:
diff changeset
   101
     * @param aResourceReader resource reader
hgs
parents:
diff changeset
   102
	 */
hgs
parents:
diff changeset
   103
	IMPORT_C void ConstructFromResourceL( TResourceReader& aResourceReader );
hgs
parents:
diff changeset
   104
hgs
parents:
diff changeset
   105
	/**
hgs
parents:
diff changeset
   106
	 * DisplayableLocationL()
hgs
parents:
diff changeset
   107
	 *    Converts TPosition into displayable descriptor usable for listboxes
hgs
parents:
diff changeset
   108
     *
hgs
parents:
diff changeset
   109
	 * @param aValue value of the location
hgs
parents:
diff changeset
   110
	 * @param aContext which part of the TPosition is used
hgs
parents:
diff changeset
   111
	 */
hgs
parents:
diff changeset
   112
	IMPORT_C static HBufC* DisplayableLocationL( const TPosition &aValue, TLocationContext aContext );
hgs
parents:
diff changeset
   113
hgs
parents:
diff changeset
   114
hgs
parents:
diff changeset
   115
    /**
hgs
parents:
diff changeset
   116
     * PrepareForFocusLossL()
hgs
parents:
diff changeset
   117
     *     detects focus changes to validate editor contents
hgs
parents:
diff changeset
   118
     */
hgs
parents:
diff changeset
   119
	IMPORT_C virtual void PrepareForFocusLossL();
hgs
parents:
diff changeset
   120
hgs
parents:
diff changeset
   121
	/**
hgs
parents:
diff changeset
   122
     * Set()
hgs
parents:
diff changeset
   123
     *     Sets either longitude or latitude values of aValue
hgs
parents:
diff changeset
   124
     *
hgs
parents:
diff changeset
   125
	 *  @param aValue new value for the editor
hgs
parents:
diff changeset
   126
     */
hgs
parents:
diff changeset
   127
	IMPORT_C void Set(const TPosition &aValue);
hgs
parents:
diff changeset
   128
	/**
hgs
parents:
diff changeset
   129
	 * Get()
hgs
parents:
diff changeset
   130
     *      Gets either longitude or latitude values of aValue
hgs
parents:
diff changeset
   131
     *
hgs
parents:
diff changeset
   132
     * @param aValue TPosition object that will be modified
hgs
parents:
diff changeset
   133
     */
hgs
parents:
diff changeset
   134
	IMPORT_C void Get( TPosition &aValue ) const;
hgs
parents:
diff changeset
   135
	/**
hgs
parents:
diff changeset
   136
	 * OfferKeyEventL()
hgs
parents:
diff changeset
   137
	 *         key event handling of location editor
hgs
parents:
diff changeset
   138
	 */
hgs
parents:
diff changeset
   139
	IMPORT_C TKeyResponse OfferKeyEventL(const TKeyEvent& aKeyEvent, TEventCode aType);
hgs
parents:
diff changeset
   140
private:
hgs
parents:
diff changeset
   141
	enum TLocationType
hgs
parents:
diff changeset
   142
		{
hgs
parents:
diff changeset
   143
		EDD,
hgs
parents:
diff changeset
   144
		EDMM,
hgs
parents:
diff changeset
   145
		EDMSD
hgs
parents:
diff changeset
   146
		};
hgs
parents:
diff changeset
   147
	TLocationType Type() const;
hgs
parents:
diff changeset
   148
	static void Split( const TPosition &aValue, 
hgs
parents:
diff changeset
   149
					   TLocationContext aContext, 
hgs
parents:
diff changeset
   150
					   TInt &aDegrees, 
hgs
parents:
diff changeset
   151
					   TInt &aDeciDegrees, 
hgs
parents:
diff changeset
   152
					   TInt &aMinutes, 
hgs
parents:
diff changeset
   153
					   TInt &aDeciMinutes, 
hgs
parents:
diff changeset
   154
					   TInt &aSeconds, 
hgs
parents:
diff changeset
   155
					   TInt &aDeciSeconds, 
hgs
parents:
diff changeset
   156
					   TBool &aNeg, 
hgs
parents:
diff changeset
   157
					   TBool &aNan );
hgs
parents:
diff changeset
   158
	static void SplitDD( const TPosition &aValue, 
hgs
parents:
diff changeset
   159
						 TLocationContext aContext, 
hgs
parents:
diff changeset
   160
						 TInt &aDegrees,
hgs
parents:
diff changeset
   161
						 TInt &aDeciDegrees, 
hgs
parents:
diff changeset
   162
						 TBool &aNeg, 
hgs
parents:
diff changeset
   163
						 TBool &aNan );
hgs
parents:
diff changeset
   164
	static void SplitDMM( const TPosition &aValue, 
hgs
parents:
diff changeset
   165
	                      TLocationContext aContext, 
hgs
parents:
diff changeset
   166
	                      TInt &aDegrees, 
hgs
parents:
diff changeset
   167
	                      TInt &aMinutes, 
hgs
parents:
diff changeset
   168
	                      TInt &aDeciMinutes, 
hgs
parents:
diff changeset
   169
	                      TBool &aNeg, 
hgs
parents:
diff changeset
   170
	                      TBool &aNan );
hgs
parents:
diff changeset
   171
	static void SplitDMSD( const TPosition &aValue, 
hgs
parents:
diff changeset
   172
						   TLocationContext aContext, 
hgs
parents:
diff changeset
   173
						   TInt &aDegrees, 
hgs
parents:
diff changeset
   174
						   TInt &aMinutes, 
hgs
parents:
diff changeset
   175
						   TInt &aSeconds, 
hgs
parents:
diff changeset
   176
						   TInt &aDeciSeconds, 
hgs
parents:
diff changeset
   177
						   TBool &aNeg, 
hgs
parents:
diff changeset
   178
						   TBool &aNan );
hgs
parents:
diff changeset
   179
	static void CombineDD( TPosition &aValue, 
hgs
parents:
diff changeset
   180
						   TLocationContext aContext, 
hgs
parents:
diff changeset
   181
						   TInt aDegrees, 
hgs
parents:
diff changeset
   182
						   TInt aDeciDegrees, 
hgs
parents:
diff changeset
   183
						   TBool aNeg, 
hgs
parents:
diff changeset
   184
						   TBool aNan );
hgs
parents:
diff changeset
   185
	static void CombineDMM( TPosition &aValue, 
hgs
parents:
diff changeset
   186
							TLocationContext aContext, 
hgs
parents:
diff changeset
   187
							TInt aDegrees, 
hgs
parents:
diff changeset
   188
							TInt aMinutes, 
hgs
parents:
diff changeset
   189
							TInt aDeciMinutes, 
hgs
parents:
diff changeset
   190
							TBool aNeg, 
hgs
parents:
diff changeset
   191
							TBool aNan );
hgs
parents:
diff changeset
   192
	static void CombineDMSD( TPosition &aValue, 
hgs
parents:
diff changeset
   193
							 TLocationContext aContext, 
hgs
parents:
diff changeset
   194
							 TInt aDegrees, 
hgs
parents:
diff changeset
   195
							 TInt aMinutes, 
hgs
parents:
diff changeset
   196
							 TInt aSeconds, 
hgs
parents:
diff changeset
   197
							 TInt aDeciSeconds, 
hgs
parents:
diff changeset
   198
							 TBool aNeg, 
hgs
parents:
diff changeset
   199
							 TBool aNan );
hgs
parents:
diff changeset
   200
private:
hgs
parents:
diff changeset
   201
	void SetUninitialised(TBool aInitialised);
hgs
parents:
diff changeset
   202
	void RefreshFromLocale();
hgs
parents:
diff changeset
   203
	void ConstructL( TPosition &aValue, TLocationContext aContext );
hgs
parents:
diff changeset
   204
public:
hgs
parents:
diff changeset
   205
	void HandleCenRepChangedL(TUint32 aKey, TInt aValue);
hgs
parents:
diff changeset
   206
	void CreateMfneFieldsL(const TPosition &aValue);
hgs
parents:
diff changeset
   207
private:
hgs
parents:
diff changeset
   208
	void LoadStringsL( TInt aResourceId );
hgs
parents:
diff changeset
   209
	
hgs
parents:
diff changeset
   210
	/**
hgs
parents:
diff changeset
   211
	* Maps logical MFNE field order to correct visual order.
hgs
parents:
diff changeset
   212
	* @param aFieldNumber Field position in logical format.
hgs
parents:
diff changeset
   213
	* @param aType Used location editor format.
hgs
parents:
diff changeset
   214
	* @return Field position in visual format.
hgs
parents:
diff changeset
   215
	*/
hgs
parents:
diff changeset
   216
	TInt FieldMapping(const TInt aFieldNumber, const TLocationType aType) const;
hgs
parents:
diff changeset
   217
hgs
parents:
diff changeset
   218
protected:
hgs
parents:
diff changeset
   219
	IMPORT_C virtual void* CAknLocationEditor_ExtensionInterface( TUid aInterface ); 
hgs
parents:
diff changeset
   220
private:
hgs
parents:
diff changeset
   221
	CLocationStrings* iStrings;
hgs
parents:
diff changeset
   222
	TLocationContext iContext;
hgs
parents:
diff changeset
   223
	};
hgs
parents:
diff changeset
   224
hgs
parents:
diff changeset
   225
hgs
parents:
diff changeset
   226
#endif