svgtopt/gfx2d/src/GfxGeom/GfxRectangularShape.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) 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 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 "GfxRectangularShape.h"
hgs
parents:
diff changeset
    20
#include "GfxRectangle2D.h"
hgs
parents:
diff changeset
    21
hgs
parents:
diff changeset
    22
hgs
parents:
diff changeset
    23
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    24
// Constructor
hgs
parents:
diff changeset
    25
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    26
// --------------------------------------------------------------------------
hgs
parents:
diff changeset
    27
//  TGfxRectangularShape::TGfxRectangularShape()
hgs
parents:
diff changeset
    28
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    29
 TGfxRectangularShape::TGfxRectangularShape()
hgs
parents:
diff changeset
    30
    {
hgs
parents:
diff changeset
    31
    }
hgs
parents:
diff changeset
    32
hgs
parents:
diff changeset
    33
// --------------------------------------------------------------------------
hgs
parents:
diff changeset
    34
//  TGfxRectangularShape::TGfxRectangularShape( const TFloatFixPt& aX,
hgs
parents:
diff changeset
    35
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    36
 TGfxRectangularShape::TGfxRectangularShape( const TFloatFixPt& aX,
hgs
parents:
diff changeset
    37
                                                     const TFloatFixPt& aY,
hgs
parents:
diff changeset
    38
                                                     const TFloatFixPt& aWidth,
hgs
parents:
diff changeset
    39
                                                     const TFloatFixPt& aHeight )
hgs
parents:
diff changeset
    40
													 :iWidth(aWidth),
hgs
parents:
diff changeset
    41
													 iHeight(aHeight),
hgs
parents:
diff changeset
    42
													 iX(aX),
hgs
parents:
diff changeset
    43
													 iY(aY)
hgs
parents:
diff changeset
    44
	{
hgs
parents:
diff changeset
    45
	}
hgs
parents:
diff changeset
    46
hgs
parents:
diff changeset
    47
hgs
parents:
diff changeset
    48
// --------------------------------------------------------------------------
hgs
parents:
diff changeset
    49
//  void TGfxRectangularShape::GetBounds( const TGfxAffineTransform& aAt,
hgs
parents:
diff changeset
    50
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    51
 void TGfxRectangularShape::GetBounds( const TGfxAffineTransform& aAt,
hgs
parents:
diff changeset
    52
                                               TGfxRectangle2D& aRect )
hgs
parents:
diff changeset
    53
    {
hgs
parents:
diff changeset
    54
    TGfxPoint2D p[4];
hgs
parents:
diff changeset
    55
    p[0].iX = iX;
hgs
parents:
diff changeset
    56
    p[0].iY = iY;
hgs
parents:
diff changeset
    57
    p[1].iX = iX + iWidth;
hgs
parents:
diff changeset
    58
    p[1].iY = iY;
hgs
parents:
diff changeset
    59
    p[2].iX = iX + iWidth;
hgs
parents:
diff changeset
    60
    p[2].iY = iY + iHeight;
hgs
parents:
diff changeset
    61
    p[3].iX = iX;
hgs
parents:
diff changeset
    62
    p[3].iY = iY + iHeight;
hgs
parents:
diff changeset
    63
    aAt.Transform( p, p, 4 );
hgs
parents:
diff changeset
    64
hgs
parents:
diff changeset
    65
    TFloatFixPt xMin( KMAXFLOATFIX ), yMin( KMAXFLOATFIX ), xMax( KMINFLOATFIX ), yMax( KMINFLOATFIX );
hgs
parents:
diff changeset
    66
    for ( TInt32 i = 0; i < 4; i++ )
hgs
parents:
diff changeset
    67
        {
hgs
parents:
diff changeset
    68
        if ( p[i].iX < xMin )
hgs
parents:
diff changeset
    69
            xMin = p[i].iX;
hgs
parents:
diff changeset
    70
        if ( p[i].iX > xMax )
hgs
parents:
diff changeset
    71
            xMax = p[i].iX;
hgs
parents:
diff changeset
    72
        if ( p[i].iY < yMin )
hgs
parents:
diff changeset
    73
            yMin = p[i].iY;
hgs
parents:
diff changeset
    74
        if ( p[i].iY > yMax )
hgs
parents:
diff changeset
    75
            yMax = p[i].iY;
hgs
parents:
diff changeset
    76
        }
hgs
parents:
diff changeset
    77
hgs
parents:
diff changeset
    78
    aRect.iX = xMin;
hgs
parents:
diff changeset
    79
    aRect.iY = yMin;
hgs
parents:
diff changeset
    80
    aRect.iWidth = xMax - xMin;
hgs
parents:
diff changeset
    81
    aRect.iHeight = yMax - yMin;
hgs
parents:
diff changeset
    82
    }
hgs
parents:
diff changeset
    83
hgs
parents:
diff changeset
    84
// --------------------------------------------------------------------------
hgs
parents:
diff changeset
    85
//  TFloatFixPt TGfxRectangularShape::AreaSize()
hgs
parents:
diff changeset
    86
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    87
 TFloatFixPt TGfxRectangularShape::AreaSize()
