epoc32/include/mw/akniconsrvclient.h
author William Roberts <williamr@symbian.org>
Tue, 16 Mar 2010 16:12:26 +0000
branchSymbian2
changeset 2 2fe1408b6811
parent 1 666f914201fb
child 4 837f303aceeb
permissions -rw-r--r--
Final list of Symbian^2 public API header files
williamr@2
     1
/*
williamr@2
     2
* Copyright (c) 2002 Nokia Corporation and/or its subsidiary(-ies).
williamr@2
     3
* All rights reserved.
williamr@2
     4
* This component and the accompanying materials are made available
williamr@2
     5
* under the terms of the License "Symbian Foundation License v1.0" to Symbian Foundation members and "Symbian Foundation End User License Agreement v1.0" to non-members
williamr@2
     6
* which accompanies this distribution, and is available
williamr@2
     7
* at the URL "http://www.symbianfoundation.org/legal/licencesv10.html".
williamr@2
     8
*
williamr@2
     9
* Initial Contributors:
williamr@2
    10
* Nokia Corporation - initial contribution.
williamr@2
    11
*
williamr@2
    12
* Contributors:
williamr@2
    13
*
williamr@2
    14
* Description:   
williamr@2
    15
*
williamr@2
    16
*/
williamr@2
    17
williamr@2
    18
williamr@2
    19
williamr@2
    20
williamr@2
    21
#ifndef AKN_ICON_SRV_CLIENT_H
williamr@2
    22
#define AKN_ICON_SRV_CLIENT_H
williamr@2
    23
williamr@2
    24
#include <e32base.h>
williamr@2
    25
#include <AknIconUtils.h>
williamr@2
    26
williamr@2
    27
struct TAknIconParams;
williamr@2
    28
struct TAknIconInitData;
williamr@2
    29
class CAknBitmap;
williamr@2
    30
class CAknIconManager;
williamr@2
    31
williamr@2
    32
williamr@2
    33
/**
williamr@2
    34
 * A client-side handle to a session with an icon server which allows handling
williamr@2
    35
 * icons (bitmaps).
williamr@2
    36
 * 
williamr@2
    37
 * @since 3.0
williamr@2
    38
 */
williamr@2
    39
