svgtopt/SVG/SVGImpl/src/SVGPathDataParser.cpp
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 source 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
#include "SVGPathDataParser.h"
hgs
parents:
diff changeset
    20
#include "SVGPointLexer.h"
hgs
parents:
diff changeset
    21
hgs
parents:
diff changeset
    22
#include "GfxFloatFixPt.h"
hgs
parents:
diff changeset
    23
#include "GfxAffineTransform.h"
hgs
parents:
diff changeset
    24
#include "GfxFlatteningPathIterator.h"
hgs
parents:
diff changeset
    25
hgs
parents:
diff changeset
    26
hgs
parents:
diff changeset
    27
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    28
//
hgs
parents:
diff changeset
    29
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    30
void TSvgPathDataParser::ParsePathData( const TDesC& aData,
hgs
parents:
diff changeset
    31
                                          CGfxGeneralPath* aPath )
hgs
parents:
diff changeset
    32
    {
hgs
parents:
diff changeset
    33
hgs
parents:
diff changeset
    34
		TRAPD( error, ParsePathDataL( aData, aPath ) );
hgs
parents:
diff changeset
    35
		if ( error != KErrNone )
hgs
parents:
diff changeset
    36
		     {
hgs
parents:
diff changeset
    37
			 // error processing
hgs
parents:
diff changeset
    38
			 return;
hgs
parents:
diff changeset
    39
	         }
hgs
parents:
diff changeset
    40
    }
hgs
parents:
diff changeset
    41
hgs
parents:
diff changeset
    42
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    43
//
hgs
parents:
diff changeset
    44
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    45
void TSvgPathDataParser::ParsePathDataL( const TDesC& aData,
hgs
parents:
diff changeset
    46
                                           CGfxGeneralPath* aPath )