hgs
parents:
diff changeset
    88
    {
hgs
parents:
diff changeset
    89
    if ( iWidth > KMAXFLOATFIX || iHeight > KMAXFLOATFIX )
hgs
parents:
diff changeset
    90
        {
hgs
parents:
diff changeset
    91
        TInt area = ( ( TInt ) iWidth ) * ( ( TInt ) iHeight );
hgs
parents:
diff changeset
    92
        if ( area < KMAXFLOATFIXVALUE )
hgs
parents:
diff changeset
    93
            return TFloatFixPt( area );
hgs
parents:
diff changeset
    94
        else
hgs
parents:
diff changeset
    95
            return KMAXFLOATFIX;
hgs
parents:
diff changeset
    96
        }
hgs
parents:
diff changeset
    97
    else
hgs
parents:
diff changeset
    98
        {
hgs
parents:
diff changeset
    99
        return iWidth * iHeight;
hgs
parents:
diff changeset
   100
        }
hgs
parents:
diff changeset
   101
    }
hgs
parents:
diff changeset
   102
hgs
parents:
diff changeset
   103
// --------------------------------------------------------------------------
hgs
parents:
diff changeset
   104
//  TFloatFixPt TGfxRectangularShape::CenterX()
hgs
parents:
diff changeset
   105
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   106
 TFloatFixPt TGfxRectangularShape::CenterX()
hgs
parents:
diff changeset
   107
  {
hgs
parents:
diff changeset
   108
	#ifdef SVG_FLOAT_BUILD
hgs
parents:
diff changeset
   109
    return ( iX + (iWidth * TFloatFixPt(.5f)));
hgs
parents:
diff changeset
   110
	#else
hgs
parents:
diff changeset
   111
    return ( iX + (iWidth >> 1));
hgs
parents:
diff changeset
   112
	#endif
hgs
parents:
diff changeset
   113
	}
hgs
parents:
diff changeset
   114
hgs
parents:
diff changeset
   115
hgs
parents:
diff changeset
   116
// --------------------------------------------------------------------------
hgs
parents:
diff changeset
   117
//  TFloatFixPt TGfxRectangularShape::CenterY()
hgs
parents:
diff changeset
   118
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   119
 TFloatFixPt TGfxRectangularShape::CenterY()
hgs
parents:
diff changeset
   120
    {
hgs
parents:
diff changeset
   121
	#ifdef SVG_FLOAT_BUILD
hgs
parents:
diff changeset
   122
    return ( iY + (iHeight * TFloatFixPt(.5f))) ;
hgs
parents:
diff changeset
   123
	#else
hgs
parents:
diff changeset
   124
    return ( iY + (iHeight >> 1)) ;
hgs
parents:
diff changeset
   125
	#endif
hgs
parents:
diff changeset
   126
    }
hgs
parents:
diff changeset
   127
hgs
parents:
diff changeset
   128
hgs
parents:
diff changeset
   129
// --------------------------------------------------------------------------
hgs
parents:
diff changeset
   130
//  TFloatFixPt TGfxRectangularShape::MinX()
hgs
parents:
diff changeset
   131
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   132
 TFloatFixPt TGfxRectangularShape::MinX()
hgs
parents:
diff changeset
   133
    {
hgs
parents:
diff changeset
   134
    return TFloatFixPt( iX );
hgs
parents:
diff changeset
   135
    }
hgs
parents:
diff changeset
   136
hgs
parents:
diff changeset
   137
// --------------------------------------------------------------------------
hgs
parents:
diff changeset
   138
//  TFloatFixPt TGfxRectangularShape::MinY()
hgs
parents:
diff changeset
   139
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   140
 TFloatFixPt TGfxRectangularShape::MinY()
hgs
parents:
diff changeset
   141
    {
hgs
parents:
diff changeset
   142
    return TFloatFixPt( iY );
hgs
parents:
diff changeset
   143
    }
hgs
parents:
diff changeset
   144
hgs
parents:
diff changeset
   145
// --------------------------------------------------------------------------
hgs
parents:
diff changeset
   146
//  TFloatFixPt TGfxRectangularShape::MaxX()
hgs
parents:
diff changeset
   147
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   148
 TFloatFixPt TGfxRectangularShape::MaxX()
hgs
parents:
diff changeset
   149
    {
hgs
parents:
diff changeset
   150
    return TFloatFixPt( iX + iWidth );
hgs
parents:
diff changeset
   151
    }
hgs
parents:
diff changeset
   152
hgs
parents:
diff changeset
   153
// --------------------------------------------------------------------------
hgs
parents:
diff changeset
   154
//  TFloatFixPt TGfxRectangularShape::MaxY()
hgs
parents:
diff changeset
   155
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   156
 TFloatFixPt TGfxRectangularShape::MaxY()
hgs
parents:
diff changeset
   157
    {
hgs
parents:
diff changeset
   158
    return TFloatFixPt( iY + iHeight );
hgs
parents:
diff changeset
   159
    }
hgs
parents:
diff changeset
   160