mpx/tsrc/public/basic/common/testviewframework/inc/testmenuview.h
author hgs
Tue, 21 Sep 2010 11:25:55 -0500
changeset 62 b276843a15ba
permissions -rw-r--r--
201037
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
62
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2002 - 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:  part of testviewframework.
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
#ifndef TESTMENUVIEW_H
hgs
parents:
diff changeset
    19
#define TESTMENUVIEW_H
hgs
parents:
diff changeset
    20
hgs
parents:
diff changeset
    21
//INCLUDES
hgs
parents:
diff changeset
    22
#include <badesca.h>
hgs
parents:
diff changeset
    23
#include "testbaseview.h"
hgs
parents:
diff changeset
    24
hgs
parents:
diff changeset
    25
hgs
parents:
diff changeset
    26
// FORWARD DECLARATION
hgs
parents:
diff changeset
    27
class CConsoleMain;
hgs
parents:
diff changeset
    28
hgs
parents:
diff changeset
    29
// CLASS DECLARATION
hgs
parents:
diff changeset
    30
hgs
parents:
diff changeset
    31
/**
hgs
parents:
diff changeset
    32
*  Abstract View class - contains functions which must be derived
hgs
parents:
diff changeset
    33
*/
hgs
parents:
diff changeset
    34
class MTestMenuView
hgs
parents:
diff changeset
    35
    {
hgs
parents:
diff changeset
    36
    public:
hgs
parents:
diff changeset
    37
    
hgs
parents:
diff changeset
    38
        /**
hgs
parents:
diff changeset
    39
        * Handle number key press
hgs
parents:
diff changeset
    40
        * NOTE: Must be derived
hgs
parents:
diff changeset
    41
        */
hgs
parents:
diff changeset
    42
        virtual void HandleNumKeyL() = 0;
hgs
parents:
diff changeset
    43
        
hgs
parents:
diff changeset
    44
        /**
hgs
parents:
diff changeset
    45
        * Handle left key press
hgs
parents:
diff changeset
    46
        * NOTE: Must be derived
hgs
parents:
diff changeset
    47
        */
hgs
parents:
diff changeset
    48
        virtual void HandleLeftKeyL() = 0;
hgs
parents:
diff changeset
    49
        
hgs
parents:
diff changeset
    50
        /**
hgs
parents:
diff changeset
    51
        * Handle right/enter key press
hgs
parents:
diff changeset
    52
        * NOTE: Must be derived
hgs
parents:
diff changeset
    53
        */
hgs
parents:
diff changeset
    54
        virtual void HandleRightKeyL() = 0;
hgs
parents:
diff changeset
    55
    };
hgs
parents:
diff changeset
    56
hgs
parents:
diff changeset
    57
/**
hgs
parents:
diff changeset
    58
*  Menu View class - Console base
hgs
parents:
diff changeset
    59
*/
hgs
parents:
diff changeset
    60
