svgtopt/VGRenderer/inc/VGRenderer.h
author hgs
Wed, 03 Nov 2010 18:56:10 +0200
changeset 46 88edb906c587
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:  SVG Implementation header file
hgs
parents:
diff changeset
    15
 *
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
hgs
parents:
diff changeset
    19
#ifndef VGRENDERER_H
hgs
parents:
diff changeset
    20
#define VGRENDERER_H
hgs
parents:
diff changeset
    21
hgs
parents:
diff changeset
    22
#include <e32std.h>
hgs
parents:
diff changeset
    23
#include <e32base.h>
hgs
parents:
diff changeset
    24
hgs
parents:
diff changeset
    25
#include "MVGRendererImpl.h"
hgs
parents:
diff changeset
    26
#include <SVGRendererId.h>
hgs
parents:
diff changeset
    27
hgs
parents:
diff changeset
    28
class CVGSurface;
hgs
parents:
diff changeset
    29
hgs
parents:
diff changeset
    30
/**
hgs
parents:
diff changeset
    31
 *  CVGRenderer
hgs
parents:
diff changeset
    32
 * 
hgs
parents:
diff changeset
    33
 */
hgs
parents:
diff changeset
    34
class CVGRenderer : public CBase
hgs
parents:
diff changeset
    35
    {
hgs
parents:
diff changeset
    36
hgs
parents:
diff changeset
    37
public:
hgs
parents:
diff changeset
    38
    /**
hgs
parents:
diff changeset
    39
     * Destructor.
hgs
parents:
diff changeset
    40
     */
hgs
parents:
diff changeset
    41
    ~CVGRenderer();
hgs
parents:
diff changeset
    42
hgs
parents:
diff changeset
    43
    /*!
hgs
parents:
diff changeset
    44
     * @fn          NewL()
hgs
parents:
diff changeset
    45
     * @bief        Creates the renderer abstraction
hgs
parents:
diff changeset
    46
     * @param       aRendererType   Type of the renderer
hgs
parents:
diff changeset
    47
     * @param       aSurface        Type of the surface
hgs
parents:
diff changeset
    48
     * @return      Renderer abstraction
hgs
parents:
diff changeset
    49
     */
hgs
parents:
diff changeset
    50
    IMPORT_C static CVGRenderer* NewL(SVGRendererId aRendererType = ESVGRendererSW, TInt aSurface = 0);
hgs
parents:
diff changeset
    51
hgs
parents:
diff changeset
    52
    /*!
hgs
parents:
diff changeset
    53
     * @fn          NewLC()
hgs
parents:
diff changeset
    54
     * @bief        Creates the renderer abstraction
hgs
parents:
diff changeset
    55
     * @param       aRendererType   Type of the renderer
hgs
parents:
diff changeset
    56
     * @param       aSurface        Type of the surface
hgs
parents:
diff changeset
    57
     * @return      Renderer abstraction
hgs
parents:
diff changeset
    58
     */
hgs
parents:
diff changeset
    59
    static CVGRenderer* NewLC(SVGRendererId aRendererType = ESVGRendererSW, TInt aSurface = 0);
hgs
parents:
diff changeset
    60
hgs
parents:
diff changeset
    61
public:
hgs
parents:
diff changeset
    62
    
hgs
parents:
diff changeset
    63
    /*!
hgs
parents:
diff changeset
    64
     * @fn          GetRendererName()
hgs
parents:
diff changeset
    65
     * @bief        Retrieves the renderer implementation's version
hgs
parents:
diff changeset
    66
     * @return      version of renderer implementation
hgs
parents:
diff changeset
    67
     */
hgs
parents:
diff changeset
    68
    TVersion GetRendererVersion()
hgs
parents:
diff changeset
    69
        {
hgs
parents:
diff changeset
    70
        return iImpl->GetVersion();
hgs
parents:
diff changeset
    71
        }
hgs
parents:
diff changeset
    72
    
hgs
parents:
diff changeset
    73
    /*!
hgs
parents:
diff changeset
    74
     * @fn          GetRendererName()
hgs
parents:
diff changeset
    75
     * @bief        Retrieves the renderer implementation's name 
hgs
parents:
diff changeset
    76
     * @return      name of renderer implementation
hgs
parents:
diff changeset
    77
     */
hgs
parents:
diff changeset
    78
    const TDesC GetRendererName()
hgs
parents:
diff changeset
    79
        {
hgs
parents:
diff changeset
    80
        return iImpl->GetName();
hgs
parents:
diff changeset
    81
        }
hgs
parents:
diff changeset
    82
    
hgs
parents:
diff changeset
    83
    // OpenVG function calls
hgs
parents:
diff changeset
    84
    
hgs
parents:
diff changeset
    85
    void vgClear(TInt x, TInt y, TInt width, TInt height)
hgs
parents:
diff changeset
    86
        {
hgs
parents:
diff changeset
    87
        iImpl->vgClear(x, y, width, height);
hgs
parents:
diff changeset
    88
        }
hgs
parents:
diff changeset
    89
    
hgs
parents:
diff changeset
    90
    void vgSeti(TInt type, TInt value)
hgs
parents:
diff changeset
    91
        {
hgs
parents:
diff changeset
    92
        iImpl->vgSeti(type, value);
hgs
parents:
diff changeset
    93
        }
hgs
parents:
diff changeset
    94
    TInt vgGeti(TInt type)
hgs
parents:
diff changeset
    95
        {
hgs
parents:
diff changeset
    96
        return iImpl->vgGeti(type);
hgs
parents:
diff changeset
    97
        }    
hgs
parents:
diff changeset
    98
    void vgSetf (TInt type, TReal32 value)
hgs
parents:
diff changeset
    99
        {
hgs
parents:
diff changeset
   100
        iImpl->vgSetf(type, value);
hgs
parents:
diff changeset
   101
        }
hgs
parents:
diff changeset
   102
    
hgs
parents:
diff changeset
   103
    void vgSetfv(TInt type, TInt count, const TReal32 * values)
hgs
parents:
diff changeset
   104
        {
hgs
parents:
diff changeset
   105
        iImpl->vgSetfv(type, count, values);
hgs
parents:
diff changeset
   106
        }
hgs
parents:
diff changeset
   107
    void vgSetiv(TInt type, TInt count, const TInt * values)
hgs
parents:
diff changeset
   108
        {
hgs
parents:
diff changeset
   109
        iImpl->vgSetiv(type, count, values);
hgs
parents:
diff changeset
   110
        }    
hgs
parents:
diff changeset
   111
    void vgSetParameteri(TUint handle, TInt paramType, TInt value)
hgs
parents:
diff changeset
   112
        {
hgs
parents:
diff changeset
   113
        iImpl->vgSetParameteri(handle, paramType, value);
hgs
parents:
diff changeset
   114
        }
hgs
parents:
diff changeset
   115
    
hgs
parents:
diff changeset
   116
    void vgSetParameterf(TUint handle, TInt paramType, TReal32 value)
hgs
parents:
diff changeset
   117
        {
hgs
parents:
diff changeset
   118
        iImpl->vgSetParameterf(handle, paramType, value);
hgs
parents:
diff changeset
   119
        }
hgs
parents:
diff changeset
   120
    
hgs
parents:
diff changeset
   121
    void vgSetParameterfv(TUint object, TInt paramType, TInt count, const TReal32 * values)
hgs
parents:
diff changeset
   122
        {
hgs
parents:
diff changeset
   123
        iImpl->vgSetParameterfv(object, paramType, count, values);
hgs
parents:
diff changeset
   124
        }
hgs
parents:
diff changeset
   125
hgs
parents:
diff changeset
   126
    void vgSetColor(TUint paint, TUint rgba)
hgs
parents:
diff changeset
   127
        {
hgs
parents:
diff changeset
   128
        iImpl->vgSetColor(paint, rgba);
hgs
parents:
diff changeset
   129
        }
hgs
parents:
diff changeset
   130
    
hgs
parents:
diff changeset
   131
    void vgSetPaint(TUint paint, TUint paintModes)
hgs
parents:
diff changeset
   132
        {
hgs
parents:
diff changeset
   133
        iImpl->vgSetPaint(paint, paintModes);
hgs
parents:
diff changeset
   134
        }
hgs
parents:
diff changeset
   135
    
hgs
parents:
diff changeset
   136
    TUint vgCreatePaint()
hgs
parents:
diff changeset
   137
        {
hgs
parents:
diff changeset
   138
        return iImpl->vgCreatePaint();
hgs
parents:
diff changeset
   139
        }
hgs
parents:
diff changeset
   140
    
hgs
parents:
diff changeset
   141
    TUint vgCreatePath(TInt pathFormat, TInt datatype, TReal32 scale, TReal32 bias,
hgs
parents:
diff changeset
   142
                        TInt segmentCapacityHint, TInt coordCapacityHint, TInt capabilities)
hgs
parents:
diff changeset
   143
        {
hgs
parents:
diff changeset
   144
        return iImpl->vgCreatePath(pathFormat, datatype, scale, bias, segmentCapacityHint, coordCapacityHint, capabilities);
hgs
parents:
diff changeset
   145
        }
hgs
parents:
diff changeset
   146
    
hgs
parents:
diff changeset
   147
    void vgLoadMatrix(const TReal32 * m)
hgs
parents:
diff changeset
   148
        {
hgs
parents:
diff changeset
   149
        iImpl->vgLoadMatrix(m);
hgs
parents:
diff changeset
   150
        }
hgs
parents:
diff changeset
   151
    
hgs
parents:
diff changeset
   152
    void vgMultMatrix(const TReal32 * m)
hgs
parents:
diff changeset
   153
        {
hgs
parents:
diff changeset
   154
        iImpl->vgMultMatrix(m);
hgs
parents:
diff changeset
   155
        }
hgs
parents:
diff changeset
   156
    
hgs
parents:
diff changeset
   157
    void vgLoadIdentity()
hgs
parents:
diff changeset
   158
        {
hgs
parents:
diff changeset
   159
        iImpl->vgLoadIdentity();
hgs
parents:
diff changeset
   160
        }
hgs
parents:
diff changeset
   161
    
hgs
parents:
diff changeset
   162
    void vgScale(TReal32 sx, TReal32 sy)
hgs
parents:
diff changeset
   163
        {
hgs
parents:
diff changeset
   164
        iImpl->vgScale(sx, sy);
hgs
parents:
diff changeset
   165
        }
hgs
parents:
diff changeset
   166
    
hgs
parents:
diff changeset
   167
    void vgRotate(TReal32 angle)
hgs
parents:
diff changeset
   168
        {
hgs
parents:
diff changeset
   169
        iImpl->vgRotate(angle);
hgs
parents:
diff changeset
   170
        }
hgs
parents:
diff changeset
   171
    void vgReadPixels(void * data, TInt dataStride,TInt dataFormat,TInt sx, TInt sy,TInt width, TInt height)
hgs
parents:
diff changeset
   172
        {
hgs
parents:
diff changeset
   173
        iImpl->vgReadPixels(data,dataStride,dataFormat,sx,sy,width,height); 
hgs
parents:
diff changeset
   174
        }   
hgs
parents:
diff changeset
   175
    
hgs
parents:
diff changeset
   176
    void vgWritePixels(const void * data, TInt dataStride, TInt dataFormat,
hgs
parents:
diff changeset
   177
            TInt dx, TInt dy, TInt width, TInt height)
hgs
parents:
diff changeset
   178
        {
hgs
parents:
diff changeset
   179
        iImpl->vgWritePixels(data, dataStride, dataFormat, dx, dy, width, height);
hgs
parents:
diff changeset
   180
        }
hgs
parents:
diff changeset
   181
    
hgs
parents:
diff changeset
   182
    void vgTranslate(TReal32 tx, TReal32 ty)
hgs
parents:
diff changeset
   183
        {
hgs
parents:
diff changeset
   184
        iImpl->vgTranslate(tx, ty);
hgs
parents:
diff changeset
   185
        }
hgs
parents:
diff changeset
   186
              
hgs
parents:
diff changeset
   187
    void vgAppendPathData(TUint path, TInt numSegments,
hgs
parents:
diff changeset
   188
                                                const TUint8 * pathSegments,
hgs
parents:
diff changeset
   189
                                                const void * pathData)
hgs
parents:
diff changeset
   190
        {
hgs
parents:
diff changeset
   191
        iImpl->vgAppendPathData(path, numSegments, pathSegments, pathData);
hgs
parents:
diff changeset
   192
        }
hgs
parents:
diff changeset
   193
    
hgs
parents:
diff changeset
   194
    void vgDrawPath(TUint path, TUint paintModes)
hgs
parents:
diff changeset
   195
        {
hgs
parents:
diff changeset
   196
        iImpl->vgDrawPath(path, paintModes);
hgs
parents:
diff changeset
   197
        }
hgs
parents:
diff changeset
   198
    
hgs
parents:
diff changeset
   199
    void vgClearPath(TUint path, TUint capabilities)
hgs
parents:
diff changeset
   200
        {
hgs
parents:
diff changeset
   201
        iImpl->vgClearPath(path, capabilities);
hgs
parents:
diff changeset
   202
        }
hgs
parents:
diff changeset
   203
    
hgs
parents:
diff changeset
   204
    TInt vguRect(TUint path, TReal32 x, TReal32 y,
hgs
parents:
diff changeset
   205
                             TReal32 width, TReal32 height)
hgs
parents:
diff changeset
   206
        {
hgs
parents:
diff changeset
   207
        return iImpl->vguRect(path, x, y, width, height);
hgs
parents:
diff changeset
   208
        }
hgs
parents:
diff changeset
   209
    
hgs
parents:
diff changeset
   210
    TInt vguEllipse(TUint path, TReal32 cx, TReal32 cy,
hgs
parents:
diff changeset
   211
                                TReal32 width, TReal32 height)
hgs
parents:
diff changeset
   212
        {
hgs
parents:
diff changeset
   213
        return iImpl->vguEllipse(path, cx, cy, width, height);
hgs
parents:
diff changeset
   214
        }
hgs
parents:
diff changeset
   215
          
hgs
parents:
diff changeset
   216
    TInt vguRoundRect(TUint path, TReal32 x, TReal32 y,
hgs
parents:
diff changeset
   217
                                            TReal32 width, TReal32 height, TReal32 arcWidth, TReal32 arcHeight)
hgs
parents:
diff changeset
   218
        {
hgs
parents:
diff changeset
   219
        return iImpl->vguRoundRect(path, x, y, width, height, arcWidth, arcHeight);
hgs
parents:
diff changeset
   220
        }
hgs
parents:
diff changeset
   221
    
hgs
parents:
diff changeset
   222
    TInt vguLine(TUint path, TReal32 x0, TReal32 y0, TReal32 x1, TReal32 y1)
hgs
parents:
diff changeset
   223
        {
hgs
parents:
diff changeset
   224
        return iImpl->vguLine(path, x0, y0, x1, y1);
hgs
parents:
diff changeset
   225
        } 
hgs
parents:
diff changeset
   226
    
hgs
parents:
diff changeset
   227
    void DumpToLogFile()
hgs
parents:
diff changeset
   228
        {
hgs
parents:
diff changeset
   229
        return iImpl->DumpToLogFile();
hgs
parents:
diff changeset
   230
        }
hgs
parents:
diff changeset
   231
    void CloseLogFile()
hgs
parents:
diff changeset
   232
        {
hgs
parents:
diff changeset
   233
        return iImpl->CloseLogFile();
hgs
parents:
diff changeset
   234
        }
hgs
parents:
diff changeset
   235
    TUint vgCreateImage(TInt format, TInt width, TInt height, TInt allowedQuality)
hgs
parents:
diff changeset
   236
        {
hgs
parents:
diff changeset
   237
        return iImpl->vgCreateImage(format, width, height, allowedQuality);
hgs
parents:
diff changeset
   238
        }
hgs
parents:
diff changeset
   239
    
hgs
parents:
diff changeset
   240
    void vgClearImage(TUint image, TInt x, TInt y, TInt width, TInt height)
hgs
parents:
diff changeset
   241
        {
hgs
parents:
diff changeset
   242
        return iImpl->vgClearImage(image, x, y, width, height);
hgs
parents:
diff changeset
   243
        }
hgs
parents:
diff changeset
   244
    
hgs
parents:
diff changeset
   245
    void vgImageSubData(TUint image, const void * data, TInt dataStride,
hgs
parents:
diff changeset
   246
            TInt dataFormat, TInt x, TInt y, TInt width, TInt height)
hgs
parents:
diff changeset
   247
        {
hgs
parents:
diff changeset
   248
        return iImpl->vgImageSubData(image, data, dataStride, dataFormat, x, y, width, height);
hgs
parents:
diff changeset
   249
        }
hgs
parents:
diff changeset
   250
    
hgs
parents:
diff changeset
   251
    void vgGetPixels(TUint dst, TInt dx, TInt dy, TInt sx, TInt sy, TInt width, TInt height)
hgs
parents:
diff changeset
   252
        {
hgs
parents:
diff changeset
   253
        iImpl->vgGetPixels(dst, dx, dy, sx, sy, width, height);
hgs
parents:
diff changeset
   254
        }
hgs
parents:
diff changeset
   255
    
hgs
parents:
diff changeset
   256
    void vgDrawImage(TUint image)
hgs
parents:
diff changeset
   257
        {
hgs
parents:
diff changeset
   258
        iImpl->vgDrawImage(image);
hgs
parents:
diff changeset
   259
        }
hgs
parents:
diff changeset
   260
    
hgs
parents:
diff changeset
   261
    void vgMask(TUint mask, TInt operation, TInt x, TInt y, TInt width, TInt height)
hgs
parents:
diff changeset
   262
        {
hgs
parents:
diff changeset
   263
        return iImpl->vgMask(mask, operation, x, y, width, height);
hgs
parents:
diff changeset
   264
        }
hgs
parents:
diff changeset
   265
    
hgs
parents:
diff changeset
   266
    void vgDestroyImage(TUint aHandle)
hgs
parents:
diff changeset
   267
        {
hgs
parents:
diff changeset
   268
        iImpl->vgDestroyImage(aHandle);
hgs
parents:
diff changeset
   269
        }
hgs
parents:
diff changeset
   270
    
hgs
parents:
diff changeset
   271
    void vgDestroyPaint(TUint aHandle)
hgs
parents:
diff changeset
   272
        {
hgs
parents:
diff changeset
   273
        iImpl->vgDestroyPaint(aHandle);
hgs
parents:
diff changeset
   274
        }
hgs
parents:
diff changeset
   275
    
hgs
parents:
diff changeset
   276
    void vgDestroyPath(TUint aHandle)
hgs
parents:
diff changeset
   277
        {
hgs
parents:
diff changeset
   278
        iImpl->vgDestroyPath(aHandle);
hgs
parents:
diff changeset
   279
        }
hgs
parents:
diff changeset
   280
hgs
parents:
diff changeset
   281
    void ToggleReset()
hgs
parents:
diff changeset
   282
        {
hgs
parents:
diff changeset
   283
        iImpl->ToggleReset();
hgs
parents:
diff changeset
   284
        }
hgs
parents:
diff changeset
   285
    
hgs
parents:
diff changeset
   286
    TInt vgGetError()
hgs
parents:
diff changeset
   287
        {
hgs
parents:
diff changeset
   288
        return iImpl->vgGetError();
hgs
parents:
diff changeset
   289
        }
hgs
parents:
diff changeset
   290
    
hgs
parents:
diff changeset
   291
    void vgFlush()
hgs
parents:
diff changeset
   292
        {
hgs
parents:
diff changeset
   293
        iImpl->vgFlush();
hgs
parents:
diff changeset
   294
        }
hgs
parents:
diff changeset
   295
hgs
parents:
diff changeset
   296
    /*!
hgs
parents:
diff changeset
   297
     * @fn          GetCurrentSurface()
hgs
parents:
diff changeset
   298
     * @bief        Retrieves the surface associated with the renderer
hgs
parents:
diff changeset
   299
     * @return      Renderer surface
hgs
parents:
diff changeset
   300
     */
hgs
parents:
diff changeset
   301
    CVGSurface * GetCurrentSurface()
hgs
parents:
diff changeset
   302
        {
hgs
parents:
diff changeset
   303
        return this->iCurrentSurface;
hgs
parents:
diff changeset
   304
        }
hgs
parents:
diff changeset
   305
    const TPtrC8 TLVEncodedData() const
hgs
parents:
diff changeset
   306
        {
hgs
parents:
diff changeset
   307
        return (iImpl->TLVEncodedData());    
hgs
parents:
diff changeset
   308
        }
hgs
parents:
diff changeset
   309
    
hgs
parents:
diff changeset
   310
private:
hgs
parents:
diff changeset
   311
hgs
parents:
diff changeset
   312
    CVGRenderer();
hgs
parents:
diff changeset
   313
hgs
parents:
diff changeset
   314
    /**
hgs
parents:
diff changeset
   315
     * default constructor for performing 2nd stage construction
hgs
parents:
diff changeset
   316
     */
hgs
parents:
diff changeset
   317
    void ConstructL(SVGRendererId , TInt );
hgs
parents:
diff changeset
   318
hgs
parents:
diff changeset
   319
    MVGRendererImpl *   iImpl;
hgs
parents:
diff changeset
   320
    CVGSurface *        iCurrentSurface;
hgs
parents:
diff changeset
   321
    RLibrary            iLibrary;
hgs
parents:
diff changeset
   322
    };
hgs
parents:
diff changeset
   323
hgs
parents:
diff changeset
   324
#endif // VGRENDERER_H