亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? c3dbase.cpp

?? 一個基于symbian s60 3rd 的3D汽車游戲演示程序,模擬器上編譯通過。
?? CPP
字號:
   /*
============================================================================
    * Name : C3DBase.cpp
    * Part of : Example3D
    * Description : Definition of C3DBase
    * Copyright (c) 2007 Nokia Corporation
============================================================================
    */

// INCLUDES
#include "C3DBase.h"
#include <e32math.h>
#include <f32file.h>

// MEMBER FUNCTIONS

C3DBase* C3DBase::NewL( const TSize& aScreenSize )
    {
    C3DBase* self = new( ELeave )C3DBase( aScreenSize );
    CleanupStack::PushL( self );
    self->ConstructL();
    CleanupStack::Pop( self );
    return self;
    }

C3DBase::~C3DBase()
    {
    delete[] iCos;
    delete[] iSin;
    }

C3DBase::C3DBase( const TSize& aScreenSize )
    : iScreenSize( aScreenSize )
    {
    }

void C3DBase::ConstructL()
    {
    //
    // generate sin & cos tables
    //
    iCos = new( ELeave )TInt16[ KSinTableSize ];
    iSin = new( ELeave )TInt16[ KSinTableSize ];

    TInt max = 1 << KShift;
    TInt i;
    for( i=0; i<KSinTableSize; i++ )
        {
        TReal r;
        Math::Cos( r, KPi * i / (KSinTableSize/2) );
        r *= max;
        Math::Int( iCos[ i ], r );
        Math::Sin( r, KPi * i / (KSinTableSize/2) );
        r *= max;
        Math::Int( iSin[ i ], r );
        }
    
    InitFrustum( iScreenSize );
    }

void C3DBase::InitFrustum( const TSize& aScreenSize )
    {
    iScreenSize = aScreenSize;
    TRect rect(aScreenSize);
    //
    // create view frustum
    //

    // calculate angles from screen size
    // -1 because of rounding errors
    // so we wouldn't draw outside visible screen

    TReal r;
    TInt lens = 512;
    TInt32 xangle;
    TInt32 yangle;

    Math::ATan( r, 0.5 * iScreenSize.iWidth / lens );
    r = r / KPi * KSinTableSize / 2 - 1;
    Math::Int( xangle, r );

    Math::ATan( r, 0.5 * iScreenSize.iHeight / lens );
    r = r / KPi * KSinTableSize / 2 - 1;
    Math::Int( yangle, r );

    iViewFrustum.iNumPlanes = 5;

    TInt a;
    // near clipping plane
    iViewFrustum.iPlane[ 0 ].iNormal = TVertex ( 0, 0, 1 << KShift );
    iViewFrustum.iPlane[ 0 ].iDistance = -500 << KShift;

    // left clipping plane
    a = (TInt)( xangle ) & ( KSinTableSize-1 );
    iViewFrustum.iPlane[ 1 ].iNormal = TVertex ( iCos[ a ], 0, iSin[ a ] );
    iViewFrustum.iPlane[ 1 ].iDistance = 0;

    // bottom clipping plane
    a = ( ( KSinTableSize/2 )-yangle ) & ( KSinTableSize-1 ); 
    iViewFrustum.iPlane[ 2 ].iNormal = TVertex ( 0, iCos[ a ], iSin[ a ] );
    iViewFrustum.iPlane[ 2 ].iDistance = 0;

    // right clipping plane
    a = (TInt)( ( KSinTableSize/2 )-xangle ) & ( KSinTableSize-1 ); 
    iViewFrustum.iPlane[ 3 ].iNormal = TVertex ( iCos[ a ], 0, iSin[ a ] );
    iViewFrustum.iPlane[ 3 ].iDistance = 0;

    // top clipping plane
    a = ( yangle ) & ( KSinTableSize-1 ); 
    iViewFrustum.iPlane[ 4 ].iNormal = TVertex ( 0, iCos[ a ], iSin[ a ] );
    iViewFrustum.iPlane[ 4 ].iDistance = 0;
    }

TInt16* C3DBase::CosTable()
    {
    return iCos;
    }

TInt16* C3DBase::SinTable()
    {
    return iSin;
    }

TFrustum& C3DBase::ViewFrustum()
    {
    return iViewFrustum;
    }

TVertex C3DBase::RotateX( const TVertex& aVertex, TInt aAngle )
    {
    TInt c = iCos[ aAngle & ( KSinTableSize-1 ) ];
    TInt s = iSin[ aAngle & ( KSinTableSize-1 ) ];
    
    TVertex v;

    v.iX = aVertex.iX;
    v.iY = ( aVertex.iY * c - aVertex.iZ * s ) >> KShift;
    v.iZ = ( aVertex.iY * s + aVertex.iZ * c ) >> KShift;

    return v;
    }

