svgtopt/VGRenderer/inc/VGSurface.h
author hgs
Wed, 03 Nov 2010 18:56:10 +0200
changeset 46 88edb906c587
child 26 796196dd6e68
permissions -rw-r--r--
201044
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
46
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2003 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:  CVGSurface header file
hgs
parents:
diff changeset
    15
 *
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
#ifndef VGSURFACE_H
hgs
parents:
diff changeset
    19
#define VGSURFACE_H
hgs
parents:
diff changeset
    20
hgs
parents:
diff changeset
    21
#include <e32std.h>
hgs
parents:
diff changeset
    22
#include <e32base.h>
hgs
parents:
diff changeset
    23
hgs
parents:
diff changeset
    24
#include "MVGSurfaceImpl.h"
hgs
parents:
diff changeset
    25
hgs
parents:
diff changeset
    26
class RWindow;
hgs
parents:
diff changeset
    27
class CFbsBitmap;
hgs
parents:
diff changeset
    28
class CVGRenderer;
hgs
parents:
diff changeset
    29
hgs
parents:
diff changeset
    30
/**
hgs
parents:
diff changeset
    31
 *  CVGSurface
hgs
parents:
diff changeset
    32
 * 
hgs
parents:
diff changeset
    33
 */
hgs
parents:
diff changeset
    34
