svgtopt/gfx2d/inc/GfxImageTransformer.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) 2002 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:  Graphics Extension Library 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 GFXIMAGETRANSFORMER_H
hgs
parents:
diff changeset
    20
#define GFXIMAGETRANSFORMER_H
hgs
parents:
diff changeset
    21
hgs
parents:
diff changeset
    22
#include <e32std.h>
hgs
parents:
diff changeset
    23
#include <fbs.h>
hgs
parents:
diff changeset
    24
#include <bitstd.h>
hgs
parents:
diff changeset
    25
hgs
parents:
diff changeset
    26
#include "GfxFloatFixPt.h"
hgs
parents:
diff changeset
    27
#include "GfxAffineTransform.h"
hgs
parents:
diff changeset
    28
#include "GfxRenderingHints.h"
hgs
parents:
diff changeset
    29
#include "GfxRectangle2D.h"
hgs
parents:
diff changeset
    30
#include "GfxPoint2D.h"
hgs
parents:
diff changeset
    31
#include "GfxColor.h"
hgs
parents:
diff changeset
    32
hgs
parents:
diff changeset
    33
hgs
parents:
diff changeset
    34
class CVGRenderer;
hgs
parents:
diff changeset
    35
hgs
parents:
diff changeset
    36
/**
hgs
parents:
diff changeset
    37
 * Class to perform transformation on an image.
hgs
parents:
diff changeset
    38
 *
hgs
parents:
diff changeset
    39
 *  @lib Gfx2D.lib
hgs
parents:
diff changeset
    40
 *  @since 1.0
hgs
parents:
diff changeset
    41
 */
hgs
parents:
diff changeset
    42
