svgtopt/nvgdecoder/inc/nvgfittoviewbox.inl
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) 2009 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:
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
// Setter function for viewBox
hgs
parents:
diff changeset
    20
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    21
inline void CNvgFitToViewBoxImpl::SetViewBox(TReal avbX, TReal avbY, TReal avbW, TReal avbH)
hgs
parents:
diff changeset
    22
    {
hgs
parents:
diff changeset
    23
    ivbX = avbX;
hgs
parents:
diff changeset
    24
    ivbY = avbY;
hgs
parents:
diff changeset
    25
    ivbW = avbW;
hgs
parents:
diff changeset
    26
    ivbH = avbH;
hgs
parents:
diff changeset
    27
    iViewBoxDefined = ETrue;
hgs
parents:
diff changeset
    28
    }
hgs
parents:
diff changeset
    29
hgs
parents:
diff changeset
    30
hgs
parents:
diff changeset
    31
hgs
parents:
diff changeset
    32
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    33
// Setter function for Alignment
hgs
parents:
diff changeset
    34
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    35
inline void CNvgFitToViewBoxImpl::SetAlign(TNvgAlignStatusType aAlignStatus)    
hgs
parents:
diff changeset
    36
    {
hgs
parents:
diff changeset
    37
    iAlign = aAlignStatus;
hgs
parents:
diff changeset
    38
    }
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
// Setter function for Scaling of viewport to viewbox
hgs
parents:
diff changeset
    44
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    45
inline void CNvgFitToViewBoxImpl::SetScaling(TNvgMeetOrSliceType aMeetSlice)    
hgs
parents:
diff changeset
    46
    {
hgs
parents:
diff changeset
    47
    iMeetSlice = aMeetSlice;
hgs
parents:
diff changeset
    48
    }
hgs
parents:
diff changeset
    49
hgs
parents:
diff changeset
    50
hgs
parents:
diff changeset
    51
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    52
// Setter function for setting current transformation matrix
hgs
parents:
diff changeset
    53
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    54
inline void CNvgFitToViewBoxImpl::SetTransform(TReal aM00, TReal aM01, TReal aM02, TReal aM10, TReal aM11, TReal aM12)
hgs
parents:
diff changeset
    55
    {
hgs
parents:
diff changeset
    56
    iM00 = aM00;    
hgs
parents:
diff changeset
    57
    iM01 = aM01;
hgs
parents:
diff changeset
    58
    iM02 = aM02;
hgs
parents:
diff changeset
    59
    iM10 = aM10;
hgs
parents:
diff changeset
    60
    iM11 = aM11;
hgs
parents:
diff changeset
    61
    iM12 = aM12;
hgs
parents:
diff changeset
    62
    }
hgs
parents:
diff changeset
    63
hgs
parents:
diff changeset
    64
hgs
parents:
diff changeset
    65
hgs
parents:
diff changeset
    66
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    67
// Setter function for translation factors
hgs
parents:
diff changeset
    68
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    69
inline void CNvgFitToViewBoxImpl::Translate(TReal aTx, TReal aTy)
hgs
parents:
diff changeset
    70
    {
hgs
parents:
diff changeset
    71
    TReal lTranslateMatrix[6] =  { 1, 0, aTx, 0, 1, aTy};
hgs
parents:
diff changeset
    72
    Concatenate(lTranslateMatrix);
hgs
parents:
diff changeset
    73
    }
hgs
parents:
diff changeset
    74
hgs
parents:
diff changeset
    75
hgs
parents:
diff changeset
    76
hgs
parents:
diff changeset
    77
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    78
// Setter function for Scaling factors
hgs
parents:
diff changeset
    79
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    80
inline void CNvgFitToViewBoxImpl::Scale(TReal aSx, TReal aSy)
hgs
parents:
diff changeset
    81
    {
hgs
parents:
diff changeset
    82
    TReal lScaleMatrix[6] = { aSx, 0, 0, 0, aSy, 0};
hgs
parents:
diff changeset
    83
    Concatenate(lScaleMatrix);
hgs
parents:
diff changeset
    84
    }
hgs
parents:
diff changeset
    85
hgs
parents:
diff changeset
    86
hgs
parents:
diff changeset
    87
inline void CNvgFitToViewBoxImpl::Concatenate(TReal aMatrix[6])
hgs
parents:
diff changeset
    88
    {
hgs
parents:
diff changeset
    89
    Concatenate(aMatrix[0], aMatrix[1], aMatrix[2], aMatrix[3], aMatrix[4], aMatrix[5]);
hgs
parents:
diff changeset
    90
    }
hgs
parents:
diff changeset
    91
//===========================End Of File=================================================
hgs
parents:
diff changeset
    92