svgtopt/gfx2d/inc/GfxFlatteningPathIterator.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 GFXFLATTENINGPATHITERATOR_H
hgs
parents:
diff changeset
    20
#define GFXFLATTENINGPATHITERATOR_H
hgs
parents:
diff changeset
    21
hgs
parents:
diff changeset
    22
#include <e32base.h>
hgs
parents:
diff changeset
    23
#include <e32std.h>
hgs
parents:
diff changeset
    24
hgs
parents:
diff changeset
    25
#include "GfxFloatFixPt.h"
hgs
parents:
diff changeset
    26
#include "GfxPathIterator.h"
hgs
parents:
diff changeset
    27
hgs
parents:
diff changeset
    28
hgs
parents:
diff changeset
    29
hgs
parents:
diff changeset
    30
class TGfxAffineTransform;
hgs
parents:
diff changeset
    31
class MGfxShape;
hgs
parents:
diff changeset
    32
hgs
parents:
diff changeset
    33
/**
hgs
parents:
diff changeset
    34
 * This class provides the methods to smooth a path.
hgs
parents:
diff changeset
    35
 *
hgs
parents:
diff changeset
    36
 *  @lib Gfx2D.lib
hgs
parents:
diff changeset
    37
 *  @since 1.0
hgs
parents:
diff changeset
    38
 */
hgs
parents:
diff changeset
    39