class RAknIconSrvClient : public RSessionBase
williamr@2
    40
    {
williamr@2
    41
    
williamr@2
    42
    public: // New functions
williamr@2
    43
williamr@2
    44
        /**
williamr@2
    45
         * C++ default constructor.
williamr@2
    46
         */      
williamr@2
    47
        RAknIconSrvClient();
williamr@2
    48
williamr@2
    49
        /**
williamr@2
    50
         * Connects AknIconSrv session. It is stored in TLS.
williamr@2
    51
         * Application framework calls this in application startup.
williamr@2
    52
         *
williamr@2
    53
         * @since 3.0
williamr@2
    54
         * @return Symbian OS standard error code.
williamr@2
    55
         */      
williamr@2
    56
        IMPORT_C static TInt Connect();
williamr@2
    57
williamr@2
    58
        /**
williamr@2
    59
         * Disconnects the session.
williamr@2
    60
         * @since 3.0
williamr@2
    61
         */
williamr@2
    62
        IMPORT_C static void Disconnect();
williamr@2
    63
williamr@2
    64
        /**
williamr@2
    65
         * Returns the connected server client from TLS.
williamr@2
    66
         *
williamr@2
    67
         * @return The connected server client from TLS.
williamr@2
    68
         * @panic EClientSessionNotConnected @c Connect() has not been called
williamr@2
    69
         *        successfully earlier.
williamr@2
    70
         */
williamr@2
    71
        static RAknIconSrvClient* GetSession();
williamr@2
    72
williamr@2
    73
    public: // But not exported.
williamr@2
    74
williamr@2
    75
        /**
williamr@2
    76
         * Initializes the given bitmap and mask according to the member data 
williamr@2
    77
         * stored in them and the given pixel size.
williamr@2
    78
         *
williamr@2
    79
         * @param[in] aBitmap Bitmap.
williamr@2
    80
         * @param[in] aMask Mask of the bitmap.
williamr@2
    81
         * @param[out] aContentDimensions The content dimensions if it is 
williamr@2
    82
         *             a SVG icon.
williamr@2
    83
         * @param aInfo parameters of the icon.
williamr@2
    84
         */
williamr@2
    85
        void InitializeIconL( 
williamr@2
    86
                CAknBitmap& aBitmap,
williamr@2
    87
                CAknBitmap& aMask,
williamr@2
    88
                TAknContentDimensions& aContentDimensions, 
williamr@2
    89
                const TAknIconParams& aInfo ) const;
williamr@2
    90
williamr@2
    91
        /**
williamr@2
    92
         * Frees the shared bitmap.
williamr@2
    93
         *
williamr@2
    94
         * @param aBitmap Bitmap.
williamr@2
    95
         */
williamr@2
    96
        void FreeBitmap( CAknBitmap& aBitmap ) const;
williamr@2
    97
williamr@2
    98
        /**
williamr@2
    99
         * Gets content dimensions of the icon.
williamr@2
   100
         *
williamr@2
   101
         * @param[in] aBitmap Bitmap.
williamr@2
   102
         * @param[out] aContentDimensions The content dimensions of an icon.
williamr@2
   103
         * @return Symbian OS standard error code .
williamr@2
   104
         */
williamr@2
   105
        TInt GetContentDimensions( 
williamr@2
   106
                CAknBitmap& aBitmap, 
williamr@2
   107
                TAknContentDimensions& aContentDimensions ) const;
williamr@2
   108
williamr@2
   109
        /**
williamr@2
   110
         * Preserves icon data (e.g. SVG-T DOM tree) in memory.
williamr@2
   111
         *
williamr@2
   112
         * @param aBitmap Bitmap.
williamr@2
   113
         * @return Symbian OS standard error code .
williamr@2
   114
         */
williamr@2
   115
        TInt PreserveIconData( CAknIconManager& aBitmap ) const;
williamr@2
   116
williamr@2
   117
        /**
williamr@2
   118
         * Removes icon data (e.g. SVG-T DOM tree) from the memory.
williamr@2
   119
         *
williamr@2
   120
         * @param aBitmap Bitmap.
williamr@2
   121
         */
williamr@2
   122
        void DestroyIconData( CAknIconManager& aBitmap ) const;
williamr@2
   123
williamr@2
   124
        /**
williamr@2
   125
         * Retrieves initialization data from server side.
williamr@2
   126
         *
williamr@2
   127
         * @param[out] aData Initialization data.
williamr@2
   128
         */
williamr@2
   129
        void GetInitData( TAknIconInitData& aData ) const;
williamr@2
   130
williamr@2
   131
        /**
williamr@2
   132
         * Test functions (debug only).
williamr@2
   133
         */
williamr@2
   134
        void __SERVER_HEAP_MARK() const;
williamr@2
   135
        void __SERVER_HEAP_MARKEND() const;
williamr@2
   136
        void __SERVER_HEAP_FAILNEXT( TInt aCount ) const;
williamr@2
   137
        void __SERVER_HEAP_FAILNEXT_INCREASING( TInt aCount ) const;
williamr@2
   138
        void __SERVER_HEAP_RESET() const;
williamr@2
   139
        void __SERVER_RESET_DYNAMICALLY_CHANGING_ALLOCATIONS() const;
williamr@2
   140
        TInt __SERVER_HEAP_USED() const;
williamr@2
   141
        void __SERVER_SET_PREFERRED_ICON_DISPLAY_MODE(
williamr@2
   142
                                                    TDisplayMode aMode ) const;
williamr@2
   143
williamr@2
   144
        /**
williamr@2
   145
         * Connects to server.
williamr@2
   146
         *
williamr@2
   147
         * @return Symbian OS standard error code .
williamr@2
   148
         */
williamr@2
   149
        TInt ConnectToServer();
williamr@2
   150
        
williamr@2
   151
		/**
williamr@2
   152
		 * Enable or disable the AknIcon cache.
williamr@2
   153
		 *
williamr@2
   154
		 * @return Symbian OS standard error code .
williamr@2
   155
  		 */
williamr@2
   156
        TInt EnableCache(TBool aEnable);
williamr@2
   157
williamr@2
   158
    private: // Data
williamr@2
   159
        TInt iConnections;
williamr@2
   160
    };
williamr@2
   161
williamr@2
   162
#endif // AKN_ICON_SRV_CLIENT_H
williamr@2
   163
williamr@2
   164
// End of File