hgs
parents:
diff changeset
    47
    {
hgs
parents:
diff changeset
    48
    TUint8 lPrevCom = '\0';
hgs
parents:
diff changeset
    49
	TFloatFixPt xy[6];
hgs
parents:
diff changeset
    50
	TInt32 rslt = ETrue;
hgs
parents:
diff changeset
    51
	TUint8 com;
hgs
parents:
diff changeset
    52
    TUint8 lPrevCom2 = '\0';
hgs
parents:
diff changeset
    53
hgs
parents:
diff changeset
    54
    TSvgPointLexer svgplex( aData );
hgs
parents:
diff changeset
    55
hgs
parents:
diff changeset
    56
    TFloatFixPt KZero;
hgs
parents:
diff changeset
    57
    TFloatFixPt KMinVal = 0.01f;
hgs
parents:
diff changeset
    58
    TFloatFixPt KOne( KFloatFixOne );
hgs
parents:
diff changeset
    59
hgs
parents:
diff changeset
    60
    while ( svgplex.GetCommand ( com ) )
hgs
parents:
diff changeset
    61
        {
hgs
parents:
diff changeset
    62
hgs
parents:
diff changeset
    63
			// Reset for command procesing
hgs
parents:
diff changeset
    64
			if( com == '\0' )
hgs
parents:
diff changeset
    65
				{
hgs
parents:
diff changeset
    66
				if( lPrevCom == 'z' ||lPrevCom == 'Z' )
hgs
parents:
diff changeset
    67
					{
hgs
parents:
diff changeset
    68
					aPath->Reset();
hgs
parents:
diff changeset
    69
					break ;
hgs
parents:
diff changeset
    70
					}
hgs
parents:
diff changeset
    71
				// As per 1.2  spec 8.3.2 The "moveto" commands
hgs
parents:
diff changeset
    72
	            // If a 'moveto' is followed by multiple pairs of coordinates without explicit commands,
hgs
parents:
diff changeset
    73
	            // the subsequent pairs shall be treated as implicit 'lineto' commands.
hgs
parents:
diff changeset
    74
hgs
parents:
diff changeset
    75
				else if( lPrevCom == 'm')
hgs
parents:
diff changeset
    76
					{
hgs
parents:
diff changeset
    77
					com = 'l';
hgs
parents:
diff changeset
    78
					}
hgs
parents:
diff changeset
    79
				else if( lPrevCom == 'M' )
hgs
parents:
diff changeset
    80
					{
hgs
parents:
diff changeset
    81
					com = 'L';
hgs
parents:
diff changeset
    82
					}
hgs
parents:
diff changeset
    83
				else
hgs
parents:
diff changeset
    84
					{
hgs
parents:
diff changeset
    85
					com = lPrevCom;
hgs
parents:
diff changeset
    86
					}
hgs
parents:
diff changeset
    87
				}
hgs
parents:
diff changeset
    88
			else
hgs
parents:
diff changeset
    89
				{
hgs
parents:
diff changeset
    90
				lPrevCom = com;
hgs
parents:
diff changeset
    91
				}
hgs
parents:
diff changeset
    92
hgs
parents:
diff changeset
    93
				switch ( com )
hgs
parents:
diff changeset
    94
					{
hgs
parents:
diff changeset
    95
					case 'M':
hgs
parents:
diff changeset
    96
							rslt = svgplex.GetNextWithNumOfPoints( xy ,TInt (2) );
hgs
parents:
diff changeset
    97
							if (rslt && lPrevCom2 == 'M')
hgs
parents:
diff changeset
    98
								{
hgs
parents:
diff changeset
    99
									//AJD do we want to remove this
hgs
parents:
diff changeset
   100
									// i.e. d="M 20 20 M 10 10 L 15 15
hgs
parents:
diff changeset
   101
									// has a bounding box of 5,5,10,10 or 10,10,10,10
hgs
parents:
diff changeset
   102
									//aPath->RemoveLastPathCommand();
hgs
parents:
diff changeset
   103
								}
hgs
parents:
diff changeset
   104
							if(rslt)
hgs
parents:
diff changeset
   105
                                {
hgs
parents:
diff changeset
   106
                                aPath->MoveToL( xy[0], xy[1], ETrue );
hgs
parents:
diff changeset
   107
                                }
hgs
parents:
diff changeset
   108
                            break;
hgs
parents:
diff changeset
   109
                    case 'm':
hgs
parents:
diff changeset
   110
                            rslt = svgplex.GetNextWithNumOfPoints( xy ,TInt (2) );
hgs
parents:
diff changeset
   111
                            // added to change values from 0.0 to 0.01f if both the co-oridnates
hgs
parents:
diff changeset
   112
                            // are having value 0.0. 
hgs
parents:
diff changeset
   113
                            // fix for bug "CGSR-78X9V2"
hgs
parents:
diff changeset
   114
                            if(xy[0] == KZero && xy[1] == KZero)
hgs
parents:
diff changeset
   115
                               {
hgs
parents:
diff changeset
   116
                            	 xy[0] = KMinVal;
hgs
parents:
diff changeset
   117
                            	 xy[1] = KMinVal;
hgs
parents:
diff changeset
   118
                               }
hgs
parents:
diff changeset
   119
                            if(rslt)
hgs
parents:
diff changeset
   120
                               {
hgs
parents:
diff changeset
   121
                               aPath->MoveToL( xy[0], xy[1], EFalse );
hgs
parents:
diff changeset
   122
                               }
hgs
parents:
diff changeset
   123
                            
hgs
parents:
diff changeset
   124
							break;
hgs
parents:
diff changeset
   125
					case 'L':
hgs
parents:
diff changeset
   126
							rslt = svgplex.GetNextWithNumOfPoints( xy ,TInt (2) );
hgs
parents:
diff changeset
   127
							if(rslt)
hgs
parents:
diff changeset
   128
								{
hgs
parents:
diff changeset
   129
								aPath->LineToL( xy[0], xy[1], ETrue );
hgs
parents:
diff changeset
   130
								}
hgs
parents:
diff changeset
   131
							break;
hgs
parents:
diff changeset
   132
					case 'H':
hgs
parents:
diff changeset
   133
							rslt = svgplex.GetNextWithNumOfPoints( xy ,TInt (1) );
hgs
parents:
diff changeset
   134
							if(rslt)
hgs
parents:
diff changeset
   135
								{
hgs
parents:
diff changeset
   136
								aPath->HorizonToL( xy[0], ETrue );
hgs
parents:
diff changeset
   137
								}
hgs
parents:
diff changeset
   138
							break;
hgs
parents:
diff changeset
   139
					case 'V':
hgs
parents:
diff changeset
   140
							rslt = svgplex.GetNextWithNumOfPoints( xy ,TInt (1) );
hgs
parents:
diff changeset
   141
							if(rslt)
hgs
parents:
diff changeset
   142
                                {
hgs
parents:
diff changeset
   143
                                aPath->VertToL( xy[0], ETrue );
hgs
parents:
diff changeset
   144
                                }
hgs
parents:
diff changeset
   145
                            break;
hgs
parents:
diff changeset
   146
                    case 'l':
hgs
parents:
diff changeset
   147
                            rslt = svgplex.GetNextWithNumOfPoints( xy ,TInt (2) );
hgs
parents:
diff changeset
   148
                            // added to change values from 0.0 to 0.01f if both the co-oridnates
hgs
parents:
diff changeset
   149
                            // are having value 0.0. 
hgs
parents:
diff changeset
   150
                            // fix for bug "CGSR-78X9V2"
hgs
parents:
diff changeset
   151
                            if(xy[0] == KZero && xy[1] == KZero)
hgs
parents:
diff changeset
   152
                               {
hgs
parents:
diff changeset
   153
                               xy[0] = KMinVal;
hgs
parents:
diff changeset
   154
                               xy[1] = KMinVal;
hgs
parents:
diff changeset
   155
                               }
hgs
parents:
diff changeset
   156
                           	if(rslt)
hgs
parents:
diff changeset
   157
							   {
hgs
parents:
diff changeset
   158
							   aPath->LineToL( xy[0], xy[1], EFalse );
hgs
parents:
diff changeset
   159
							   }
hgs
parents:
diff changeset
   160
						    break;
hgs
parents:
diff changeset
   161
                    case 'h':
hgs
parents:
diff changeset
   162
                            rslt = svgplex.GetNextWithNumOfPoints( xy ,TInt (1) );
hgs
parents:
diff changeset
   163
                            // added to change values from 0.0 to 0.01f if both the co-oridnates
hgs
parents:
diff changeset
   164
                            // are having value 0.0. 
hgs
parents:
diff changeset
   165
                            // fix for bug "CGSR-78X9V2"
hgs
parents:
diff changeset
   166
                            if(xy[0] == KZero && xy[1] == KZero)
hgs
parents:
diff changeset
   167
                               {
hgs
parents:
diff changeset
   168
                               xy[0] = KMinVal;
hgs
parents:
diff changeset
   169
                               xy[1] = KMinVal;
hgs
parents:
diff changeset
   170
                               }
hgs
parents:
diff changeset
   171
                            if(rslt)
hgs
parents:
diff changeset
   172
                               {
hgs
parents:
diff changeset
   173
                               aPath->HorizonToL( xy[0], EFalse );
hgs
parents:
diff changeset
   174
                               }
hgs
parents:
diff changeset
   175
                             
hgs
parents:
diff changeset
   176
                            break;
hgs
parents:
diff changeset
   177
                    case 'v':
hgs
parents:
diff changeset
   178
                            rslt = svgplex.GetNextWithNumOfPoints( xy ,TInt (1) );
hgs
parents:
diff changeset
   179
                            // added to change values from 0.0 to 0.01f if both the co-oridnates
hgs
parents:
diff changeset
   180
                            // are having value 0.0. 
hgs
parents:
diff changeset
   181
                            // fix for bug "CGSR-78X9V2"
hgs
parents:
diff changeset
   182
                            if(xy[0] == KZero && xy[1] == KZero)
hgs
parents:
diff changeset
   183
                               {
hgs
parents:
diff changeset
   184
                               xy[0] = KMinVal;
hgs
parents:
diff changeset
   185
                               xy[1] = KMinVal;
hgs
parents:
diff changeset
   186
                               }
hgs
parents:
diff changeset
   187
                            if(rslt)
hgs
parents:
diff changeset
   188
                               {
hgs
parents:
diff changeset
   189
                               aPath->VertToL( xy[0], EFalse );
hgs
parents:
diff changeset
   190
                               }
hgs
parents:
diff changeset
   191
                            
hgs
parents:
diff changeset
   192
							break;
hgs
parents:
diff changeset
   193
					case 'C':
hgs
parents:
diff changeset
   194
							rslt = svgplex.GetNextWithNumOfPoints( xy ,TInt (6) );
hgs
parents:
diff changeset
   195
							if( rslt )
hgs
parents:
diff changeset
   196
								{
hgs
parents:
diff changeset
   197
								aPath->CubicToL( xy[0],
hgs
parents:
diff changeset
   198
										 xy[1],
hgs
parents:
diff changeset
   199
										 xy[2],
hgs
parents:
diff changeset
   200
										 xy[3],
hgs
parents:
diff changeset
   201
										 xy[4],
hgs
parents:
diff changeset
   202
										 xy[5],
hgs
parents:
diff changeset
   203
										 ETrue );
hgs
parents:
diff changeset
   204
								}
hgs
parents:
diff changeset
   205
							break;
hgs
parents:
diff changeset
   206
					case 'c':
hgs
parents:
diff changeset
   207
							rslt = svgplex.GetNextWithNumOfPoints( xy ,TInt (6) );
hgs
parents:
diff changeset
   208
							if(rslt)
hgs
parents:
diff changeset
   209
								{
hgs
parents:
diff changeset
   210
								aPath->CubicToL( xy[0],
hgs
parents:
diff changeset
   211
												 xy[1],
hgs
parents:
diff changeset
   212
												 xy[2],
hgs
parents:
diff changeset
   213
												 xy[3],
hgs
parents:
diff changeset
   214
												 xy[4],
hgs
parents:
diff changeset
   215
												 xy[5],
hgs
parents:
diff changeset
   216
												 EFalse );
hgs
parents:
diff changeset
   217
								}
hgs
parents:
diff changeset
   218
							break;
hgs
parents:
diff changeset
   219
					case 'S':
hgs
parents:
diff changeset
   220
							rslt = svgplex.GetNextWithNumOfPoints( xy ,TInt (4) );
hgs
parents:
diff changeset
   221
							if(rslt)
hgs
parents:
diff changeset
   222
								{
hgs
parents:
diff changeset
   223
								aPath->ShortCubicToL( xy[0],
hgs
parents:
diff changeset
   224
													  xy[1],
hgs
parents:
diff changeset
   225
													  xy[2],
hgs
parents:
diff changeset
   226
													  xy[3],
hgs
parents:
diff changeset
   227
													  ETrue );
hgs
parents:
diff changeset
   228
								}
hgs
parents:
diff changeset
   229
							break;
hgs
parents:
diff changeset
   230
					case 's':
hgs
parents:
diff changeset
   231
							rslt = svgplex.GetNextWithNumOfPoints( xy ,TInt (4) );
hgs
parents:
diff changeset
   232
							if(rslt)
hgs
parents:
diff changeset
   233
								{
hgs
parents:
diff changeset
   234
								aPath->ShortCubicToL( xy[0],
hgs
parents:
diff changeset
   235
													  xy[1],
hgs
parents:
diff changeset
   236
													  xy[2],
hgs
parents:
diff changeset
   237
													  xy[3],
hgs
parents:
diff changeset
   238
													  EFalse );
hgs
parents:
diff changeset
   239
								}
hgs
parents:
diff changeset
   240
							break;
hgs
parents:
diff changeset
   241
					case 'Q':
hgs
parents:
diff changeset
   242
							rslt = svgplex.GetNextWithNumOfPoints( xy ,TInt (4) );
hgs
parents:
diff changeset
   243
							if( rslt )
hgs
parents:
diff changeset
   244
								{
hgs
parents:
diff changeset
   245
								aPath->QuadToL( xy[0],
hgs
parents:
diff changeset
   246
												  xy[1],
hgs
parents:
diff changeset
   247
												  xy[2],
hgs
parents:
diff changeset
   248
												  xy[3],
hgs
parents:
diff changeset
   249
												ETrue );
hgs
parents:
diff changeset
   250
								}
hgs
parents:
diff changeset
   251
							break;
hgs
parents:
diff changeset
   252
					case 'T':
hgs
parents:
diff changeset
   253
							rslt = svgplex.GetNextWithNumOfPoints( xy ,TInt (2) );
hgs
parents:
diff changeset
   254
							if(rslt)
hgs
parents:
diff changeset
   255
								{
hgs
parents:
diff changeset
   256
								
hgs
parents:
diff changeset
   257
								// If there is no previous command or if
hgs
parents:
diff changeset
   258
								// the previous command was not a Q, q, T or t, the control point shall be current point.
hgs
parents:
diff changeset
   259
								if ( lPrevCom2 !='Q' && lPrevCom2 != 'q' && lPrevCom2 != 'T'
hgs
parents:
diff changeset
   260
								&& lPrevCom2 != 't' )
hgs
parents:
diff changeset
   261
								   {
hgs
parents:
diff changeset
   262
								   aPath->QuadToLWithNoControlPoint( xy[0], xy[1] );
hgs
parents:
diff changeset
   263
							   }
hgs
parents:
diff changeset
   264
								else
hgs
parents:
diff changeset
   265
								   {
hgs
parents:
diff changeset
   266
								   aPath->ShortQuadToL( xy[0], xy[1], ETrue );	
hgs
parents:
diff changeset
   267
								   }
hgs
parents:
diff changeset
   268
								}
hgs
parents:
diff changeset
   269
							break;
hgs
parents:
diff changeset
   270
					case 'q':
hgs
parents:
diff changeset
   271
							rslt = svgplex.GetNextWithNumOfPoints( xy ,TInt (4) );
hgs
parents:
diff changeset
   272
							if(rslt)
hgs
parents:
diff changeset
   273
								{
hgs
parents:
diff changeset
   274
								aPath->QuadToL( xy[0],
hgs
parents:
diff changeset
   275
										  xy[1],
hgs
parents:
diff changeset
   276
										  xy[2],
hgs
parents:
diff changeset
   277
                                          xy[3],
hgs
parents:
diff changeset
   278
                                        EFalse );
hgs
parents:
diff changeset
   279
                                }
hgs
parents:
diff changeset
   280
                            break;
hgs
parents:
diff changeset
   281
                    case 't':
hgs
parents:
diff changeset
   282
                            rslt = svgplex.GetNextWithNumOfPoints( xy ,TInt (2) );
hgs
parents:
diff changeset
   283
                            if(xy[0] != KZero || xy[1] != KZero)
hgs
parents:
diff changeset
   284
                                {
hgs
parents:
diff changeset
   285
								if(rslt)
hgs
parents:
diff changeset
   286
									{
hgs
parents:
diff changeset
   287
									aPath->ShortQuadToL( xy[0], xy[1], EFalse );
hgs
parents:
diff changeset
   288
									}
hgs
parents:
diff changeset
   289
								}
hgs
parents:
diff changeset
   290
							break;
hgs
parents:
diff changeset
   291
					case 'Z':
hgs
parents:
diff changeset
   292
					case 'z':
hgs
parents:
diff changeset
   293
							aPath->ClosePathL();
hgs
parents:
diff changeset
   294
							break;
hgs
parents:
diff changeset
   295
hgs
parents:
diff changeset
   296
					default:
hgs
parents:
diff changeset
   297
							rslt=0;
hgs
parents:
diff changeset
   298
							break;
hgs
parents:
diff changeset
   299
hgs
parents:
diff changeset
   300
					}// switch(lPrevCom)
hgs
parents:
diff changeset
   301
hgs
parents:
diff changeset
   302
				if( !rslt )
hgs
parents:
diff changeset
   303
					{
hgs
parents:
diff changeset
   304
					// This is a failing path case reset.
hgs
parents:
diff changeset
   305
					aPath->Reset();
hgs
parents:
diff changeset
   306
					break ;
hgs
parents:
diff changeset
   307
					}
hgs
parents:
diff changeset
   308
hgs
parents:
diff changeset
   309
				lPrevCom2 = com;
hgs
parents:
diff changeset
   310
        }
hgs
parents:
diff changeset
   311
    svgplex.Cleanup();
hgs
parents:
diff changeset
   312
    }