TVertex C3DBase::RotateY( const TVertex& aVertex, TInt aAngle )
    {
    TInt c = iCos[ aAngle & ( KSinTableSize-1 ) ];
    TInt s = iSin[ aAngle & ( KSinTableSize-1 ) ];
    
    TVertex v;

    v.iX = ( aVertex.iX * c - aVertex.iZ * s ) >> KShift;
    v.iY = aVertex.iY;
    v.iZ = ( aVertex.iX * s + aVertex.iZ * c ) >> KShift;

    return v;
    }

TVertex C3DBase::RotateZ( const TVertex& aVertex, TInt aAngle )
    {
    TInt c = iCos[ aAngle & ( KSinTableSize-1 ) ];
    TInt s = iSin[ aAngle & ( KSinTableSize-1 ) ];
    
    TVertex v;

    v.iX = ( aVertex.iX * c - aVertex.iY * s ) >> KShift;
    v.iY = ( aVertex.iX * s + aVertex.iY * c ) >> KShift;
    v.iZ = aVertex.iZ;

    return v;
    }

void C3DBase::QSort( TInt* aZ, TInt* aN, TInt aLow, TInt aHigh )
    {
    // the table aZ from range aLow..aHigh is sorted here
    // the table aN is an index table for aZ table entries
    
    // sorting method is a standard "quick sort"
    
    if( aHigh <= aLow ) return;

    TInt vz = aZ[ aLow ];
    TInt vn = aN[ aLow ];
    TInt lo = aLow;
    TInt hi = aHigh;
    
    TInt rPos = lo+1;
    TInt z = aZ[ rPos ];
    TInt n = aN[ rPos++ ];
    TInt t;
    
    for( TInt i=aLow+1; i<=aHigh; i++ )
        {
        if( z<vz )
            {
            aZ[ lo ] = z;
            z = aZ[ rPos ];

            aN[ lo++ ] = n;
            n = aN[ rPos++ ];
            }
        else
            {
            t = aZ[ hi ];
            aZ[ hi ] = z;
            z = t;

            t = aN[ hi ];
            aN[ hi-- ] = n;
            n = t;
            }
        }
    
    aZ[ lo ] = vz;
    aN[ lo ] = vn;

    // this function will recursively call itself to arrange
    // everything that wasn't arranged on this run.
    QSort( aZ, aN, aLow, lo-1 );
    QSort( aZ, aN, lo+1, aHigh );
    }

TInt C3DBase::PolygonCount()
    {
    return iPolygonCount;
    }

void C3DBase::ResetPolygonCount()
    {
    iPolygonCount = 0;
    }
    
