svgtopt/gfx2d/src/GfxRenderer/GfxPolygonRendererP.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 "GfxPolygonRendererP.h"
hgs
parents:
diff changeset
    20
#include "GfxPaint.h"
hgs
parents:
diff changeset
    21
#include "GfxColor.h"
hgs
parents:
diff changeset
    22
#include "GfxRendererInfoP.h"
hgs
parents:
diff changeset
    23
#include "GfxEdgeListP.h"
hgs
parents:
diff changeset
    24
hgs
parents:
diff changeset
    25
hgs
parents:
diff changeset
    26
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    27
// Constructor
hgs
parents:
diff changeset
    28
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    29
// --------------------------------------------------------------------------
hgs
parents:
diff changeset
    30
// TGfxPolygonRendererP::TGfxPolygonRendererP()
hgs
parents:
diff changeset
    31
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    32
TGfxPolygonRendererP::TGfxPolygonRendererP()
hgs
parents:
diff changeset
    33
    {
hgs
parents:
diff changeset
    34
    }
hgs
parents:
diff changeset
    35
hgs
parents:
diff changeset
    36
// --------------------------------------------------------------------------
hgs
parents:
diff changeset
    37
// void TGfxPolygonRendererP::InitializeP( CGfxEdgeListP* aEdgeList,
hgs
parents:
diff changeset
    38
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    39
void TGfxPolygonRendererP::InitializeP( CGfxEdgeListP* aEdgeList,
hgs
parents:
diff changeset
    40
                                        TGfxRendererInfoP* aRenderInfo,
hgs
parents:
diff changeset
    41
                                        MGfxPaint* aPaint,
hgs
parents:
diff changeset
    42
                                        TBool aWindingNoneZero )
hgs
parents:
diff changeset
    43
    {
hgs
parents:
diff changeset
    44
    iEdgeList = aEdgeList;
hgs
parents:
diff changeset
    45
    iRenderInfo = aRenderInfo;
hgs
parents:
diff changeset
    46
    iPaint = aPaint;
hgs
parents:
diff changeset
    47
    iWindingNoneZero = aWindingNoneZero;
hgs
parents:
diff changeset
    48
    }
hgs
parents:
diff changeset
    49
hgs
parents:
diff changeset
    50
// --------------------------------------------------------------------------
hgs
parents:
diff changeset
    51
