svgtopt/nvgdecoder/inc/FloatFixPt.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) 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:  NVG Decoder header file
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
#ifndef NVGFLOATFIX_H_
hgs
parents:
diff changeset
    19
#define NVGFLOATFIX_H_
hgs
parents:
diff changeset
    20
hgs
parents:
diff changeset
    21
#include <e32def.h>
hgs
parents:
diff changeset
    22
#include <s32mem.h>
hgs
parents:
diff changeset
    23
hgs
parents:
diff changeset
    24
const TInt32 KFixPtFrac = 16;
hgs
parents:
diff changeset
    25
const TInt32 KFixPtFracVal = (1 << KFixPtFrac);
hgs
parents:
diff changeset
    26
#   define svgFloatBits(f) (*(int*)&f)
hgs
parents:
diff changeset
    27
hgs
parents:
diff changeset
    28
inline int svgScalarFromFloat(float f)
hgs
parents:
diff changeset
    29
    {
hgs
parents:
diff changeset
    30
    int a;
hgs
parents:
diff changeset
    31
    int sign;
hgs
parents:
diff changeset
    32
    int exponent;
hgs
parents:
diff changeset
    33
    
hgs
parents:
diff changeset
    34
    int r;
hgs
parents:
diff changeset
    35
    
hgs
parents:
diff changeset
    36
    
hgs
parents:
diff changeset
    37
    a           = svgFloatBits(f);
hgs
parents:
diff changeset
    38
    sign        = a >> 31;
hgs
parents:
diff changeset
    39
    exponent    = (127 + 15) - ((a >> 23) & 0xff);
hgs
parents:
diff changeset
    40
    
hgs
parents:
diff changeset
    41
    r = (int)((((int)(a) << 8) | (1U << 31)) >> exponent);
hgs
parents:
diff changeset
    42
    r &= ((exponent - 32) >> 31);
hgs
parents:
diff changeset
    43
    
hgs
parents:
diff changeset
    44
    r = (r ^ sign) - sign;
hgs
parents:
diff changeset
    45
    
hgs
parents:
diff changeset
    46
    return r;
hgs
parents:
diff changeset
    47
    
hgs
parents:
diff changeset
    48
    }
hgs
parents:
diff changeset
    49
class TFloatFixPt
hgs
parents:
diff changeset
    50
    {
hgs
parents:
diff changeset
    51
    public:
hgs
parents:
diff changeset
    52
        
hgs
parents:
diff changeset
    53
        /**
hgs
parents:
diff changeset
    54
         * Construct a TFixPt.  The default value is 0.0.
hgs
parents:
diff changeset
    55
         *
hgs
parents:
diff changeset
    56
         * @since 1.0
hgs
parents:
diff changeset
    57
         * @return
hgs
parents:
diff changeset
    58
         */
hgs
parents:
diff changeset
    59
        TFloatFixPt();
hgs
parents:
diff changeset
    60
hgs
parents:
diff changeset
    61
        /**
hgs
parents:
diff changeset
    62
         * Construct a TFixPt from the given integer value.
hgs
parents:
diff changeset
    63
         *
hgs
parents:
diff changeset
    64
         * @since 1.0
hgs
parents:
diff changeset
    65
         * @param aVal : integer value
hgs
parents:
diff changeset
    66
         * @return
hgs
parents:
diff changeset
    67
         */
hgs
parents:
diff changeset
    68
        TFloatFixPt(TInt aVal);
hgs
parents:
diff changeset
    69
        TFloatFixPt(TInt32 aVal);
hgs
parents:
diff changeset
    70
        TFloatFixPt(TReal32 aVal);
hgs
parents:
diff changeset
    71
        TFloatFixPt(TInt aVal, TBool aBool);
hgs
parents:
diff changeset
    72
        TFloatFixPt&   operator=(TReal32 aVal);
hgs
parents:
diff changeset
    73
        TFloatFixPt           operator+(const TFloatFixPt& aVal) const;
hgs
parents:
diff changeset
    74
        operator TReal32() const;
hgs
parents:
diff changeset
    75
        TInt32           Round();
hgs
parents:
diff changeset
    76
        TInt32           RawData();
hgs
parents:
diff changeset
    77
        void copyfloatfix(TInt aVal);
hgs
parents:
diff changeset
    78
    public:
hgs
parents:
diff changeset
    79
        TInt                    iValue;    // Must be the first data member of this class!
hgs
parents:
diff changeset
    80
        
hgs
parents:
diff changeset
    81
    };
hgs
parents:
diff changeset
    82
hgs
parents:
diff changeset
    83
#endif
hgs
parents:
diff changeset
    84