void C3DBase::AddPolygonCount( TInt aCount )
    {
    iPolygonCount += aCount;
    }

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久精品夜夜夜夜久久| 国产在线精品一区在线观看麻豆| 亚洲成人在线免费| 国产成人免费视频 | 国产传媒一区在线| 欧美三日本三级三级在线播放| 精品美女在线观看| 亚洲成人免费视| www.色精品| 国产午夜亚洲精品理论片色戒| 亚洲国产精品一区二区久久| 成人黄色综合网站| 国产视频一区在线观看 | 亚洲一区二区三区自拍| 国产电影一区二区三区| 日韩欧美国产成人一区二区| 五月婷婷激情综合网| 色综合中文字幕| 中文字幕在线不卡一区| 国产成人啪免费观看软件| 日韩视频国产视频| 日本在线不卡一区| 欧美一区二区观看视频| 日韩精品亚洲专区| 欧美日韩1234| 丝袜国产日韩另类美女| 日韩欧美电影在线| 美女一区二区三区在线观看| 欧美日韩国产高清一区| 亚洲一区av在线| 欧美在线你懂得| 亚洲一区二区三区中文字幕在线| caoporen国产精品视频| 国产精品白丝在线| 97成人超碰视| 亚洲精品国产高清久久伦理二区| 色诱亚洲精品久久久久久| 国产精品传媒视频| 91国产精品成人| 亚洲大片在线观看| 日韩欧美久久久| 国产精品一区久久久久| 国产精品久久久久久久久图文区 | 亚洲黄色片在线观看| 91激情在线视频| 五月开心婷婷久久| 日韩欧美综合一区| 国产精品亚洲午夜一区二区三区| 国产欧美一区二区在线观看| 91麻豆精品国产91久久久使用方法| 五月综合激情婷婷六月色窝| 欧美大片日本大片免费观看| 国产一区免费电影| 国产精品久久久久久久久久免费看 | 国产美女av一区二区三区| 国产女人aaa级久久久级| 不卡一卡二卡三乱码免费网站| 亚洲日穴在线视频| 日韩一级完整毛片| 成人网男人的天堂| 五月天丁香久久| 欧美激情一区二区三区全黄 | 欧美一级日韩不卡播放免费| 黄一区二区三区| 亚洲免费看黄网站| 91精品国产综合久久国产大片| 国产精品中文字幕日韩精品| 亚洲免费观看高清| 精品国产一区二区三区四区四| av亚洲精华国产精华精| 视频一区欧美精品| 国产精品久久久一区麻豆最新章节| 色就色 综合激情| 国产一区视频导航| 亚洲成av人在线观看| 久久综合九色综合欧美就去吻| 91丨porny丨国产入口| 日本成人在线看| 一区二区三区四区在线免费观看| 日韩精品一区在线观看| 欧美在线观看视频一区二区| 国产精品一二三四五| 亚洲成av人片在线| 亚洲色图在线播放| 精品日韩一区二区三区免费视频| 色婷婷综合久久久中文一区二区| 国模冰冰炮一区二区| 亚洲成年人网站在线观看| 国产精品伦一区| 久久久五月婷婷| 欧美日韩另类一区| 91亚洲永久精品| 国产大片一区二区| 国产一区二区在线影院| 日本人妖一区二区| 五月婷婷色综合| 亚洲成人激情av| 亚洲综合免费观看高清完整版在线 | 欧美不卡一二三| 欧美日韩一区不卡| 在线观看国产日韩| 一本色道综合亚洲| 一道本成人在线| www.欧美色图| 成人动漫一区二区| 高清不卡在线观看av| 国产乱子伦一区二区三区国色天香| 日日摸夜夜添夜夜添精品视频| 亚洲午夜久久久久| 一区二区欧美在线观看| 一区二区三区 在线观看视频| 亚洲欧美一区二区久久 | 国产无一区二区| 国产亚洲综合在线| 国产欧美一区视频| 国产日产精品一区| 成人欧美一区二区三区视频网页| 国产欧美一区视频| 国产精品狼人久久影院观看方式| 中文字幕欧美激情一区| 国产精品免费观看视频| 亚洲手机成人高清视频| 一区二区三区视频在线看| 一区二区三区精品视频| 日韩国产欧美在线视频| 欧美aaaaaa午夜精品| 国产麻豆成人精品| 99久久精品国产麻豆演员表| 欧美午夜精品免费| 日韩亚洲电影在线| 久久久www免费人成精品| 亚洲国产成人一区二区三区| 亚洲人快播电影网| 日韩电影一区二区三区四区| 精品亚洲成a人在线观看 | 亚洲欧美一区二区视频| 亚洲一区二区三区在线看| 人妖欧美一区二区| 丁香婷婷深情五月亚洲| 日本精品裸体写真集在线观看| 91麻豆精品国产91久久久更新时间| 欧美mv日韩mv亚洲| 亚洲视频免费观看| 日本不卡视频在线观看| 粉嫩一区二区三区性色av| 欧美在线不卡视频| 精品国产1区二区| 亚洲女爱视频在线| 久久99国产精品免费网站| 粉嫩13p一区二区三区| 欧美日韩一卡二卡三卡| 国产视频一区二区三区在线观看| 亚洲免费观看高清| 国内精品视频666| 色国产综合视频| 久久久久久久久久久久电影| 一卡二卡三卡日韩欧美| 国产在线视频一区二区三区| 在线观看日韩国产| 国产午夜亚洲精品理论片色戒| 亚洲电影在线免费观看| 国产成人亚洲精品狼色在线 | 日韩vs国产vs欧美| 成人a免费在线看| 日韩亚洲电影在线| 亚洲欧美激情插 | 麻豆精品在线看| 日本韩国欧美在线| 中文文精品字幕一区二区| 日韩中文字幕1| 91成人看片片| 亚洲欧洲99久久| 国产大陆亚洲精品国产| 欧美一区二区三区啪啪| 亚洲电影第三页| 99久久免费视频.com| 国产喂奶挤奶一区二区三区| 日本欧美在线观看| 欧美日韩在线亚洲一区蜜芽| 亚洲色图制服丝袜| 成人免费看的视频| 精品人伦一区二区色婷婷| 日本大胆欧美人术艺术动态| 欧美性高清videossexo| 136国产福利精品导航| 国产成人免费视频一区| 久久精品一区蜜桃臀影院| 九九精品一区二区| 日韩色视频在线观看| 麻豆精品在线播放| 欧美一区二区在线观看| 青草av.久久免费一区| 欧美日韩情趣电影| 日日嗨av一区二区三区四区| 欧美精品一级二级| 亚洲chinese男男1069| 欧美三级午夜理伦三级中视频| 一区二区高清视频在线观看| 欧美在线啊v一区| 日韩在线观看一区二区|