classicui_plat/editors_api/inc/aknipfed.h
author hgs
Tue, 17 Aug 2010 18:16:43 +0800
changeset 53 3c67ea82fafc
parent 45 667edd0b8678
permissions -rw-r--r--
201033
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
45
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2002-2006 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 CAknIpFieldEditor class implements an editor for an 
hgs
parents:
diff changeset
    15
*                IP address.
hgs
parents:
diff changeset
    16
*
hgs
parents:
diff changeset
    17
*/
hgs
parents:
diff changeset
    18
hgs
parents:
diff changeset
    19
hgs
parents:
diff changeset
    20
#if !defined(__AKNIPFED_H_)
hgs
parents:
diff changeset
    21
#define __AKNIPFED_H_
hgs
parents:
diff changeset
    22
hgs
parents:
diff changeset
    23
// INCLUDES
hgs
parents:
diff changeset
    24
#include <eikmfne.h>
hgs
parents:
diff changeset
    25
hgs
parents:
diff changeset
    26
// FORWARD DECLERATIONS
hgs
parents:
diff changeset
    27
class TInetAddr;
hgs
parents:
diff changeset
    28
hgs
parents:
diff changeset
    29
//CLASS DECLERATION
hgs
parents:
diff changeset
    30
/**
hgs
parents:
diff changeset
    31
 * The @c CAknIpFieldEditor class implements an editor for an IP address.
hgs
parents:
diff changeset
    32
 * Based on Crystal @c CCknIpFieldEditor.
hgs
parents:
diff changeset
    33
 * 
hgs
parents:
diff changeset
    34
 * @since Series 60 0.9 
hgs
parents:
diff changeset
    35
 */
hgs
parents:
diff changeset
    36