// void TGfxPolygonRendererP::RenderScanlineL( TInt aY, TUint32 /* aAlpha */ )
hgs
parents:
diff changeset
    52
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    53
void TGfxPolygonRendererP::RenderScanlineL( TInt aY, TUint32 /* aAlpha */ )
hgs
parents:
diff changeset
    54
    {
hgs
parents:
diff changeset
    55
    if ( iRenderInfo->iClipMinY >= aY || aY > iRenderInfo->iClipMaxY )
hgs
parents:
diff changeset
    56
        return;
hgs
parents:
diff changeset
    57
hgs
parents:
diff changeset
    58
    TInt edgeCount = iEdgeList->iEdgesCount;
hgs
parents:
diff changeset
    59
    TGfxSegEdge dummyEdge;
hgs
parents:
diff changeset
    60
    dummyEdge.iEnd = -1;    // less than 0
hgs
parents:
diff changeset
    61
    dummyEdge.iSign = 100;  // neither -1, 0, or 1
hgs
parents:
diff changeset
    62
hgs
parents:
diff changeset
    63
    TUint16 flatColor;
hgs
parents:
diff changeset
    64
    flatColor = TGfxColor( iPaint->FlatColor() ).ColorRgb();
hgs
parents:
diff changeset
    65
hgs
parents:
diff changeset
    66
    // ************ Buffer is 2 bytes per pixel **********
hgs
parents:
diff changeset
    67
    TUint16* fb;
hgs
parents:
diff changeset
    68
hgs
parents:
diff changeset
    69
    fb = ( ( TUint16 * ) iRenderInfo->iDstBuf ) +
hgs
parents:
diff changeset
    70
           aY * iRenderInfo->iWidth;
hgs
parents:
diff changeset
    71
hgs
parents:
diff changeset
    72
hgs
parents:
diff changeset
    73
    TInt i, j;
hgs
parents:
diff changeset
    74
hgs
parents:
diff changeset
    75
    TInt edgeSignSum = 0;
hgs
parents:
diff changeset
    76
    TBool fill = EFalse;
hgs
parents:
diff changeset
    77
    TGfxSegEdge* lastEdge =& dummyEdge; // iEdgeList->EdgeList();
hgs
parents:
diff changeset
    78
    TGfxSegEdge* currentEdge = iEdgeList->EdgeList();
hgs
parents:
diff changeset
    79
    for ( i = 0; i < edgeCount; i++ )
hgs
parents:
diff changeset
    80
        {
hgs
parents:
diff changeset
    81
        // Fill between edges
hgs
parents:
diff changeset
    82
        TInt32 fbXmin, fbXmax;
hgs
parents:
diff changeset
    83
        if ( fill )
hgs
parents:
diff changeset
    84
            {
hgs
parents:
diff changeset
    85
            fbXmin = lastEdge->iStart + iEdgeList->iMinX;
hgs
parents:
diff changeset
    86
            fbXmax = currentEdge->iEnd + iEdgeList->iMinX;
hgs
parents:
diff changeset
    87
            if ( fbXmax >= iRenderInfo->iClipMinX &&
hgs
parents:
diff changeset
    88
                           fbXmin < iRenderInfo->iClipMaxX )  // inside clipping
hgs
parents:
diff changeset
    89
            {
hgs
parents:
diff changeset
    90
                if ( fbXmin < iRenderInfo->iClipMinX )
hgs
parents:
diff changeset
    91
                    {
hgs
parents:
diff changeset
    92
                    fbXmin = iRenderInfo->iClipMinX;
hgs
parents:
diff changeset
    93
                    }
hgs
parents:
diff changeset
    94
                if ( iRenderInfo->iClipMaxX <= fbXmax )
hgs
parents:
diff changeset
    95
                    {
hgs
parents:
diff changeset
    96
                    fbXmax = iRenderInfo->iClipMaxX - 1;
hgs
parents:
diff changeset
    97
                    }
hgs
parents:
diff changeset
    98
                TUint16* fbb =& fb[fbXmin];
hgs
parents:
diff changeset
    99
hgs
parents:
diff changeset
   100
                TInt fbw = fbXmax - fbXmin;
hgs
parents:
diff changeset
   101
                if ( fbw > 10 )
hgs
parents:
diff changeset
   102
                    {
hgs
parents:
diff changeset
   103
                    DrawHLine( fbb, flatColor, fbXmin, fbw );
hgs
parents:
diff changeset
   104
                    }
hgs
parents:
diff changeset
   105
                else
hgs
parents:
diff changeset
   106
                    {
hgs
parents:
diff changeset
   107
                    for ( j = fbXmin; j <= fbXmax ; j++ )
hgs
parents:
diff changeset
   108
                        *fbb++ = flatColor;
hgs
parents:
diff changeset
   109
                    }
hgs
parents:
diff changeset
   110
                }
hgs
parents:
diff changeset
   111
            }   // end if (fill)
hgs
parents:
diff changeset
   112
hgs
parents:
diff changeset
   113
        // update sum of sign and determine fill/non-fill
hgs
parents:
diff changeset
   114
hgs
parents:
diff changeset
   115
        if ( iWindingNoneZero )
hgs
parents:
diff changeset
   116
            {
hgs
parents:
diff changeset
   117
            fill = ( edgeSignSum += currentEdge->iSign );  // Non-zero rule.
hgs
parents:
diff changeset
   118
            }
hgs
parents:
diff changeset
   119
        else
hgs
parents:
diff changeset
   120
            {
hgs
parents:
diff changeset
   121
            fill = ( ++edgeSignSum & 1 );       // Even/odd rule.
hgs
parents:
diff changeset
   122
            }
hgs
parents:
diff changeset
   123
hgs
parents:
diff changeset
   124
        lastEdge = currentEdge;
hgs
parents:
diff changeset
   125
        currentEdge = currentEdge->iNext;
hgs
parents:
diff changeset
   126
        } // end for i (each edges)
hgs
parents:
diff changeset
   127
    }
hgs
parents:
diff changeset
   128
hgs
parents:
diff changeset
   129
hgs
parents:
diff changeset
   130