CPbkViewState.h

Go to the documentation of this file.
00001 /*
00002 * ============================================================================
00003 *  Name     : CPbkViewState from CPbkViewState.h
00004 *  Part of  : PbkView.dll
00005 *
00006 *  Description:
00007 *     View states.
00008 *  Version:
00009 *
00010 *  Copyright (C) 2002 Nokia Corporation.
00011 *  This material, including documentation and any related 
00012 *  computer programs, is protected by copyright controlled by 
00013 *  Nokia Corporation. All rights are reserved. Copying, 
00014 *  including reproducing, storing,  adapting or translating, any 
00015 *  or all of this material requires the prior written consent of 
00016 *  Nokia Corporation. This material also contains confidential 
00017 *  information which may not be disclosed to others without the 
00018 *  prior written consent of Nokia Corporation.
00019 * ============================================================================
00020 */
00021 
00022 #ifndef __CPbkViewState_H__
00023 #define __CPbkViewState_H__
00024 
00025 //  INCLUDES
00026 #include <e32base.h>    // CBase
00027 #include <cntdef.h>     // TContactItemId, CContactIdArray
00028 
00029 // FORWARD DECLARATIONS
00030 class RReadStream;
00031 class RWriteStream;
00032 class CPbkFieldDataArray;
00033 
00034 // CLASS DECLARATION
00035 
00041 class CPbkViewState : public CBase
00042     {
00043     public:  // Types
00044         enum TDataType
00045             {
00046             EEnd = 0,
00047             EFocusedContactId,
00048             ETopContactId,
00049             EMarkedContactIds,
00050             EFocusedFieldIndex,
00051             ETopFieldIndex,
00052             EFieldDataArray,
00053             EParentContactId,
00054             EFlags
00055             };
00056 
00057         enum TFlags
00058             {
00060             ENullFlags = 0,
00062             EFocusFirst  = 0x0001,
00064             EFocusLast   = 0x0002,
00066             EInitialized = 0x0004,
00068             ESendToBackground = 0x0008
00069             };
00070 
00071     public:  // Constructors and destructor
00075         IMPORT_C static CPbkViewState* NewL();
00076 
00081         IMPORT_C static CPbkViewState* NewLC();
00082         
00088         IMPORT_C static CPbkViewState* NewL(RReadStream& aStream);
00089         
00096         IMPORT_C static CPbkViewState* NewLC(RReadStream& aStream);
00097         
00103         IMPORT_C static CPbkViewState* NewL(const TDesC8& aBuf);
00104         
00111         IMPORT_C static CPbkViewState* NewLC(const TDesC8& aBuf);
00112 
00116         ~CPbkViewState();
00117 
00118     public:  // Getters
00122         IMPORT_C static TUid Uid();
00123 
00128         IMPORT_C TContactItemId FocusedContactId() const;
00129 
00134         IMPORT_C TContactItemId TopContactId() const;
00135 
00140         IMPORT_C const CContactIdArray* MarkedContactIds() const;
00141 
00147         IMPORT_C CContactIdArray* MarkedContactIds();
00148 
00154         IMPORT_C TInt FocusedFieldIndex() const;
00155 
00161         IMPORT_C TInt TopFieldIndex() const;
00162 
00167         IMPORT_C CPbkFieldDataArray* FieldDataArray() const;
00168 
00173         IMPORT_C TContactItemId ParentContactId() const; 
00174 
00179         IMPORT_C TUint Flags() const;
00180 
00181     public:  // Setters
00186         IMPORT_C void SetFocusedContactId(TContactItemId aId);
00187 
00192         IMPORT_C void SetTopContactId(TContactItemId aId);
00193 
00199         IMPORT_C void SetMarkedContactIds(CContactIdArray* aArray);
00200 
00206         IMPORT_C void SetFocusedFieldIndex(TInt aIndex);
00207 
00213         IMPORT_C void SetTopFieldIndex(TInt aIndex);
00214 
00220         IMPORT_C void SetFieldDataArray(CPbkFieldDataArray* aFieldDataArray);
00221 
00225         IMPORT_C void Reset();
00226 
00231         IMPORT_C void SetParentContactId(TContactItemId aParentContactId);
00232 
00237         IMPORT_C void SetFlags(TUint aFlags);
00238 
00248         /*IMPORT_C*/ void MergeViewState(CPbkViewState& aOtherState);
00249 
00250     public:  // Stream support
00256         IMPORT_C HBufC8* PackL() const;
00257 
00263         IMPORT_C HBufC8* PackLC() const;
00264 
00271         IMPORT_C void UnpackL(const TDesC8& aPack);
00272 
00278         IMPORT_C void ExternalizeL(RWriteStream& aStream) const;
00279 
00285         IMPORT_C void InternalizeL(RReadStream& aStream);
00286 
00287     public: // Support functions
00288         IMPORT_C TBool operator==(const CPbkViewState& aRhs) const; 
00289 
00290     private:  // Implementation
00291         CPbkViewState();
00292 
00293     private:  // data
00295         TContactItemId iFocusedContactId;
00297         TContactItemId iTopContactId;
00299         TInt iFocusedFieldIndex;
00301         TInt iTopFieldIndex;
00303         CContactIdArray* iMarkedContactIds;
00305         CPbkFieldDataArray* iFieldDataArray;
00307         TContactItemId iParentContactId;
00309         TUint iFlags;
00310 
00311     private:  // const static data
00312         static const TUid KUid;
00313     };
00314 
00315 
00316 /*
00317    ** View state binary stream format **
00318    
00319     - View parameter UID is 0x101f4ccf
00320 
00321     - Format of the stream in (slightly freeform) BNF:
00322 
00323     <stream>  ::= <command>+
00324     <command> ::= Int8(opcode) parameters
00325     <opcode>  ::= EEnd | EFocusedContactId | ETopContactId | EMarkedContactIds |
00326                   EFocusedFieldIndex | ETopFieldIndex | EFieldDataArray
00327     <command> ::= EEnd  // no further commands are read after EEnd. EEnd is not mandatory in a stream.
00328     <command> ::= EFocusedContactId Int32(TContactItemId)
00329     <command> ::= ETopContactId Int32(TContactItemId)
00330     <command> ::= EMarkedContactIds (Int32(count) { Int32(TContactItemId) })  // count is count TContactItemIds
00331     <command> ::= EFocusedFieldIndex Int32(index)
00332     <command> ::= ETopFieldIndex Int32(index)
00333     <command> ::= EFieldDataArray <contactdata>
00334     <command> ::= EParentContactId Int32(TContactItemId)
00335 
00336     <contactdata> ::= Int32(count) { fielddata }  // count is count of fieldatas
00337     <fielddata> ::= <fieldtype> data
00338     <fieldtype> ::= ETypeText | ETypeTime
00339     <fielddata> ::= ETypeText (Int32(length) text)  // length is length of text in chars, text is unicode
00340     <fielddata> ::= ETypeTime (Int32(high) Int32(low))  // high and low words of a TTime's internal Int64
00341 
00342     Constants:
00343         EEnd = 0,
00344         EFocusedContactId = 1,
00345         ETopContactId = 2,
00346         EMarkedContactIds = 3,
00347         EFocusedFieldIndex = 4,
00348         ETopFieldIndex = 5,
00349         EFieldDataArray = 6,
00350         EParentContactId = 7
00351 
00352     - Example:
00353     Activate Phonebook's contact info view to show contact with id 5 and field 
00354     at index 3 focused:
00355 
00356     // Write parameters in a buffer
00357     TBuf8<16> param;
00358     RDesWriteStream stream(param);
00359     stream.PushL();
00360     param.WriteInt8L(1);  // opcode EFocusedContactId
00361     param.WriteInt32L(5);  // Contact id 5
00362     param.WriteInt8L(4);  // opcode EFocusedFieldIndex
00363     param.WriteInt32L(3);  // field index 3
00364     stream.CommitL();
00365     CleanupStack::PopAndDestroy();  // stream
00366 
00367     // Make view id with Phonebook's app UID3 and Contact Info View's id
00368     const TVwsViewId viewId(0x101f4cce, 4);
00369 
00370     // Activate the view
00371     AppUi()->ActivateViewL(viewId, TUid::Uid(0x101f4ccf), param);
00372 
00373 
00374     - Same example as above, now using CPbkViewState:
00375 
00376     #include <CPbkViewState.h>  // need also to add PbkView.lib into projects .mmp
00377     #include <PbkUID.h> // Phonebook UIDs
00378 
00379     CPbkViewState* pbkViewParam = CPbkViewState::NewLC();
00380     pbkViewParam->SetFocusedContactId(5);
00381     pbkViewParam->SetFocusedFieldIndex(3);
00382     HBufC8* paramBuf = pbkViewParam->PackLC();
00383     
00384     // Make view id with Phonebook's app UID3 and Contact Info View's id
00385     const TVwsViewId viewId(KPbkUID3, 4);
00386 
00387     // Activate the view
00388     AppUi()->ActivateViewL(viewId, CPbkViewState::Uid(), *paramBuf);
00389 
00390     // Cleanup
00391     CleanupStack::PopAndDestroy(2);  // paramBuf, pbkViewParam
00392 
00393     - The latter example is cleaner, but using CPbkViewState from your 
00394     application means that your application will have a dependency to 
00395     CPbkViewState.h and PbkView.lib at compile time and to PbkView.dll at
00396     run time.
00397 
00398 */
00399 
00400 #endif // __CPbkViewState_H__
00401             
00402 // End of File

Copyright © Nokia Corporation 2001-2007
Back to top