hgs
parents:
diff changeset
   313
hgs
parents:
diff changeset
   314
//
hgs
parents:
diff changeset
   315
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   316
//
hgs
parents:
diff changeset
   317
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   318
void TSvgPathDataParser::ParsePointDataL( const TDesC& aData,
hgs
parents:
diff changeset
   319
                                           CGfxGeneralPath* aPath )
hgs
parents:
diff changeset
   320
    {
hgs
parents:
diff changeset
   321
    TSvgPointLexer svgplex( aData );
hgs
parents:
diff changeset
   322
    TBool first = ETrue;
hgs
parents:
diff changeset
   323
    while ( !svgplex.IsDone() )
hgs
parents:
diff changeset
   324
        {
hgs
parents:
diff changeset
   325
        TChar com;
hgs
parents:
diff changeset
   326
        TFloatFixPt x, y;
hgs
parents:
diff changeset
   327
        TInt32 rslt = svgplex.GetNextPoint( com, x, y );
hgs
parents:
diff changeset
   328
hgs
parents:
diff changeset
   329
        if ( rslt != KErrNone )
hgs
parents:
diff changeset
   330
            {
hgs
parents:
diff changeset
   331
            aPath->Reset();
hgs
parents:
diff changeset
   332
            break;
hgs
parents:
diff changeset
   333
            }
hgs
parents:
diff changeset
   334
        if ( first )
hgs
parents:
diff changeset
   335
            {
hgs
parents:
diff changeset
   336
            aPath->MoveToL( x, y, ETrue );
hgs
parents:
diff changeset
   337
            first = EFalse;
hgs
parents:
diff changeset
   338
            }
hgs
parents:
diff changeset
   339
        else
hgs
parents:
diff changeset
   340
            {
hgs
parents:
diff changeset
   341
            aPath->LineToL( x, y, ETrue );
hgs
parents:
diff changeset
   342
            }
hgs
parents:
diff changeset
   343
        }
hgs
parents:
diff changeset
   344
    svgplex.Cleanup();
hgs
parents:
diff changeset
   345
    }