class CTestMenuView :public CTestBaseView, public MTestMenuView
hgs
parents:
diff changeset
    61
    {
hgs
parents:
diff changeset
    62
    public:
hgs
parents:
diff changeset
    63
        /**
hgs
parents:
diff changeset
    64
        * Destructor
hgs
parents:
diff changeset
    65
        */
hgs
parents:
diff changeset
    66
        IMPORT_C virtual ~CTestMenuView();
hgs
parents:
diff changeset
    67
hgs
parents:
diff changeset
    68
        
hgs
parents:
diff changeset
    69
    public: //Implement abstract function from base classes
hgs
parents:
diff changeset
    70
        /** 
hgs
parents:
diff changeset
    71
        * From: CTestBaseView
hgs
parents:
diff changeset
    72
        * Display view
hgs
parents:
diff changeset
    73
        */
hgs
parents:
diff changeset
    74
        IMPORT_C void DisplayViewL();
hgs
parents:
diff changeset
    75
hgs
parents:
diff changeset
    76
        /** 
hgs
parents:
diff changeset
    77
        * From: CTestBaseView
hgs
parents:
diff changeset
    78
        * Process keypresses on this menu - called by ConsoleMain
hgs
parents:
diff changeset
    79
        * @param aSelection, key pressed
hgs
parents:
diff changeset
    80
        * @param aContinue, whether to continue or stop scheduler
hgs
parents:
diff changeset
    81
        */
hgs
parents:
diff changeset
    82
        IMPORT_C void SelectL( TKeyCode aSelection, TBool& aContinue );
hgs
parents:
diff changeset
    83
hgs
parents:
diff changeset
    84
        /** 
hgs
parents:
diff changeset
    85
        * From: CTestBaseView
hgs
parents:
diff changeset
    86
        * Update display from timer - called by ConsoleMain
hgs
parents:
diff changeset
    87
        */
hgs
parents:
diff changeset
    88
        IMPORT_C void TimerUpdate();
hgs
parents:
diff changeset
    89
    
hgs
parents:
diff changeset
    90
hgs
parents:
diff changeset
    91
    protected:
hgs
parents:
diff changeset
    92
    
hgs
parents:
diff changeset
    93
        /**
hgs
parents:
diff changeset
    94
        * C++ default constructor
hgs
parents:
diff changeset
    95
        */
hgs
parents:
diff changeset
    96
        IMPORT_C CTestMenuView(CConsoleMain* aConsoleMain,
hgs
parents:
diff changeset
    97
                         CTestBaseView* aParent,
hgs
parents:
diff changeset
    98
                         const TDesC& aName);
hgs
parents:
diff changeset
    99
hgs
parents:
diff changeset
   100
        
hgs
parents:
diff changeset
   101
        /**
hgs
parents:
diff changeset
   102
        * NOTE: This function must be call within deriving class ConstructL
hgs
parents:
diff changeset
   103
        * the second phase constructor ConstructL to safely construct things 
hgs
parents:
diff changeset
   104
        * that can leave 
hgs
parents:
diff changeset
   105
        * @param aConsole, console to display menu
hgs
parents:
diff changeset
   106
        * @param aParent, parent menu
hgs
parents:
diff changeset
   107
        * @param aName, name of current menu to be set
hgs
parents:
diff changeset
   108
        * @param aLastMenu, whether the current has child menu
hgs
parents:
diff changeset
   109
        */
hgs
parents:
diff changeset
   110
        IMPORT_C void ConstructL();
hgs
parents:
diff changeset
   111
                         
hgs
parents:
diff changeset
   112
    protected:
hgs
parents:
diff changeset
   113
        /** 
hgs
parents:
diff changeset
   114
        * Print line
hgs
parents:
diff changeset
   115
        * @param aPrint, descriptor of message to be printed
hgs
parents:
diff changeset
   116
        */
hgs
parents:
diff changeset
   117
        IMPORT_C void Print( const TDesC& aPrint);
hgs
parents:
diff changeset
   118
hgs
parents:
diff changeset
   119
        /** 
hgs
parents:
diff changeset
   120
        * Multi line print if message exceeds one line
hgs
parents:
diff changeset
   121
        * @param aPrint, descriptor of message to be printed
hgs
parents:
diff changeset
   122
        */
hgs
parents:
diff changeset
   123
        IMPORT_C void PrintMulti( const TDesC& aPrint );
hgs
parents:
diff changeset
   124
hgs
parents:
diff changeset
   125
        /** 
hgs
parents:
diff changeset
   126
        * Add item to menu
hgs
parents:
diff changeset
   127
        * @param aItem, item of current menu
hgs
parents:
diff changeset
   128
        */
hgs
parents:
diff changeset
   129
        IMPORT_C void AddItemL ( const TDesC& aItem );
hgs
parents:
diff changeset
   130
        
hgs
parents:
diff changeset
   131
        /** 
hgs
parents:
diff changeset
   132
        * Delete an item from menu
hgs
parents:
diff changeset
   133
        * @param aIndex, index of item to be deleted
hgs
parents:
diff changeset
   134
        */
hgs
parents:
diff changeset
   135
        IMPORT_C void DeleteItem ( TInt aIndex );
hgs
parents:
diff changeset
   136
hgs
parents:
diff changeset
   137
        /**
hgs
parents:
diff changeset
   138
        * Get last key pressed
hgs
parents:
diff changeset
   139
        * @return code of last key pressed
hgs
parents:
diff changeset
   140
        */
hgs
parents:
diff changeset
   141
        IMPORT_C TKeyCode LastKeyPressed();
hgs
parents:
diff changeset
   142
hgs
parents:
diff changeset
   143
        /**
hgs
parents:
diff changeset
   144
        * Determine whether there are items added to iItems
hgs
parents:
diff changeset
   145
        * @return whether item is empty
hgs
parents:
diff changeset
   146
        */
hgs
parents:
diff changeset
   147
        IMPORT_C TBool ItemsCreated();
hgs
parents:
diff changeset
   148
hgs
parents:
diff changeset
   149
        /**
hgs
parents:
diff changeset
   150
        * Get the position that the cursor is point to in the items
hgs
parents:
diff changeset
   151
        * @return index of current cursor pointing item in iItems
hgs
parents:
diff changeset
   152
        */
hgs
parents:
diff changeset
   153
        IMPORT_C TInt CurrentIndex();
hgs
parents:
diff changeset
   154
hgs
parents:
diff changeset
   155
        /**
hgs
parents:
diff changeset
   156
        * Get the position that the cursor is point to on the screen
hgs
parents:
diff changeset
   157
        * @return index of current cursor pointing item on screen
hgs
parents:
diff changeset
   158
        */
hgs
parents:
diff changeset
   159
        IMPORT_C TInt CurrentPosition();
hgs
parents:
diff changeset
   160
hgs
parents:
diff changeset
   161
        /**
hgs
parents:
diff changeset
   162
        * Get the item
hgs
parents:
diff changeset
   163
        * @return reference of item
hgs
parents:
diff changeset
   164
        */
hgs
parents:
diff changeset
   165
        IMPORT_C TPtrC ItemL(TInt aIndex);
hgs
parents:
diff changeset
   166
hgs
parents:
diff changeset
   167
        /**
hgs
parents:
diff changeset
   168
        * Count the number of items in the current menu
hgs
parents:
diff changeset
   169
        * @return number of items in the current menu
hgs
parents:
diff changeset
   170
        */
hgs
parents:
diff changeset
   171
        IMPORT_C TInt ItemCount() const;
hgs
parents:
diff changeset
   172
        
hgs
parents:
diff changeset
   173
        /**
hgs
parents:
diff changeset
   174
        * Reads user input into the start of the descriptor aDes
hgs
parents:
diff changeset
   175
        * @param aDes, descriptor to store input string
hgs
parents:
diff changeset
   176
        */
hgs
parents:
diff changeset
   177
        IMPORT_C void ReadString( TDes& aDes );
hgs
parents:
diff changeset
   178
        
hgs
parents:
diff changeset
   179
    protected:  // New functions
hgs
parents:
diff changeset
   180
hgs
parents:
diff changeset
   181
        /**
hgs
parents:
diff changeset
   182
        * Append text before original text.
hgs
parents:
diff changeset
   183
        */
hgs
parents:
diff changeset
   184
        void AppendBefore(  TInt aLineNum, TDes& aLine );
hgs
parents:
diff changeset
   185
hgs
parents:
diff changeset
   186
    protected:  // Data
hgs
parents:
diff changeset
   187
        CDesCArrayFlat*         iItems;         // View items
hgs
parents:
diff changeset
   188
hgs
parents:
diff changeset
   189
        TInt                    iPosOnScreen;  // Position on display
hgs
parents:
diff changeset
   190
        TInt                    iFirst;        // First displayed item
hgs
parents:
diff changeset
   191
        TInt                    iLast;         // Last displayed item
hgs
parents:
diff changeset
   192
        TInt                    iItemCount;    // Last Item
hgs
parents:
diff changeset
   193
        TSize                   iSize;         // Display size
hgs
parents:
diff changeset
   194
        TInt                    iScreenSize;   // "Work area" size
hgs
parents:
diff changeset
   195
        TInt                    iDirection;    // Scrolling direction
hgs
parents:
diff changeset
   196
        TInt                    iStart;        // Scrolling position
hgs
parents:
diff changeset
   197
        TInt                    iPrevPos;      // Previous position in scrolling
hgs
parents:
diff changeset
   198
        TKeyCode                iKey;          // Last key pressed
hgs
parents:
diff changeset
   199
hgs
parents:
diff changeset
   200
    };
hgs
parents:
diff changeset
   201
hgs
parents:
diff changeset
   202
hgs
parents:
diff changeset
   203
#endif  //TESTMENUVIEW_H