class TGfxImageTransformer
hgs
parents:
diff changeset
    43
    {
hgs
parents:
diff changeset
    44
    public:
hgs
parents:
diff changeset
    45
hgs
parents:
diff changeset
    46
        /**
hgs
parents:
diff changeset
    47
         * Contructor.
hgs
parents:
diff changeset
    48
         *
hgs
parents:
diff changeset
    49
         * @since 1.0
hgs
parents:
diff changeset
    50
         * @param aTransform : transform to apply.
hgs
parents:
diff changeset
    51
         * @param aInterpolation : image interpolation
hgs
parents:
diff changeset
    52
         * @return
hgs
parents:
diff changeset
    53
         */
hgs
parents:
diff changeset
    54
                            TGfxImageTransformer( TGfxAffineTransform* aTransform, CVGRenderer * aRenderer);
hgs
parents:
diff changeset
    55
hgs
parents:
diff changeset
    56
hgs
parents:
diff changeset
    57
        /**
hgs
parents:
diff changeset
    58
         * Draw the source image onto the destination with the transformation defined by
hgs
parents:
diff changeset
    59
         * this object, blending with the alpha value.
hgs
parents:
diff changeset
    60
         *
hgs
parents:
diff changeset
    61
         * @since 1.0
hgs
parents:
diff changeset
    62
         * @param aSrc : source image
hgs
parents:
diff changeset
    63
         * @param aPoint : origin point of the text rectangle.
hgs
parents:
diff changeset
    64
         * @param aDst : destination image buffer.
hgs
parents:
diff changeset
    65
         * @param aDstWidth : destination image width.
hgs
parents:
diff changeset
    66
         * @param aDstHeight : destination image height.
hgs
parents:
diff changeset
    67
         * @param aAlpha : blending alpha value.
hgs
parents:
diff changeset
    68
         * @param aClipRect :
hgs
parents:
diff changeset
    69
         * @param aReverse : ETrue if copying image from aDst to aSrc.
hgs
parents:
diff changeset
    70
         *                   This is a special case and used to copy background image to text box.
hgs
parents:
diff changeset
    71
         *                   EFalse is for regular use.
hgs
parents:
diff changeset
    72
         * @return
hgs
parents:
diff changeset
    73
         */
hgs
parents:
diff changeset
    74
         void               Draw( CFbsBitmap* aSrc,
hgs
parents:
diff changeset
    75
                                          const TGfxPoint2D& p,
hgs
parents:
diff changeset
    76
										  TUint32* aDst,
hgs
parents:
diff changeset
    77
										  TInt aDstWidth,
hgs
parents:
diff changeset
    78
										  TInt aDstHeight,
hgs
parents:
diff changeset
    79
										  TUint8 aAlpha,
hgs
parents:
diff changeset
    80
                                          TGfxColor aTransparentColor,
hgs
parents:
diff changeset
    81
										  const TRect& aClipRect,
hgs
parents:
diff changeset
    82
										  TBool aReverse = EFalse
hgs
parents:
diff changeset
    83
										  );
hgs
parents:
diff changeset
    84
hgs
parents:
diff changeset
    85
        /**
hgs
parents:
diff changeset
    86
         * Draw the source image onto the destination with the transformation defined by
hgs
parents:
diff changeset
    87
         * this object.  Uses the alpha bits of the EColor16MU to blend.  Only EColor16MU mode
hgs
parents:
diff changeset
    88
         * for aSrc is allowed.
hgs
parents:
diff changeset
    89
         *
hgs
parents:
diff changeset
    90
         * @since 1.0
hgs
parents:
diff changeset
    91
         * @param aSrc : source image
hgs
parents:
diff changeset
    92
         * @param aPoint : origin point of the text rectangle.
hgs
parents:
diff changeset
    93
         * @param aDst : destination image buffer.
hgs
parents:
diff changeset
    94
         * @param aDstWidth : destination image width.
hgs
parents:
diff changeset
    95
         * @param aDstHeight : destination image height.
hgs
parents:
diff changeset
    96
         * @param aClipRect :
hgs
parents:
diff changeset
    97
         * @param aReverse : ETrue if copying image from aDst to aSrc.
hgs
parents:
diff changeset
    98
         *                   This is a special case and used to copy background image to text box.
hgs
parents:
diff changeset
    99
         *                   EFalse is for regular use.
hgs
parents:
diff changeset
   100
         * @return
hgs
parents:
diff changeset
   101
         */
hgs
parents:
diff changeset
   102
         void               Draw( CFbsBitmap* aSrc,
hgs
parents:
diff changeset
   103
                                          const TGfxPoint2D& p,
hgs
parents:
diff changeset
   104
										  TUint32* aDst,
hgs
parents:
diff changeset
   105
										  TInt aDstWidth,
hgs
parents:
diff changeset
   106
										  TInt aDstHeight,
hgs
parents:
diff changeset
   107
										  const TRect& aClipRect
hgs
parents:
diff changeset
   108
										  );
hgs
parents:
diff changeset
   109
hgs
parents:
diff changeset
   110
hgs
parents:
diff changeset
   111
        /**
hgs
parents:
diff changeset
   112
         * Get the bounding box for the given image once transformed.
hgs
parents:
diff changeset
   113
         *
hgs
parents:
diff changeset
   114
         * @since 1.0
hgs
parents:
diff changeset
   115
         * @param aSrc : source image
hgs
parents:
diff changeset
   116
         * @param aOffset : offset.
hgs
parents:
diff changeset
   117
         * @return
hgs
parents:
diff changeset
   118
         */
hgs
parents:
diff changeset
   119
         TGfxRectangle2D    GetTransformedBound( CFbsBitmap* aSrc,
hgs
parents:
diff changeset
   120
                                                         const TGfxPoint2D& aOffset );
hgs
parents:
diff changeset
   121
        /**
hgs
parents:
diff changeset
   122
         * Draw the source image onto the destination with the transformation defined by
hgs
parents:
diff changeset
   123
         * this object, blending with the alpha value. When aReverse is ETrue, do the reverse.
hgs
parents:
diff changeset
   124
         *
hgs
parents:
diff changeset
   125
         * @since 1.0
hgs
parents:
diff changeset
   126
         * @param aSrc : source image
hgs
parents:
diff changeset
   127
         * @param aPoint : origin point of the text rectangle.
hgs
parents:
diff changeset
   128
         * @param aDstWidth : destination image width.
hgs
parents:
diff changeset
   129
         * @param aDstHeight : destination image height.
hgs
parents:
diff changeset
   130
         * @param aClipRect :
hgs
parents:
diff changeset
   131
         * @param aReverse : ETrue if copying image from aDst to aSrc.
hgs
parents:
diff changeset
   132
         *                   This is a special case and used to copy background image to text box.
hgs
parents:
diff changeset
   133
         *                   EFalse is for regular use.
hgs
parents:
diff changeset
   134
         * @return
hgs
parents:
diff changeset
   135
         */
hgs
parents:
diff changeset
   136
         void       ImageBlend( CFbsBitmap* aSrc,
hgs
parents:
diff changeset
   137
                                          const TGfxPoint2D& p,
hgs
parents:
diff changeset
   138
										  TInt aDstWidth,
hgs
parents:
diff changeset
   139
										  TInt aDstHeight,
hgs
parents:
diff changeset
   140
										  const TRect& aClipRect,
hgs
parents:
diff changeset
   141
										  TBool aReverse = EFalse
hgs
parents:
diff changeset
   142
										  );
hgs
parents:
diff changeset
   143
hgs
parents:
diff changeset
   144
        /**
hgs
parents:
diff changeset
   145
         * Compute scanline starting/end position for the rectangle.
hgs
parents:
diff changeset
   146
         *
hgs
parents:
diff changeset
   147
         * @since 1.0
hgs
parents:
diff changeset
   148
         * @param y : current rectangle's height
hgs
parents:
diff changeset
   149
         * @param rect : rectangle that needs to be computed.
hgs
parents:
diff changeset
   150
         * @param north : transformed corner.
hgs
parents:
diff changeset
   151
         * @param west :  transformed corner.
hgs
parents:
diff changeset
   152
         * @param east :  transformed corner.
hgs
parents:
diff changeset
   153
         * @param south :  transformed corner.
hgs
parents:
diff changeset
   154
         * @param xstart : computed x coordinates for start position
hgs
parents:
diff changeset
   155
         * @param xend : computed x coordinates for end position
hgs
parents:
diff changeset
   156
         *
hgs
parents:
diff changeset
   157
         * @return none
hgs
parents:
diff changeset
   158
         */
hgs
parents:
diff changeset
   159
        void ComputeXPositions(TFloatFixPt y, TRect rect, TGfxPoint2D north, TGfxPoint2D west,
hgs
parents:
diff changeset
   160
            TGfxPoint2D east, TGfxPoint2D south, TInt& xstart, TInt& xend);
hgs
parents:
diff changeset
   161
hgs
parents:
diff changeset
   162
        /**
hgs
parents:
diff changeset
   163
         * compute coordinates from transformed 4 points.
hgs
parents:
diff changeset
   164
         *
hgs
parents:
diff changeset
   165
         * @since 1.0
hgs
parents:
diff changeset
   166
         *
hgs
parents:
diff changeset
   167
         * @return none
hgs
parents:
diff changeset
   168
         */
hgs
parents:
diff changeset
   169
        void SortCoordinates(TGfxPoint2D& origin, TGfxPoint2D& top,
hgs
parents:
diff changeset
   170
            TGfxPoint2D& north, TGfxPoint2D& south, TGfxPoint2D& right,
hgs
parents:
diff changeset
   171
            TGfxPoint2D& east, TGfxPoint2D& west, TGfxPoint2D& corner,
hgs
parents:
diff changeset
   172
            TGfxPoint2D aP, const TInt srcWidth, const TInt srcHeight);
hgs
parents:
diff changeset
   173
hgs
parents:
diff changeset
   174
    private:
hgs
parents:
diff changeset
   175
hgs
parents:
diff changeset
   176
        TGfxAffineTransform*        iTransform;
hgs
parents:
diff changeset
   177
        CVGRenderer *           iVgRenderer;
hgs
parents:
diff changeset
   178
    };
hgs
parents:
diff changeset
   179
hgs
parents:
diff changeset
   180
#endif      // GFXIMAGETRANSFORMER_H