hgs
parents:
diff changeset
   346
hgs
parents:
diff changeset
   347
//
hgs
parents:
diff changeset
   348
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   349
//
hgs
parents:
diff changeset
   350
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   351
TFloatFixPt TSvgPathDataParser::PathLengthL( CGfxGeneralPath* aPath )
hgs
parents:
diff changeset
   352
    {
hgs
parents:
diff changeset
   353
    CGfxFlatteningPathIterator* pitr;
hgs
parents:
diff changeset
   354
    TGfxAffineTransform ident;
hgs
parents:
diff changeset
   355
    pitr = CGfxFlatteningPathIterator::NewL( aPath, & ident, 3 );
hgs
parents:
diff changeset
   356
hgs
parents:
diff changeset
   357
hgs
parents:
diff changeset
   358
    CleanupStack::PushL( pitr );
hgs
parents:
diff changeset
   359
hgs
parents:
diff changeset
   360
    TFloatFixPt len;
hgs
parents:
diff changeset
   361
    TFloatFixPt lx, ly;
hgs
parents:
diff changeset
   362
    TFloatFixPt dx, dy, int0x7f( KMAXFLOATFIX );
hgs
parents:
diff changeset
   363
    TFloatFixPt tmpcoords[6];
hgs
parents:
diff changeset
   364
    while ( !pitr->IsDone() )
hgs
parents:
diff changeset
   365
        {
hgs
parents:
diff changeset
   366
        switch ( pitr->CurrentSegment( tmpcoords ) )
hgs
parents:
diff changeset
   367
            {
hgs
parents:
diff changeset
   368
            case EGfxSegMoveTo:
hgs
parents:
diff changeset
   369
                lx = tmpcoords[0];
hgs
parents:
diff changeset
   370
                ly = tmpcoords[1];
hgs
parents:
diff changeset
   371
                break;
hgs
parents:
diff changeset
   372
            case EGfxSegLineTo:
hgs
parents:
diff changeset
   373
                dx = lx - tmpcoords[0];
hgs
parents:
diff changeset
   374
                dy = ly - tmpcoords[1];
hgs
parents:
diff changeset
   375
                if ( dx > int0x7f || dy > int0x7f )
hgs
parents:
diff changeset
   376
                    {
hgs
parents:
diff changeset
   377
                    // calculate as integer
hgs
parents:
diff changeset
   378
                    TInt32 tmplen, tx, ty;
hgs
parents:
diff changeset
   379
                    tx = ( TInt32 ) dx;
hgs
parents:
diff changeset
   380
                    ty = ( TInt32 ) dy;
hgs
parents:
diff changeset
   381
	#ifdef SVG_FLOAT_BUILD
hgs
parents:
diff changeset
   382
                    tmplen = TFloatFixPt::Sqrt(tx * tx + ty * ty);
hgs
parents:
diff changeset
   383
	#else
hgs
parents:
diff changeset
   384
                    tmplen = TFloatFixPt::FixedSqrtGeneral( tx * tx + ty * ty, 0 );
hgs
parents:
diff changeset
   385
	#endif
hgs
parents:
diff changeset
   386
                    len += TFloatFixPt( tmplen );
hgs
parents:
diff changeset
   387
                    }
hgs
parents:
diff changeset
   388
                else
hgs
parents:
diff changeset
   389
                    {
hgs
parents:
diff changeset
   390
                    // calculate as TFixPt
hgs
parents:
diff changeset
   391
	
hgs
parents:
diff changeset
   392
                    len += TFloatFixPt::Sqrt( dx * dx + dy * dy );
hgs
parents:
diff changeset
   393
                    }
hgs
parents:
diff changeset
   394
                lx = tmpcoords[0];
hgs
parents:
diff changeset
   395
                ly = tmpcoords[1];
hgs
parents:
diff changeset
   396
                break;
hgs
parents:
diff changeset
   397
            case EGfxSegClose:
hgs
parents:
diff changeset
   398
                ;// Not support multiple path length
hgs
parents:
diff changeset
   399
                break;
hgs
parents:
diff changeset
   400
            default:
hgs
parents:
diff changeset
   401
                break;
hgs
parents:
diff changeset
   402
            }
hgs
parents:
diff changeset
   403
        pitr->NextL();
hgs
parents:
diff changeset
   404
        }
hgs
parents:
diff changeset
   405
hgs
parents:
diff changeset
   406
    CleanupStack::PopAndDestroy( 1 );
hgs
parents:
diff changeset
   407
hgs
parents:
diff changeset
   408
    return len;
hgs
parents:
diff changeset
   409
    }