class CGfxFlatteningPathIterator : public CGfxPathIterator
hgs
parents:
diff changeset
    40
    {
hgs
parents:
diff changeset
    41
    public:
hgs
parents:
diff changeset
    42
hgs
parents:
diff changeset
    43
        /**
hgs
parents:
diff changeset
    44
         * Two-phase constructor.
hgs
parents:
diff changeset
    45
         *
hgs
parents:
diff changeset
    46
         * @since 1.0
hgs
parents:
diff changeset
    47
         * @param aSrc : source of path of flatten
hgs
parents:
diff changeset
    48
         * @param aAt : transform to apply.
hgs
parents:
diff changeset
    49
         * @param aFlatness : degree of flattening to apply.
hgs
parents:
diff changeset
    50
         * @param aLimit : maximum number of points used for flattening.
hgs
parents:
diff changeset
    51
         * @return
hgs
parents:
diff changeset
    52
         */
hgs
parents:
diff changeset
    53
         static CGfxFlatteningPathIterator*     NewL( MGfxShape* aSrc,
hgs
parents:
diff changeset
    54
                                                              TGfxAffineTransform* aAt,
hgs
parents:
diff changeset
    55
                                                              TInt32 aLimit );
hgs
parents:
diff changeset
    56
hgs
parents:
diff changeset
    57
hgs
parents:
diff changeset
    58
        /**
hgs
parents:
diff changeset
    59
         * Destructor
hgs
parents:
diff changeset
    60
         *
hgs
parents:
diff changeset
    61
         * @since 1.0
hgs
parents:
diff changeset
    62
         * @return
hgs
parents:
diff changeset
    63
         */
hgs
parents:
diff changeset
    64
         virtual                                ~CGfxFlatteningPathIterator();
hgs
parents:
diff changeset
    65
hgs
parents:
diff changeset
    66
hgs
parents:
diff changeset
    67
        /**
hgs
parents:
diff changeset
    68
         * Set the degree of flattening to apply.
hgs
parents:
diff changeset
    69
         *
hgs
parents:
diff changeset
    70
         * @since 1.0
hgs
parents:
diff changeset
    71
         * @param aFlatness : degree of flattening.
hgs
parents:
diff changeset
    72
         * @return
hgs
parents:
diff changeset
    73
         */
hgs
parents:
diff changeset
    74
hgs
parents:
diff changeset
    75
         void                                   SetFlatness( TFloatFixPt& aFlatness );
hgs
parents:
diff changeset
    76
hgs
parents:
diff changeset
    77
        /**
hgs
parents:
diff changeset
    78
         * Set the recursion level.
hgs
parents:
diff changeset
    79
         *
hgs
parents:
diff changeset
    80
         * @since 1.0
hgs
parents:
diff changeset
    81
         * @param aLimit : recursion level.
hgs
parents:
diff changeset
    82
         * @return
hgs
parents:
diff changeset
    83
         */
hgs
parents:
diff changeset
    84
         void                                   SetRecursionLimit( TInt32 aLimit );
hgs
parents:
diff changeset
    85
hgs
parents:
diff changeset
    86
        /**
hgs
parents:
diff changeset
    87
         * Get the flattening level..
hgs
parents:
diff changeset
    88
         *
hgs
parents:
diff changeset
    89
         * @since 1.0
hgs
parents:
diff changeset
    90
         * @param aLimit : recursion level.
hgs
parents:
diff changeset
    91
         * @return flattening value.
hgs
parents:
diff changeset
    92
         */
hgs
parents:
diff changeset
    93
hgs
parents:
diff changeset
    94
         TFloatFixPt                                 Flatness();
hgs
parents:
diff changeset
    95
hgs
parents:
diff changeset
    96
        /**
hgs
parents:
diff changeset
    97
         * Get the recursion level.
hgs
parents:
diff changeset
    98
         *
hgs
parents:
diff changeset
    99
         * @since 1.0
hgs
parents:
diff changeset
   100
         * @return the recursion level.
hgs
parents:
diff changeset
   101
         */
hgs
parents:
diff changeset
   102
         TInt32                                 RecursionLimit();
hgs
parents:
diff changeset
   103
hgs
parents:
diff changeset
   104
hgs
parents:
diff changeset
   105
        /**
hgs
parents:
diff changeset
   106
         * Get the points defining the current segment of iteration.
hgs
parents:
diff changeset
   107
         *
hgs
parents:
diff changeset
   108
         * @since 1.0
hgs
parents:
diff changeset
   109
         * @param aCoords : array to store segment points.
hgs
parents:
diff changeset
   110
         * @return segment type.
hgs
parents:
diff changeset
   111
         */
hgs
parents:
diff changeset
   112
         TGfxSegType                            CurrentSegment( TFloatFixPt* aCoords );
hgs
parents:
diff changeset
   113
hgs
parents:
diff changeset
   114
        /**
hgs
parents:
diff changeset
   115
         * Determine wether the end has been reached.
hgs
parents:
diff changeset
   116
         *
hgs
parents:
diff changeset
   117
         * @since 1.0
hgs
parents:
diff changeset
   118
         * @return true, if end of iterator reached.
hgs
parents:
diff changeset
   119
         */
hgs
parents:
diff changeset
   120
         TBool                                  IsDone();
hgs
parents:
diff changeset
   121
hgs
parents:
diff changeset
   122
        /**
hgs
parents:
diff changeset
   123
         * Cycle to the next segment of this iterator.
hgs
parents:
diff changeset
   124
         *
hgs
parents:
diff changeset
   125
         * @since 1.0
hgs
parents:
diff changeset
   126
         * @return
hgs
parents:
diff changeset
   127
         */
hgs
parents:
diff changeset
   128
         void                                   NextL();
hgs
parents:
diff changeset
   129
hgs
parents:
diff changeset
   130
hgs
parents:
diff changeset
   131
        /**
hgs
parents:
diff changeset
   132
         * Create a polygon from iterator.  This method is does nothing.
hgs
parents:
diff changeset
   133
         *
hgs
parents:
diff changeset
   134
         * @since 1.0
hgs
parents:
diff changeset
   135
         * @return
hgs
parents:
diff changeset
   136
         */
hgs
parents:
diff changeset
   137
         void PolygonizeL( CGfxEdgeListP* aRenderer, TInt aFlatness );
hgs
parents:
diff changeset
   138
hgs
parents:
diff changeset
   139
    private:
hgs
parents:
diff changeset
   140
hgs
parents:
diff changeset
   141
        /**
hgs
parents:
diff changeset
   142
         * Constructor
hgs
parents:
diff changeset
   143
         *
hgs
parents:
diff changeset
   144
         * @since 1.0
hgs
parents:
diff changeset
   145
         * @param aFlatness : degree of flattening to apply.
hgs
parents:
diff changeset
   146
         * @param aLimit : maximum number of points used for flattening.
hgs
parents:
diff changeset
   147
         * @return
hgs
parents:
diff changeset
   148
         */
hgs
parents:
diff changeset
   149
                            CGfxFlatteningPathIterator( TInt32 aLimit );
hgs
parents:
diff changeset
   150
hgs
parents:
diff changeset
   151
        /**
hgs
parents:
diff changeset
   152
         * Second phase of constrction.
hgs
parents:
diff changeset
   153
         *
hgs
parents:
diff changeset
   154
         * @since 1.0
hgs
parents:
diff changeset
   155
         * @param aSrc : source of path of flatten
hgs
parents:
diff changeset
   156
         * @param aAt : transform to apply.
hgs
parents:
diff changeset
   157
         * @return
hgs
parents:
diff changeset
   158
         */
hgs
parents:
diff changeset
   159
        void                ConstructL( MGfxShape* aSrc,
hgs
parents:
diff changeset
   160
                                        TGfxAffineTransform* aAt );
hgs
parents:
diff changeset
   161
hgs
parents:
diff changeset
   162
hgs
parents:
diff changeset
   163
        /**
hgs
parents:
diff changeset
   164
         * Create a quadratic sub-curve.
hgs
parents:
diff changeset
   165
         *
hgs
parents:
diff changeset
   166
         * @since 1.0
hgs
parents:
diff changeset
   167
         * @param aCtrlPoints : quadratic control points.
hgs
parents:
diff changeset
   168
         * @return
hgs
parents:
diff changeset
   169
         */
hgs
parents:
diff changeset
   170
        void                CreateSubcurveQuadL( RArray<TFloatFixPt>* aCtrlPoints );
hgs
parents:
diff changeset
   171
hgs
parents:
diff changeset
   172
        /**
hgs
parents:
diff changeset
   173
         * Create a cubic sub-curve.
hgs
parents:
diff changeset
   174
         *
hgs
parents:
diff changeset
   175
         * @since 1.0
hgs
parents:
diff changeset
   176
         * @param aCtrlPoints : cubic control points.
hgs
parents:
diff changeset
   177
         * @return
hgs
parents:
diff changeset
   178
         */
hgs
parents:
diff changeset
   179
        void                CreateSubcurveCubicL( RArray<TFloatFixPt>* aCtrlPoints );
hgs
parents:
diff changeset
   180
hgs
parents:
diff changeset
   181
    private:
hgs
parents:
diff changeset
   182
        RArray<TFloatFixPt>*     iCoords;
hgs
parents:
diff changeset
   183
        TInt32              iIdx;
hgs
parents:
diff changeset
   184
        CGfxPathIterator*   iSrc;
hgs
parents:
diff changeset
   185
        TFloatFixPt              iLastX;
hgs
parents:
diff changeset
   186
        TFloatFixPt              iLastY;
hgs
parents:
diff changeset
   187
        TGfxSegType         iSegType;
hgs
parents:
diff changeset
   188
        TBool               iIsDone;
hgs
parents:
diff changeset
   189
hgs
parents:
diff changeset
   190
        TInt32              iLimit;
hgs
parents:
diff changeset
   191
hgs
parents:
diff changeset
   192
        TFloatFixPt              iFlatness;
hgs
parents:
diff changeset
   193
hgs
parents:
diff changeset
   194
hgs
parents:
diff changeset
   195
hgs
parents:
diff changeset
   196
    };
hgs
parents:
diff changeset
   197
hgs
parents:
diff changeset
   198
#endif      // GFXFLATTENINGPATHITERATOR_H