1
0
forked from metin2/client
client/EterLib/GrpBase.cpp

513 lines
14 KiB
C++
Raw Blame History

#include "StdAfx.h"
#include "../eterBase/Utils.h"
#include "../eterBase/Timer.h"
#include "GrpBase.h"
#include "Camera.h"
#include "StateManager.h"
void PixelPositionToD3DXVECTOR3(const D3DXVECTOR3& c_rkPPosSrc, D3DXVECTOR3* pv3Dst)
{
pv3Dst->x=+c_rkPPosSrc.x;
pv3Dst->y=-c_rkPPosSrc.y;
pv3Dst->z=+c_rkPPosSrc.z;
}
void D3DXVECTOR3ToPixelPosition(const D3DXVECTOR3& c_rv3Src, D3DXVECTOR3* pv3Dst)
{
pv3Dst->x=+c_rv3Src.x;
pv3Dst->y=-c_rv3Src.y;
pv3Dst->z=+c_rv3Src.z;
}
UINT CGraphicBase::ms_iD3DAdapterInfo=0;
UINT CGraphicBase::ms_iD3DDevInfo=0;
UINT CGraphicBase::ms_iD3DModeInfo=0;
D3D_CDisplayModeAutoDetector CGraphicBase::ms_kD3DDetector;
HWND CGraphicBase::ms_hWnd;
HDC CGraphicBase::ms_hDC;
LPDIRECT3D8 CGraphicBase::ms_lpd3d = NULL;
LPDIRECT3DDEVICE8 CGraphicBase::ms_lpd3dDevice = NULL;
ID3DXMatrixStack * CGraphicBase::ms_lpd3dMatStack = NULL;
D3DPRESENT_PARAMETERS CGraphicBase::ms_d3dPresentParameter;
D3DVIEWPORT8 CGraphicBase::ms_Viewport;
HRESULT CGraphicBase::ms_hLastResult = NULL;
int CGraphicBase::ms_iWidth;
int CGraphicBase::ms_iHeight;
DWORD CGraphicBase::ms_faceCount = 0;
D3DCAPS8 CGraphicBase::ms_d3dCaps;
DWORD CGraphicBase::ms_dwD3DBehavior = 0;
DWORD CGraphicBase::ms_ptVS = 0;
DWORD CGraphicBase::ms_pntVS = 0;
DWORD CGraphicBase::ms_pnt2VS = 0;
D3DXMATRIX CGraphicBase::ms_matIdentity;
D3DXMATRIX CGraphicBase::ms_matView;
D3DXMATRIX CGraphicBase::ms_matProj;
D3DXMATRIX CGraphicBase::ms_matInverseView;
D3DXMATRIX CGraphicBase::ms_matInverseViewYAxis;
D3DXMATRIX CGraphicBase::ms_matWorld;
D3DXMATRIX CGraphicBase::ms_matWorldView;
D3DXMATRIX CGraphicBase::ms_matScreen0;
D3DXMATRIX CGraphicBase::ms_matScreen1;
D3DXMATRIX CGraphicBase::ms_matScreen2;
D3DXVECTOR3 CGraphicBase::ms_vtPickRayOrig;
D3DXVECTOR3 CGraphicBase::ms_vtPickRayDir;
float CGraphicBase::ms_fFieldOfView;
float CGraphicBase::ms_fNearY;
float CGraphicBase::ms_fFarY;
float CGraphicBase::ms_fAspect;
DWORD CGraphicBase::ms_dwWavingEndTime;
int CGraphicBase::ms_iWavingPower;
DWORD CGraphicBase::ms_dwFlashingEndTime;
D3DXCOLOR CGraphicBase::ms_FlashingColor;
// Terrain picking<6E><67> Ray... CCamera <20>̿<EFBFBD><CCBF>ϴ<EFBFBD> <20><><EFBFBD><EFBFBD>.. <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> Ray<61><79> <20><><EFBFBD><EFBFBD> <20>ʿ<EFBFBD>...
CRay CGraphicBase::ms_Ray;
bool CGraphicBase::ms_bSupportDXT = true;
bool CGraphicBase::ms_isLowTextureMemory = false;
bool CGraphicBase::ms_isHighTextureMemory = false;
// 2004.11.18.myevan.DynamicVertexBuffer<65><72> <20><>ü
/*
std::vector<TIndex> CGraphicBase::ms_lineIdxVector;
std::vector<TIndex> CGraphicBase::ms_lineTriIdxVector;
std::vector<TIndex> CGraphicBase::ms_lineRectIdxVector;
std::vector<TIndex> CGraphicBase::ms_lineCubeIdxVector;
std::vector<TIndex> CGraphicBase::ms_fillTriIdxVector;
std::vector<TIndex> CGraphicBase::ms_fillRectIdxVector;
std::vector<TIndex> CGraphicBase::ms_fillCubeIdxVector;
*/
LPD3DXMESH CGraphicBase::ms_lpSphereMesh = NULL;
LPD3DXMESH CGraphicBase::ms_lpCylinderMesh = NULL;
LPDIRECT3DVERTEXBUFFER8 CGraphicBase::ms_alpd3dPDTVB[PDT_VERTEXBUFFER_NUM];
LPDIRECT3DINDEXBUFFER8 CGraphicBase::ms_alpd3dDefIB[DEFAULT_IB_NUM];
bool CGraphicBase::IsLowTextureMemory()
{
return ms_isLowTextureMemory;
}
bool CGraphicBase::IsHighTextureMemory()
{
return ms_isHighTextureMemory;
}
bool CGraphicBase::IsFastTNL()
{
if (ms_dwD3DBehavior & D3DCREATE_HARDWARE_VERTEXPROCESSING ||
ms_dwD3DBehavior & D3DCREATE_MIXED_VERTEXPROCESSING)
{
if (ms_d3dCaps.VertexShaderVersion>D3DVS_VERSION(1,0))
return true;
}
return false;
}
bool CGraphicBase::IsTLVertexClipping()
{
if (ms_d3dCaps.PrimitiveMiscCaps & D3DPMISCCAPS_CLIPTLVERTS)
return true;
return false;
}
void CGraphicBase::GetBackBufferSize(UINT* puWidth, UINT* puHeight)
{
*puWidth=ms_d3dPresentParameter.BackBufferWidth;
*puHeight=ms_d3dPresentParameter.BackBufferHeight;
}
void CGraphicBase::SetDefaultIndexBuffer(UINT eDefIB)
{
if (eDefIB>=DEFAULT_IB_NUM)
return;
STATEMANAGER.SetIndices(ms_alpd3dDefIB[eDefIB], 0);
}
bool CGraphicBase::SetPDTStream(SPDTVertex* pVertices, UINT uVtxCount)
{
return SetPDTStream((SPDTVertexRaw*)pVertices, uVtxCount);
}
bool CGraphicBase::SetPDTStream(SPDTVertexRaw* pSrcVertices, UINT uVtxCount)
{
if (!uVtxCount)
return false;
static DWORD s_dwVBPos=0;
if (s_dwVBPos>=PDT_VERTEXBUFFER_NUM)
s_dwVBPos=0;
IDirect3DVertexBuffer8* plpd3dFillRectVB=ms_alpd3dPDTVB[s_dwVBPos];
++s_dwVBPos;
assert(PDT_VERTEX_NUM>=uVtxCount);
if (uVtxCount >= PDT_VERTEX_NUM)
return false;
TPDTVertex* pDstVertices;
if (FAILED(
plpd3dFillRectVB->Lock(0, sizeof(TPDTVertex)*uVtxCount, (BYTE**)&pDstVertices, D3DLOCK_DISCARD)
))
{
STATEMANAGER.SetStreamSource(0, NULL, 0);
return false;
}
memcpy(pDstVertices, pSrcVertices, sizeof(TPDTVertex)*uVtxCount);
plpd3dFillRectVB->Unlock();
STATEMANAGER.SetStreamSource(0, plpd3dFillRectVB, sizeof(TPDTVertex));
return true;
}
DWORD CGraphicBase::GetAvailableTextureMemory()
{
assert(ms_lpd3dDevice!=NULL && "CGraphicBase::GetAvailableTextureMemory - D3DDevice is EMPTY");
static DWORD s_dwNextUpdateTime=0;
static DWORD s_dwTexMemSize=0;//ms_lpd3dDevice->GetAvailableTextureMem();
DWORD dwCurTime=ELTimer_GetMSec();
if (s_dwNextUpdateTime<dwCurTime)
{
s_dwNextUpdateTime=dwCurTime+5000;
s_dwTexMemSize=ms_lpd3dDevice->GetAvailableTextureMem();
}
return s_dwTexMemSize;
}
const D3DXMATRIX& CGraphicBase::GetViewMatrix()
{
return ms_matView;
}
const D3DXMATRIX & CGraphicBase::GetIdentityMatrix()
{
return ms_matIdentity;
}
void CGraphicBase::SetEyeCamera(float xEye, float yEye, float zEye,
float xCenter, float yCenter, float zCenter,
float xUp, float yUp, float zUp)
{
D3DXVECTOR3 vectorEye(xEye, yEye, zEye);
D3DXVECTOR3 vectorCenter(xCenter, yCenter, zCenter);
D3DXVECTOR3 vectorUp(xUp, yUp, zUp);
// CCameraManager::Instance().SetCurrentCamera(CCameraManager::DEFAULT_PERSPECTIVE_CAMERA);
CCameraManager::Instance().GetCurrentCamera()->SetViewParams(vectorEye, vectorCenter, vectorUp);
UpdateViewMatrix();
}
void CGraphicBase::SetSimpleCamera(float x, float y, float z, float pitch, float roll)
{
CCamera * pCamera = CCameraManager::Instance().GetCurrentCamera();
D3DXVECTOR3 vectorEye(x, y, z);
pCamera->SetViewParams(D3DXVECTOR3(0.0f, y, 0.0f), D3DXVECTOR3(0.0f, 0.0f, 0.0f), D3DXVECTOR3(0.0f, 0.0f, 1.0f));
pCamera->RotateEyeAroundTarget(pitch, roll);
pCamera->Move(vectorEye);
UpdateViewMatrix();
// This is levites's virtual(?) code which you should not trust.
ms_lpd3dDevice->GetTransform(D3DTS_WORLD, &ms_matWorld);
D3DXMatrixMultiply(&ms_matWorldView, &ms_matWorld, &ms_matView);
}
void CGraphicBase::SetAroundCamera(float distance, float pitch, float roll, float lookAtZ)
{
CCamera * pCamera = CCameraManager::Instance().GetCurrentCamera();
pCamera->SetViewParams(D3DXVECTOR3(0.0f, -distance, 0.0f), D3DXVECTOR3(0.0f, 0.0f, 0.0f), D3DXVECTOR3(0.0f, 0.0f, 1.0f));
pCamera->RotateEyeAroundTarget(pitch, roll);
D3DXVECTOR3 v3Target = pCamera->GetTarget();
v3Target.z = lookAtZ;
pCamera->SetTarget(v3Target);
// pCamera->Move(v3Target);
UpdateViewMatrix();
// This is levites's virtual(?) code which you should not trust.
ms_lpd3dDevice->GetTransform(D3DTS_WORLD, &ms_matWorld);
D3DXMatrixMultiply(&ms_matWorldView, &ms_matWorld, &ms_matView);
}
void CGraphicBase::SetPositionCamera(float fx, float fy, float fz, float distance, float pitch, float roll)
{
// I wanna downward this code to the game control level. - [levites]
if (ms_dwWavingEndTime > CTimer::Instance().GetCurrentMillisecond())
{
if (ms_iWavingPower>0)
{
fx += float(rand() % ms_iWavingPower) / 10.0f;
fy += float(rand() % ms_iWavingPower) / 10.0f;
fz += float(rand() % ms_iWavingPower) / 10.0f;
}
}
CCamera * pCamera = CCameraManager::Instance().GetCurrentCamera();
if (!pCamera)
return;
pCamera->SetViewParams(D3DXVECTOR3(0.0f, -distance, 0.0f), D3DXVECTOR3(0.0f, 0.0f, 0.0f), D3DXVECTOR3(0.0f, 0.0f, 1.0f));
pitch = fMIN(80.0f, fMAX(-80.0f, pitch) );
// Tracef("SetPosition Camera : %f, %f\n", pitch, roll);
pCamera->RotateEyeAroundTarget(pitch, roll);
pCamera->Move(D3DXVECTOR3(fx, fy, fz));
UpdateViewMatrix();
// This is levites's virtual(?) code which you should not trust.
STATEMANAGER.GetTransform(D3DTS_WORLD, &ms_matWorld);
D3DXMatrixMultiply(&ms_matWorldView, &ms_matWorld, &ms_matView);
}
void CGraphicBase::SetOrtho2D(float hres, float vres, float zres)
{
//CCameraManager::Instance().SetCurrentCamera(CCameraManager::DEFAULT_ORTHO_CAMERA);
D3DXMatrixOrthoOffCenterRH(&ms_matProj, 0, hres, vres, 0, 0, zres);
//UpdatePipeLineMatrix();
UpdateProjMatrix();
}
void CGraphicBase::SetOrtho3D(float hres, float vres, float zmin, float zmax)
{
//CCameraManager::Instance().SetCurrentCamera(CCameraManager::DEFAULT_PERSPECTIVE_CAMERA);
D3DXMatrixOrthoRH(&ms_matProj, hres, vres, zmin, zmax);
//UpdatePipeLineMatrix();
UpdateProjMatrix();
}
void CGraphicBase::SetPerspective(float fov, float aspect, float nearz, float farz)
{
ms_fFieldOfView = fov;
//if (ms_d3dPresentParameter.BackBufferWidth>0 && ms_d3dPresentParameter.BackBufferHeight>0)
// ms_fAspect = float(ms_d3dPresentParameter.BackBufferWidth)/float(ms_d3dPresentParameter.BackBufferHeight);
//else
ms_fAspect = aspect;
ms_fNearY = nearz;
ms_fFarY = farz;
//CCameraManager::Instance().SetCurrentCamera(CCameraManager::DEFAULT_PERSPECTIVE_CAMERA);
D3DXMatrixPerspectiveFovRH(&ms_matProj, D3DXToRadian(fov), ms_fAspect, nearz, farz);
//UpdatePipeLineMatrix();
UpdateProjMatrix();
}
void CGraphicBase::UpdateProjMatrix()
{
STATEMANAGER.SetTransform(D3DTS_PROJECTION, &ms_matProj);
}
void CGraphicBase::UpdateViewMatrix()
{
CCamera* pkCamera=CCameraManager::Instance().GetCurrentCamera();
if (!pkCamera)
return;
ms_matView = pkCamera->GetViewMatrix();
STATEMANAGER.SetTransform(D3DTS_VIEW, &ms_matView);
D3DXMatrixInverse(&ms_matInverseView, NULL, &ms_matView);
ms_matInverseViewYAxis._11 = ms_matInverseView._11;
ms_matInverseViewYAxis._12 = ms_matInverseView._12;
ms_matInverseViewYAxis._21 = ms_matInverseView._21;
ms_matInverseViewYAxis._22 = ms_matInverseView._22;
}
void CGraphicBase::UpdatePipeLineMatrix()
{
UpdateProjMatrix();
UpdateViewMatrix();
}
void CGraphicBase::SetViewport(DWORD dwX, DWORD dwY, DWORD dwWidth, DWORD dwHeight, float fMinZ, float fMaxZ)
{
ms_Viewport.X = dwX;
ms_Viewport.Y = dwY;
ms_Viewport.Width = dwWidth;
ms_Viewport.Height = dwHeight;
ms_Viewport.MinZ = fMinZ;
ms_Viewport.MaxZ = fMaxZ;
}
void CGraphicBase::GetTargetPosition(float * px, float * py, float * pz)
{
*px = CCameraManager::Instance().GetCurrentCamera()->GetTarget().x;
*py = CCameraManager::Instance().GetCurrentCamera()->GetTarget().y;
*pz = CCameraManager::Instance().GetCurrentCamera()->GetTarget().z;
}
void CGraphicBase::GetCameraPosition(float * px, float * py, float * pz)
{
*px = CCameraManager::Instance().GetCurrentCamera()->GetEye().x;
*py = CCameraManager::Instance().GetCurrentCamera()->GetEye().y;
*pz = CCameraManager::Instance().GetCurrentCamera()->GetEye().z;
}
void CGraphicBase::GetMatrix(D3DXMATRIX* pRetMatrix) const
{
assert(ms_lpd3dMatStack != NULL);
*pRetMatrix = *ms_lpd3dMatStack->GetTop();
}
const D3DXMATRIX* CGraphicBase::GetMatrixPointer() const
{
assert(ms_lpd3dMatStack!=NULL);
return ms_lpd3dMatStack->GetTop();
}
void CGraphicBase::GetSphereMatrix(D3DXMATRIX * pMatrix, float fValue)
{
D3DXMatrixIdentity(pMatrix);
pMatrix->_11 = fValue * ms_matWorldView._11;
pMatrix->_21 = fValue * ms_matWorldView._21;
pMatrix->_31 = fValue * ms_matWorldView._31;
pMatrix->_41 = fValue;
pMatrix->_12 = -fValue * ms_matWorldView._12;
pMatrix->_22 = -fValue * ms_matWorldView._22;
pMatrix->_32 = -fValue * ms_matWorldView._32;
pMatrix->_42 = -fValue;
}
float CGraphicBase::GetFOV()
{
return ms_fFieldOfView;
}
void CGraphicBase::PushMatrix()
{
ms_lpd3dMatStack->Push();
}
void CGraphicBase::Scale(float x, float y, float z)
{
ms_lpd3dMatStack->Scale(x, y, z);
}
void CGraphicBase::Rotate(float degree, float x, float y, float z)
{
D3DXVECTOR3 vec(x, y, z);
ms_lpd3dMatStack->RotateAxis(&vec, D3DXToRadian(degree));
}
void CGraphicBase::RotateLocal(float degree, float x, float y, float z)
{
D3DXVECTOR3 vec(x, y, z);
ms_lpd3dMatStack->RotateAxisLocal(&vec, D3DXToRadian(degree));
}
void CGraphicBase::MultMatrix( const D3DXMATRIX* pMat)
{
ms_lpd3dMatStack->MultMatrix(pMat);
}
void CGraphicBase::MultMatrixLocal( const D3DXMATRIX* pMat)
{
ms_lpd3dMatStack->MultMatrixLocal(pMat);
}
void CGraphicBase::RotateYawPitchRollLocal(float fYaw, float fPitch, float fRoll)
{
ms_lpd3dMatStack->RotateYawPitchRollLocal(D3DXToRadian(fYaw), D3DXToRadian(fPitch), D3DXToRadian(fRoll));
}
void CGraphicBase::Translate(float x, float y, float z)
{
ms_lpd3dMatStack->Translate(x, y, z);
}
void CGraphicBase::LoadMatrix(const D3DXMATRIX& c_rSrcMatrix)
{
ms_lpd3dMatStack->LoadMatrix(&c_rSrcMatrix);
}
void CGraphicBase::PopMatrix()
{
ms_lpd3dMatStack->Pop();
}
DWORD CGraphicBase::GetColor(float r, float g, float b, float a)
{
BYTE argb[4] =
{
(BYTE) (255.0f * b),
(BYTE) (255.0f * g),
(BYTE) (255.0f * r),
(BYTE) (255.0f * a)
};
return *((DWORD *) argb);
}
void CGraphicBase::InitScreenEffect()
{
ms_dwWavingEndTime = 0;
ms_dwFlashingEndTime = 0;
ms_iWavingPower = 0;
ms_FlashingColor = D3DXCOLOR(0.0f, 0.0f, 0.0f, 0.0f);
}
void CGraphicBase::SetScreenEffectWaving(float fDuringTime, int iPower)
{
ms_dwWavingEndTime = CTimer::Instance().GetCurrentMillisecond() + long(fDuringTime * 1000.0f);
ms_iWavingPower = iPower;
}
void CGraphicBase::SetScreenEffectFlashing(float fDuringTime, const D3DXCOLOR & c_rColor)
{
ms_dwFlashingEndTime = CTimer::Instance().GetCurrentMillisecond() + long(fDuringTime * 1000.0f);
ms_FlashingColor = c_rColor;
}
DWORD CGraphicBase::GetFaceCount()
{
return ms_faceCount;
}
void CGraphicBase::ResetFaceCount()
{
ms_faceCount = 0;
}
HRESULT CGraphicBase::GetLastResult()
{
return ms_hLastResult;
}
CGraphicBase::CGraphicBase()
{
}
CGraphicBase::~CGraphicBase()
{
}