class CVGSurface : public CBase
hgs
parents:
diff changeset
    35
    {
hgs
parents:
diff changeset
    36
public:
hgs
parents:
diff changeset
    37
    enum SurfaceConfig
hgs
parents:
diff changeset
    38
    {
hgs
parents:
diff changeset
    39
    BTIMAP_HEADER = MVGSurfaceImpl::BTIMAP_HEADER,
hgs
parents:
diff changeset
    40
    ALPHA_SIZE = MVGSurfaceImpl::ALPHA_SIZE,
hgs
parents:
diff changeset
    41
    ALPHA_MASK_SIZE = MVGSurfaceImpl::ALPHA_MASK_SIZE
hgs
parents:
diff changeset
    42
    };
hgs
parents:
diff changeset
    43
    
hgs
parents:
diff changeset
    44
    /**
hgs
parents:
diff changeset
    45
     * Destructor.
hgs
parents:
diff changeset
    46
     */
hgs
parents:
diff changeset
    47
    ~CVGSurface();
hgs
parents:
diff changeset
    48
hgs
parents:
diff changeset
    49
    /*!
hgs
parents:
diff changeset
    50
     * @fn          NewL()
hgs
parents:
diff changeset
    51
     * @bief        Creates the renderer surface abstraction
hgs
parents:
diff changeset
    52
     * @param       aVGSurfaceImpl The surface implementation
hgs
parents:
diff changeset
    53
     * @return      Renderer surface abstraction
hgs
parents:
diff changeset
    54
     */
hgs
parents:
diff changeset
    55
    static CVGSurface* NewL(MVGSurfaceImpl *aVGSurfaceImpl);
hgs
parents:
diff changeset
    56
hgs
parents:
diff changeset
    57
    /*!
hgs
parents:
diff changeset
    58
     * @fn          NewL()
hgs
parents:
diff changeset
    59
     * @bief        Creates the renderer surface abstraction
hgs
parents:
diff changeset
    60
     * @param       aVGSurfaceImpl The surface implementation
hgs
parents:
diff changeset
    61
     * @return      Renderer surface abstraction
hgs
parents:
diff changeset
    62
     */
hgs
parents:
diff changeset
    63
    static CVGSurface* NewLC(MVGSurfaceImpl *aVGSurfaceImpl);
hgs
parents:
diff changeset
    64
hgs
parents:
diff changeset
    65
    /*!
hgs
parents:
diff changeset
    66
     * @fn          InitializeSurface(TSize aSize, TInt aColorSpace)
hgs
parents:
diff changeset
    67
     * @bief        Initialize the surface
hgs
parents:
diff changeset
    68
     * @param       aSize The surface size
hgs
parents:
diff changeset
    69
     * @param       aColorSpace This is optional with egl
hgs
parents:
diff changeset
    70
     * @return      KErrNone in case of succesfull, appropriate error code otherwise
hgs
parents:
diff changeset
    71
     */
hgs
parents:
diff changeset
    72
    TInt InitializeSurface(TSize aSize, TInt aColorSpace)
hgs
parents:
diff changeset
    73
        {
hgs
parents:
diff changeset
    74
        return iImpl->InitializeSurface(aSize, aColorSpace);
hgs
parents:
diff changeset
    75
        }
hgs
parents:
diff changeset
    76
hgs
parents:
diff changeset
    77
    /*!
hgs
parents:
diff changeset
    78
     * @fn          CreateSurface(RWindow *aSurface, CFbsBitmap *aBitmap)
hgs
parents:
diff changeset
    79
     * @bief        Creates the actual rendering surface
hgs
parents:
diff changeset
    80
     * @param       aDisplayMode    The display mode
hgs
parents:
diff changeset
    81
     * @param       aSurface The window object
hgs
parents:
diff changeset
    82
     * @param       aBitmap  The bitmao object, is optional
hgs
parents:
diff changeset
    83
     * @return      KErrNone in case of succesfull, appropriate error code otherwise
hgs
parents:
diff changeset
    84
     */
hgs
parents:
diff changeset
    85
    TInt CreateSurface(TInt aDisplayMode, RWindow *aSurface, CFbsBitmap *aBitmap)
hgs
parents:
diff changeset
    86
        {
hgs
parents:
diff changeset
    87
        return iImpl->CreateSurface(aDisplayMode, aSurface, aBitmap);
hgs
parents:
diff changeset
    88
        }
hgs
parents:
diff changeset
    89
    
hgs
parents:
diff changeset
    90
    /*!
hgs
parents:
diff changeset
    91
     * @fn          ResizeSurface(TSize aSize)
hgs
parents:
diff changeset
    92
     * @bief        Resizes the surface
hgs
parents:
diff changeset
    93
     * @param       aSize   The new size
hgs
parents:
diff changeset
    94
     * @return      KErrNone in case of succesfull, appropriate error code otherwise
hgs
parents:
diff changeset
    95
     */
hgs
parents:
diff changeset
    96
    TInt ResizeSurface(TSize aSize)
hgs
parents:
diff changeset
    97
        {
hgs
parents:
diff changeset
    98
        return iImpl->ResizeSurface(aSize);
hgs
parents:
diff changeset
    99
        }
hgs
parents:
diff changeset
   100
hgs
parents:
diff changeset
   101
    /*!
hgs
parents:
diff changeset
   102
     * @fn          SetConfiguration
hgs
parents:
diff changeset
   103
     * @brief       sets surface/context/display configuration options
hgs
parents:
diff changeset
   104
     * @param       aOption  name of the option
hgs
parents:
diff changeset
   105
     * @param       aValue   value(s) for the option
hgs
parents:
diff changeset
   106
     */
hgs
parents:
diff changeset
   107
    void SetConfiguration(TInt aOption, const TAny* aValue)
hgs
parents:
diff changeset
   108
        {
hgs
parents:
diff changeset
   109
        return iImpl->SetConfiguration(aOption, aValue);
hgs
parents:
diff changeset
   110
        }
hgs
parents:
diff changeset
   111
    /*!
hgs
parents:
diff changeset
   112
     * @fn          CopyBitmap(CFbsBitmap *aBitmap, CFbsBitmap *aMask, TInt aOption)
hgs
parents:
diff changeset
   113
     * @brief       copies the bitmap from the surface to the given bitmap
hgs
parents:
diff changeset
   114
     * @param       aDisplayMode    The display mode
hgs
parents:
diff changeset
   115
     * @param       aBitmap The bitmap where the content will be copied
hgs
parents:
diff changeset
   116
     * @param       aMask   Mask
hgs
parents:
diff changeset
   117
     * @param       aOption Options, may be required for VGI calls
hgs
parents:
diff changeset
   118
     */
hgs
parents:
diff changeset
   119
    TInt CopyBitmap(TInt aDisplayMode,TInt aMaskMode,CFbsBitmap *aBitmap, CFbsBitmap *aMask, TSize aSize)
hgs
parents:
diff changeset
   120
        {
hgs
parents:
diff changeset
   121
        return iImpl->CopyBitmap(aDisplayMode,aMaskMode, aBitmap, aMask, aSize);
hgs
parents:
diff changeset
   122
        }
hgs
parents:
diff changeset
   123
 
hgs
parents:
diff changeset
   124
    /**
hgs
parents:
diff changeset
   125
     * @fn          PrepareToBindClientBuffer
hgs
parents:
diff changeset
   126
     *              Prepares the renderer to bind to an image. 
hgs
parents:
diff changeset
   127
     *              This is added to allow some performance improvement the TLV renderer
hgs
parents:
diff changeset
   128
     *              This method should be called before creating the VGImage, which should be made as the surface.
hgs
parents:
diff changeset
   129
     *              No other image should be created after calling this function
hgs
parents:
diff changeset
   130
     */
hgs
parents:
diff changeset
   131
    TInt PrepareToBindClientBuffer()
hgs
parents:
diff changeset
   132
        {
hgs
parents:
diff changeset
   133
        return iImpl->PrepareToBindClientBuffer();
hgs
parents:
diff changeset
   134
        }
hgs
parents:
diff changeset
   135
    /*!
hgs
parents:
diff changeset
   136
     * @fn          BindSurfaces(TInt buffer)
hgs
parents:
diff changeset
   137
     * @brief       This function is used for Binding Off-Screen Rendering Surfaces To Client Buffers
hgs
parents:
diff changeset
   138
     * @param       buffer is a client API reference to the buffer to be bound. buffer must be a valid VGImage handle.
hgs
parents:
diff changeset
   139
     * @return      0 if success
hgs
parents:
diff changeset
   140
     */
hgs
parents:
diff changeset
   141
    TInt BindClientBuffer(TInt buffer)
hgs
parents:
diff changeset
   142
        {
hgs
parents:
diff changeset
   143
        return iImpl->BindClientBuffer(buffer);
hgs
parents:
diff changeset
   144
        }
hgs
parents:
diff changeset
   145
    
hgs
parents:
diff changeset
   146
    /*!
hgs
parents:
diff changeset
   147
     * @fn          UnbindSurface(TInt surface)
hgs
parents:
diff changeset
   148
     * @brief       copies the bitmap from the surface to the given bitmap
hgs
parents:
diff changeset
   149
     * @param       aBitmap The bitmap where the content will be copied
hgs
parents:
diff changeset
   150
     * @param       aMask   Mask
hgs
parents:
diff changeset
   151
     * @param       aOption Options, may be required for VGI calls
hgs
parents:
diff changeset
   152
     * @return      0 if success
hgs
parents:
diff changeset
   153
     */
hgs
parents:
diff changeset
   154
    TInt UnBindClientBuffer()
hgs
parents:
diff changeset
   155
        {
hgs
parents:
diff changeset
   156
        return iImpl->UnBindClientBuffer();
hgs
parents:
diff changeset
   157
        }
hgs
parents:
diff changeset
   158
    /*!
hgs
parents:
diff changeset
   159
     * @fn          TerminateSurface()
hgs
parents:
diff changeset
   160
     * @brief       Will destroy the surface
hgs
parents:
diff changeset
   161
     */
hgs
parents:
diff changeset
   162
    void TerminateSurface()
hgs
parents:
diff changeset
   163
        {
hgs
parents:
diff changeset
   164
        iImpl->TerminateSurface();
hgs
parents:
diff changeset
   165
        }
hgs
parents:
diff changeset
   166
hgs
parents:
diff changeset
   167
hgs
parents:
diff changeset
   168
private:
hgs
parents:
diff changeset
   169
hgs
parents:
diff changeset
   170
    CVGSurface();
hgs
parents:
diff changeset
   171
hgs
parents:
diff changeset
   172
    /**
hgs
parents:
diff changeset
   173
     * default constructor for performing 2nd stage construction
hgs
parents:
diff changeset
   174
     */
hgs
parents:
diff changeset
   175
    void ConstructL(MVGSurfaceImpl *aVGSurfaceImpl);
hgs
parents:
diff changeset
   176
hgs
parents:
diff changeset
   177
    MVGSurfaceImpl  *iImpl;
hgs
parents:
diff changeset
   178
    };
hgs
parents:
diff changeset
   179
hgs
parents:
diff changeset
   180
#endif // VGSURFACE_H