class CAknIpFieldEditor : public CEikMfne 
hgs
parents:
diff changeset
    37
    {
hgs
parents:
diff changeset
    38
public: // public constructors
hgs
parents:
diff changeset
    39
hgs
parents:
diff changeset
    40
    /**
hgs
parents:
diff changeset
    41
    * C++ default constructor.
hgs
parents:
diff changeset
    42
    */
hgs
parents:
diff changeset
    43
	IMPORT_C CAknIpFieldEditor();
hgs
parents:
diff changeset
    44
hgs
parents:
diff changeset
    45
    /**
hgs
parents:
diff changeset
    46
    * Two phased constructor.
hgs
parents:
diff changeset
    47
    * @param aMinimumAddress Reference to a @c TInetAddr struct. Defines lower 
hgs
parents:
diff changeset
    48
    * limits for IP editor fields.
hgs
parents:
diff changeset
    49
    * @param aMaximumAddress Reference to a @c TInetAddr struct. Defines upper 
hgs
parents:
diff changeset
    50
    * limits for IP editor fields.
hgs
parents:
diff changeset
    51
    * @param aInitialAddress Reference to a @c TInetAddr struct. Defines the 
hgs
parents:
diff changeset
    52
    * initial address of the IP editor.
hgs
parents:
diff changeset
    53
    * @param aFlags The number field's flags. Default is 0.
hgs
parents:
diff changeset
    54
    * @return Pointer to the fully constructed @c CAknIpFieldEditor object.
hgs
parents:
diff changeset
    55
    */
hgs
parents:
diff changeset
    56
	void ConstructL(TInetAddr& aMinimumAddress,
hgs
parents:
diff changeset
    57
                    TInetAddr& aMaximumAddress,
hgs
parents:
diff changeset
    58
                    TInetAddr& aInitialAddress,
hgs
parents:
diff changeset
    59
                    const TInt aFlags=0);
hgs
parents:
diff changeset
    60
hgs
parents:
diff changeset
    61
    /**
hgs
parents:
diff changeset
    62
    * Two phased constructor.
hgs
parents:
diff changeset
    63
    * Constructs a CAknIpFieldEditor object using given parameters.
hgs
parents:
diff changeset
    64
    * @param aMinimumAddress Reference to a @c TInetAddr struct. Defines lower
hgs
parents:
diff changeset
    65
    * limits for IP editor fields.
hgs
parents:
diff changeset
    66
    * @param aMaximumAddress Reference to a @c TInetAddr struct. Defines upper
hgs
parents:
diff changeset
    67
    * limits for IP editor fields.
hgs
parents:
diff changeset
    68
    * @param aInitialAddress Reference to a @c TInetAddr struct. Defines the 
hgs
parents:
diff changeset
    69
    * initial address of the IP editor.
hgs
parents:
diff changeset
    70
    * @return Pointer to the fully constructed @c CAknIpFieldEditor object.
hgs
parents:
diff changeset
    71
    */
hgs
parents:
diff changeset
    72
	IMPORT_C static CAknIpFieldEditor* NewL(TInetAddr& aMinimumAddress,
hgs
parents:
diff changeset
    73
                                            TInetAddr& aMaximumAddress,
hgs
parents:
diff changeset
    74
                                            TInetAddr& aInitialAddress);
hgs
parents:
diff changeset
    75
	
hgs
parents:
diff changeset
    76
	/**
hgs
parents:
diff changeset
    77
	* Two phased constructor.
hgs
parents:
diff changeset
    78
	* Requires a call for @c ConstructFromResourcesL() method to finish 
hgs
parents:
diff changeset
    79
	* construction.
hgs
parents:
diff changeset
    80
	* @return Pointer to the constructed @c CAknIpFieldEditor object.
hgs
parents:
diff changeset
    81
	*/
hgs
parents:
diff changeset
    82
	IMPORT_C static CAknIpFieldEditor* NewL();
hgs
parents:
diff changeset
    83
	
hgs
parents:
diff changeset
    84
public: // Methods for getting and setting values
hgs
parents:
diff changeset
    85
hgs
parents:
diff changeset
    86
	        
hgs
parents:
diff changeset
    87
    /**
hgs
parents:
diff changeset
    88
 	* Sets the editor's value dynamically.
hgs
parents:
diff changeset
    89
    * @param aAddress Reference to a @c TInetAddr struct including the new 
hgs
parents:
diff changeset
    90
    * address.
hgs
parents:
diff changeset
    91
    */
hgs
parents:
diff changeset
    92
	IMPORT_C void SetAddress(const TInetAddr& aAddress);
hgs
parents:
diff changeset
    93
	
hgs
parents:
diff changeset
    94
    /**
hgs
parents:
diff changeset
    95
    * Gets the editor's value.
hgs
parents:
diff changeset
    96
    * @return TInetAddr struct including the address.
hgs
parents:
diff changeset
    97
    */
hgs
parents:
diff changeset
    98
	IMPORT_C TInetAddr Address() const;
hgs
parents:
diff changeset
    99
	
hgs
parents:
diff changeset
   100
	/**
hgs
parents:
diff changeset
   101
    * Sets the minimum and maximum editor values.
hgs
parents:
diff changeset
   102
    * @param aMinimumAddress Reference to a @c TInetAddr struct defining the
hgs
parents:
diff changeset
   103
    * lower limits of the editor fields.
hgs
parents:
diff changeset
   104
    * @param aMaximumAddress Reference to a @c TInetAddr struct defining the
hgs
parents:
diff changeset
   105
    * upper limits of the editor fields.
hgs
parents:
diff changeset
   106
    */
hgs
parents:
diff changeset
   107
	IMPORT_C virtual void SetMinimumAndMaximum(
hgs
parents:
diff changeset
   108
	                                    const TInetAddr& aMinimumAddress,
hgs
parents:
diff changeset
   109
                                        const TInetAddr& aMaximumAddress); // only values inside the initial minimum and maximum are permitted
hgs
parents:
diff changeset
   110
hgs
parents:
diff changeset
   111
    /**
hgs
parents:
diff changeset
   112
    * Gets the minimum and maximum editor values.
hgs
parents:
diff changeset
   113
    * @param aMinimumAddress Reference to a @c TInetAddr struct in which the
hgs
parents:
diff changeset
   114
    * lower limits are wanted to be returned.
hgs
parents:
diff changeset
   115
    * @param aMaximumAddress Reference to a @c TInetAddr struct in which the
hgs
parents:
diff changeset
   116
    * upper limits are wanted to be returned.
hgs
parents:
diff changeset
   117
    */
hgs
parents:
diff changeset
   118
	IMPORT_C virtual void GetMinimumAndMaximum(
hgs
parents:
diff changeset
   119
	                                    TInetAddr& aMinimumAddress,
hgs
parents:
diff changeset
   120
                                        TInetAddr& aMaximumAddress) const;
hgs
parents:
diff changeset
   121
    
hgs
parents:
diff changeset
   122
    /**
hgs
parents:
diff changeset
   123
    * Gets an IP address from resources.
hgs
parents:
diff changeset
   124
    * @param aResourceReader  Reference to a resource reader associated to the
hgs
parents:
diff changeset
   125
    * @c IP_FIELD resource.
hgs
parents:
diff changeset
   126
    * @return TInetAddr struct including the address.
hgs
parents:
diff changeset
   127
    */
hgs
parents:
diff changeset
   128
	IMPORT_C TInetAddr ReadIPAddress(TResourceReader& aResourceReader);
hgs
parents:
diff changeset
   129
	
hgs
parents:
diff changeset
   130
public: // from CCoeControl
hgs
parents:
diff changeset
   131
hgs
parents:
diff changeset
   132
	/**
hgs
parents:
diff changeset
   133
    * From @c CCoeControl. Constructs controls from a resource file.
hgs
parents:
diff changeset
   134
    * Essential for Dialog/Form construction.
hgs
parents:
diff changeset
   135
    * @param aResourceReader The resource reader with which to access 
hgs
parents:
diff changeset
   136
    * @c IP_FIELD_EDITOR
hgs
parents:
diff changeset
   137
    * resource.
hgs
parents:
diff changeset
   138
    */
hgs
parents:
diff changeset
   139
	IMPORT_C void ConstructFromResourceL(TResourceReader& aResourceReader);
hgs
parents:
diff changeset
   140
	
hgs
parents:
diff changeset
   141
	/**
hgs
parents:
diff changeset
   142
    * From @c CCoeControl. Handles key events.
hgs
parents:
diff changeset
   143
    * Called by framework when a key event occurs.
hgs
parents:
diff changeset
   144
    * @param aKeyEvent The key event that occured.
hgs
parents:
diff changeset
   145
	* @param aType The type of key event that occured.
hgs
parents:
diff changeset
   146
    * @return @c EKeyWasConsumed if the event was processed, 
hgs
parents:
diff changeset
   147
    * @c EKeyWasNotConsumed if the event was not processed
hgs
parents:
diff changeset
   148
    */
hgs
parents:
diff changeset
   149
	IMPORT_C TKeyResponse OfferKeyEventL(const TKeyEvent& aKeyEvent,
hgs
parents:
diff changeset
   150
	                                     TEventCode aType);
hgs
parents:
diff changeset
   151
    IMPORT_C void HandlePointerEventL(const TPointerEvent& aPointerEvent);	
hgs
parents:
diff changeset
   152
private:
hgs
parents:
diff changeset
   153
    /**
hgs
parents:
diff changeset
   154
    * From CAknControl
hgs
parents:
diff changeset
   155
    */
hgs
parents:
diff changeset
   156
    IMPORT_C void* ExtensionInterface( TUid aInterface );
hgs
parents:
diff changeset
   157
private: 
hgs
parents:
diff changeset
   158
   void SplitAddressIntoFields(
hgs
parents:
diff changeset
   159
                                const TInetAddr& aAddress,
hgs
parents:
diff changeset
   160
                                TUint8 &aFieldA,
hgs
parents:
diff changeset
   161
                                TUint8 &aFieldB,
hgs
parents:
diff changeset
   162
                                TUint8 &aFieldC,
hgs
parents:
diff changeset
   163
                                TUint8 &aFieldD) const;
hgs
parents:
diff changeset
   164
	IMPORT_C virtual void CEikMfne_Reserved();
hgs
parents:
diff changeset
   165
hgs
parents:
diff changeset
   166
private:
hgs
parents:
diff changeset
   167
    TInt iSpare;
hgs
parents:
diff changeset
   168
    TInt iSpare2;
hgs
parents:
diff changeset
   169
	};
hgs
parents:
diff changeset
   170
hgs
parents:
diff changeset
   171
hgs
parents:
diff changeset
   172
#endif