00001 /* 00002 Copyright (c) 2000-2010 Nokia Corporation and/or its subsidiary(-ies). All rights reserved. 00003 00004 Redistribution and use in source and binary forms, with or without 00005 modification, are permitted provided that the following conditions are met: 00006 00007 * Redistributions of source code must retain the above copyright notice, this 00008 list of conditions and the following disclaimer. 00009 * Redistributions in binary form must reproduce the above copyright notice, 00010 this list of conditions and the following disclaimer in the documentation 00011 and/or other materials provided with the distribution. 00012 * Neither the name of Nokia Corporation nor the names of its contributors 00013 may be used to endorse or promote products derived from this software 00014 without specific prior written permission. 00015 00016 THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 00017 AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 00018 IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 00019 DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE 00020 FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 00021 DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR 00022 SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER 00023 CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, 00024 OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 00025 OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 00026 00027 Description: 00028 HelloWorld_CExampleAppUi.cpp 00029 Source file for the implementation of the 00030 application UI class - CExampleAppUi 00031 */ 00032 00033 00034 00035 #include "HelloWorld.h" 00036 00037 // The second phase constructor of the application UI class. 00038 // The application UI creates and owns the one and only view. 00039 // 00040 void CExampleAppUi::ConstructL() 00041 { 00042 // BaseConstructL() completes the UI framework's 00043 // construction of the App UI. 00044 BaseConstructL(); 00045 // Create the single application view in which to 00046 // draw the text "Hello World!", passing into it 00047 // the rectangle available to it. 00048 iAppView = CExampleAppView::NewL(ClientRect()); 00049 } 00050 00051 00052 // The app Ui owns the two views and is. 00053 // therefore, responsible for destroying them 00054 // 00055 CExampleAppUi::~CExampleAppUi() 00056 { 00057 delete iAppView; 00058 } 00059 00060 00061 // Called by the UI framework when a command has been issued. 00062 // In this example, a command can originate through a 00063 // hot-key press or by selection of a menu item. 00064 // The command Ids are defined in the .hrh file 00065 // and are 'connected' to the hot-key and menu item in the 00066 // resource file. 00067 // Note that the EEikCmdExit is defined by the UI 00068 // framework and is pulled in by including eikon.hrh 00069 // 00070 void CExampleAppUi::HandleCommandL(TInt aCommand) 00071 { 00072 switch (aCommand) 00073 { 00074 // Just issue simple info messages to show that 00075 // the menu items have been selected 00076 case EExampleItem0: 00077 iEikonEnv->InfoMsg(R_EXAMPLE_TEXT_ITEM0); 00078 break; 00079 00080 00081 case EExampleItem1: 00082 iEikonEnv->InfoMsg(R_EXAMPLE_TEXT_ITEM1); 00083 break; 00084 00085 case EExampleItem2: 00086 iEikonEnv->InfoMsg(R_EXAMPLE_TEXT_ITEM2); 00087 break; 00088 // Exit the application. The call is 00089 // implemented by the UI framework. 00090 00091 case EEikCmdExit: 00092 Exit(); 00093 break; 00094 } 00095 } 00096