forked from metin2/client
291 lines
9.0 KiB
C++
291 lines
9.0 KiB
C++
#include "stdafx.h"
|
|
#include "../eterLib/StateManager.h"
|
|
#include "../eterLib/Camera.h"
|
|
|
|
#include "FlyingData.h"
|
|
#include "FlyTrace.h"
|
|
|
|
CDynamicPool<CFlyTrace> CFlyTrace::ms_kPool;
|
|
|
|
void CFlyTrace::DestroySystem()
|
|
{
|
|
ms_kPool.Destroy();
|
|
}
|
|
|
|
CFlyTrace* CFlyTrace::New()
|
|
{
|
|
return ms_kPool.Alloc();
|
|
}
|
|
|
|
void CFlyTrace::Delete(CFlyTrace* pkInst)
|
|
{
|
|
pkInst->Destroy();
|
|
ms_kPool.Free(pkInst);
|
|
}
|
|
|
|
CFlyTrace::CFlyTrace()
|
|
{
|
|
__Initialize();
|
|
|
|
/*
|
|
// Code for texture
|
|
CGraphicImage * pImage = (CGraphicImage *)CResourceManager::Instance().GetResourcePointer("d:/ray.jpg");
|
|
m_ImageInstance.SetImagePointer(pImage);
|
|
|
|
CGraphicTexture * pTexture = m_ImageInstance.GetTexturePointer();
|
|
m_lpTexture = pTexture->GetD3DTexture();
|
|
*/
|
|
}
|
|
|
|
CFlyTrace::~CFlyTrace()
|
|
{
|
|
Destroy();
|
|
}
|
|
|
|
|
|
void CFlyTrace::__Initialize()
|
|
{
|
|
m_bRectShape=false;
|
|
m_dwColor=0;
|
|
m_fSize=0.0f;
|
|
m_fTailLength=0.0f;
|
|
}
|
|
|
|
void CFlyTrace::Destroy()
|
|
{
|
|
m_TimePositionDeque.clear();
|
|
|
|
__Initialize();
|
|
}
|
|
|
|
void CFlyTrace::UpdateNewPosition(const D3DXVECTOR3 & v3Position)
|
|
{
|
|
m_TimePositionDeque.push_front(TTimePosition(CTimer::Instance().GetCurrentSecond(),v3Position));
|
|
//Tracenf("%f %f",m_TimePositionDeque.back().first, CTimer::Instance().GetCurrentSecond());
|
|
while(!m_TimePositionDeque.empty() && m_TimePositionDeque.back().first+m_fTailLength<CTimer::Instance().GetCurrentSecond())
|
|
{
|
|
m_TimePositionDeque.pop_back();
|
|
}
|
|
}
|
|
|
|
void CFlyTrace::Create(const CFlyingData::TFlyingAttachData & rFlyingAttachData)
|
|
{
|
|
//assert(rFlyingAttachData.bHasTail);
|
|
m_dwColor = rFlyingAttachData.dwTailColor;
|
|
m_fTailLength = rFlyingAttachData.fTailLength;
|
|
m_fSize = rFlyingAttachData.fTailSize;
|
|
m_bRectShape = rFlyingAttachData.bRectShape;
|
|
}
|
|
|
|
|
|
void CFlyTrace::Update()
|
|
{
|
|
|
|
}
|
|
|
|
//1. 알파를 쓰려면 색깔만 줄수있다.
|
|
//2. 텍스쳐를 쓰려면 알파 없다-_-
|
|
|
|
|
|
struct TFlyVertex
|
|
{
|
|
D3DXVECTOR3 p;
|
|
DWORD c;
|
|
D3DXVECTOR2 t;
|
|
TFlyVertex(){};
|
|
TFlyVertex(const D3DXVECTOR3& p, DWORD c, const D3DXVECTOR2 & t):p(p),c(c),t(t){}
|
|
};
|
|
|
|
struct TFlyVertexSet
|
|
{
|
|
TFlyVertex v[6];
|
|
TFlyVertexSet(TFlyVertex * pv)
|
|
{
|
|
memcpy(v,pv,sizeof(v));
|
|
}
|
|
bool operator < (const TFlyVertexSet& ) const
|
|
{
|
|
return false;
|
|
}
|
|
TFlyVertexSet & operator = ( const TFlyVertexSet& rhs )
|
|
{
|
|
memcpy(v,rhs.v,sizeof(v));
|
|
return *this;
|
|
}
|
|
};
|
|
|
|
typedef std::vector<std::pair<float, TFlyVertexSet> > TFlyVertexSetVector;
|
|
|
|
void CFlyTrace::Render()
|
|
{
|
|
if (m_TimePositionDeque.size()<=1)
|
|
return;
|
|
TFlyVertexSetVector VSVector;
|
|
|
|
//STATEMANAGER.SaveRenderState(D3DRS_ZFUNC,D3DCMP_LESS);
|
|
STATEMANAGER.SaveRenderState(D3DRS_ZFUNC,D3DCMP_LESS);
|
|
//STATEMANAGER.SaveRenderState(D3DRS_ZWRITEENABLE,FALSE);
|
|
|
|
D3DXMATRIX matWorld;
|
|
D3DXMatrixIdentity(&matWorld);
|
|
|
|
STATEMANAGER.SaveTransform(D3DTS_WORLD, &matWorld);
|
|
STATEMANAGER.SaveVertexShader(D3DFVF_XYZ | D3DFVF_DIFFUSE | D3DFVF_TEX1);
|
|
STATEMANAGER.SaveRenderState(D3DRS_CULLMODE, D3DCULL_NONE);
|
|
|
|
STATEMANAGER.SaveRenderState(D3DRS_ALPHABLENDENABLE, TRUE);
|
|
STATEMANAGER.SaveRenderState(D3DRS_SRCBLEND, D3DBLEND_SRCALPHA);
|
|
STATEMANAGER.SaveRenderState(D3DRS_DESTBLEND, D3DBLEND_ONE);
|
|
|
|
STATEMANAGER.SaveRenderState(D3DRS_ALPHATESTENABLE, TRUE);
|
|
STATEMANAGER.SaveRenderState(D3DRS_ALPHAFUNC, D3DCMP_GREATER);
|
|
STATEMANAGER.SaveRenderState(D3DRS_ALPHAREF, 0x00000000);
|
|
|
|
STATEMANAGER.SaveRenderState(D3DRS_BLENDOP, D3DBLENDOP_ADD );
|
|
//STATEMANAGER.SaveRenderState(D3DRS_BLENDOP, D3DBLENDOP_ADD );
|
|
|
|
STATEMANAGER.SetTextureStageState(0, D3DTSS_COLORARG1, D3DTA_DIFFUSE);
|
|
STATEMANAGER.SetTextureStageState(0, D3DTSS_COLORARG2, D3DTA_TEXTURE);
|
|
//STATEMANAGER.SetTextureStageState(0, D3DTSS_COLOROP, /*(m_bUseTexture)?D3DTOP_SELECTARG2:*/D3DTOP_SELECTARG2);
|
|
STATEMANAGER.SetTextureStageState(0, D3DTSS_COLOROP, D3DTOP_SELECTARG1);
|
|
|
|
STATEMANAGER.SetTextureStageState(0, D3DTSS_ALPHAARG1, D3DTA_DIFFUSE);
|
|
STATEMANAGER.SetTextureStageState(0, D3DTSS_ALPHAARG2, D3DTA_TEXTURE);
|
|
//STATEMANAGER.SetTextureStageState(0, D3DTSS_ALPHAOP, D3DTOP_MODULATE);
|
|
STATEMANAGER.SetTextureStageState(0, D3DTSS_ALPHAOP, /*(m_bUseTexture)?D3DTOP_SELECTARG2:*/D3DTOP_SELECTARG1);
|
|
STATEMANAGER.SetTextureStageState(1, D3DTSS_COLOROP, D3DTOP_DISABLE);
|
|
STATEMANAGER.SetTextureStageState(1, D3DTSS_ALPHAOP, D3DTOP_DISABLE);
|
|
STATEMANAGER.SetRenderState(D3DRS_LIGHTING, FALSE);
|
|
STATEMANAGER.SetTexture(0, NULL);
|
|
STATEMANAGER.SetTexture(1, NULL);
|
|
|
|
|
|
D3DXMATRIX m;
|
|
CScreen s;s.UpdateViewMatrix();
|
|
CCamera * pCurrentCamera = CCameraManager::Instance().GetCurrentCamera();
|
|
if (!pCurrentCamera)
|
|
return;
|
|
|
|
const D3DXMATRIX & M = pCurrentCamera->GetViewMatrix();
|
|
D3DXMatrixIdentity(&m);
|
|
D3DXVECTOR3 F(pCurrentCamera->GetView());
|
|
m._31 = F.x;
|
|
m._32 = F.y;
|
|
m._33 = F.z;
|
|
|
|
Frustum & frustum = s.GetFrustum();
|
|
//frustum.BuildViewFrustum(ms_matView * ms_matProj);
|
|
|
|
TTimePositionDeque::iterator it1, it2;
|
|
it2 = it1 = m_TimePositionDeque.begin();
|
|
++it2;
|
|
for(;it2!=m_TimePositionDeque.end();++it2,++it1)
|
|
{
|
|
const D3DXVECTOR3& rkOld=it1->second;
|
|
const D3DXVECTOR3& rkNew=it2->second;
|
|
D3DXVECTOR3 B = rkNew - rkOld;
|
|
|
|
float radius = max(fabs(B.x),max(fabs(B.y),fabs(B.z)))/2;
|
|
Vector3d c(it1->second.x+B.x*0.5f,
|
|
it1->second.y+B.y*0.5f,
|
|
it1->second.z+B.z*0.5f
|
|
);
|
|
if (frustum.ViewVolumeTest(c, radius)==VS_OUTSIDE)
|
|
continue;
|
|
|
|
float rate1 = (1-(CTimer::Instance().GetCurrentSecond()-it1->first)/m_fTailLength);
|
|
float rate2 = (1-(CTimer::Instance().GetCurrentSecond()-it2->first)/m_fTailLength);
|
|
float size1 = m_fSize;
|
|
float size2 = m_fSize;
|
|
if (!m_bRectShape)
|
|
{
|
|
size1 *= rate1;
|
|
size2 *= rate2;
|
|
}
|
|
TFlyVertex v[6] =
|
|
{
|
|
TFlyVertex(D3DXVECTOR3(0.0f,size1,0.0f), m_dwColor,D3DXVECTOR2(0.0f,0.0f)),
|
|
TFlyVertex(D3DXVECTOR3(-size1,0.0f,0.0f),m_dwColor,D3DXVECTOR2(0.0f,0.5f)),
|
|
TFlyVertex(D3DXVECTOR3(size1,0.0f,0.0f), m_dwColor,D3DXVECTOR2(0.5f,0.0f)),
|
|
TFlyVertex(D3DXVECTOR3(-size2,0.0f,0.0f),m_dwColor,D3DXVECTOR2(0.5f,1.0f)),
|
|
TFlyVertex(D3DXVECTOR3(size2,0.0f,0.0f), m_dwColor,D3DXVECTOR2(1.0f,0.5f)),
|
|
TFlyVertex(D3DXVECTOR3(0.0f,-size2,0.0f),m_dwColor,D3DXVECTOR2(1.0f,1.0f)),
|
|
|
|
/*TVertex(D3DXVECTOR3(0.0f,size1,0.0f), ((DWORD)(0x40*rate1)<<24) + 0x0000ff,D3DXVECTOR2(0.0f,0.0f)),
|
|
TVertex(D3DXVECTOR3(-size1,0.0f,0.0f),((DWORD)(0x40*rate1)<<24) + 0x0000ff,D3DXVECTOR2(0.0f,0.0f)),
|
|
TVertex(D3DXVECTOR3(size1,0.0f,0.0f), ((DWORD)(0x40*rate1)<<24) + 0x0000ff,D3DXVECTOR2(0.0f,0.0f)),
|
|
TVertex(D3DXVECTOR3(-size2,0.0f,0.0f),((DWORD)(0x40*rate2)<<24) + 0x0000ff,D3DXVECTOR2(0.0f,0.0f)),
|
|
TVertex(D3DXVECTOR3(size2,0.0f,0.0f), ((DWORD)(0x40*rate2)<<24) + 0x0000ff,D3DXVECTOR2(0.0f,0.0f)),
|
|
TVertex(D3DXVECTOR3(0.0f,-size2,0.0f),((DWORD)(0x40*rate2)<<24) + 0x0000ff,D3DXVECTOR2(0.0f,0.0f)),*/
|
|
|
|
/*TVertex(D3DXVECTOR3(0.0f,size1,0.0f),0x20ff0000,D3DXVECTOR2(0.0f,0.0f)),
|
|
TVertex(D3DXVECTOR3(-size1,0.0f,0.0f),0x20ff0000,D3DXVECTOR2(0.0f,0.0f)),
|
|
TVertex(D3DXVECTOR3(size1,0.0f,0.0f),0x20ff0000,D3DXVECTOR2(0.0f,0.0f)),
|
|
TVertex(D3DXVECTOR3(-size2,0.0f,0.0f),0x20ff0000,D3DXVECTOR2(0.0f,0.0f)),
|
|
TVertex(D3DXVECTOR3(size2,0.0f,0.0f),0x20ff0000,D3DXVECTOR2(0.0f,0.0f)),
|
|
TVertex(D3DXVECTOR3(0.0f,-size2,0.0f),0x20ff0000,D3DXVECTOR2(0.0f,0.0f)),*/
|
|
|
|
/*TVertex(D3DXVECTOR3(0.0f,size1,0.0f),0xffff0000,D3DXVECTOR2(0.0f,0.0f)),
|
|
TVertex(D3DXVECTOR3(-size1,0.0f,0.0f),0xffff0000,D3DXVECTOR2(0.0f,0.0f)),
|
|
TVertex(D3DXVECTOR3(size1,0.0f,0.0f),0xffff0000,D3DXVECTOR2(0.0f,0.0f)),
|
|
TVertex(D3DXVECTOR3(-size2,0.0f,0.0f),0xff0000ff,D3DXVECTOR2(0.0f,0.0f)),
|
|
TVertex(D3DXVECTOR3(size2,0.0f,0.0f),0xff0000ff,D3DXVECTOR2(0.0f,0.0f)),
|
|
TVertex(D3DXVECTOR3(0.0f,-size2,0.0f),0xff0000ff,D3DXVECTOR2(0.0f,0.0f)),*/
|
|
};
|
|
|
|
|
|
D3DXVECTOR3 E(M._41,M._42,M._43);
|
|
E = pCurrentCamera->GetEye();
|
|
E-=it1->second;
|
|
|
|
D3DXVECTOR3 P;
|
|
D3DXVec3Cross(&P, &B,&E);
|
|
|
|
D3DXVECTOR3 U;
|
|
D3DXVec3Cross(&U,&F,&P);
|
|
D3DXVec3Normalize(&U,&U);
|
|
D3DXVECTOR3 R;
|
|
D3DXVec3Cross(&R,&F,&U);
|
|
//D3DXMatrixIdentity(&m);
|
|
m._21 = U.x;
|
|
m._22 = U.y;
|
|
m._23 = U.z;
|
|
m._11 = R.x;
|
|
m._12 = R.y;
|
|
m._13 = R.z;
|
|
int i;
|
|
for(i=0;i<6;i++)
|
|
D3DXVec3TransformNormal(&v[i].p,&v[i].p,&m);
|
|
for(i=0;i<3;i++)
|
|
v[i].p += it1->second;
|
|
for(;i<6;i++)
|
|
v[i].p += it2->second;
|
|
//for(i=0;i<6;i++)
|
|
// Tracenf("#%d:%f %f %f", i, v[i].p.x,v[i].p.y,v[i].p.z);
|
|
|
|
VSVector.push_back(std::make_pair(-D3DXVec3Dot(&E,&pCurrentCamera->GetView()),TFlyVertexSet(v)));
|
|
//OLD: STATEMANAGER.DrawPrimitiveUP(D3DPT_TRIANGLESTRIP, 4, v, sizeof(TVertex));
|
|
//OLD: STATEMANAGER.DrawPrimitiveUP(D3DPT_TRIANGLESTRIP, 2, v+1, sizeof(TVertex));
|
|
}
|
|
|
|
std::sort(VSVector.begin(),VSVector.end());
|
|
|
|
for(TFlyVertexSetVector::iterator it = VSVector.begin();it!=VSVector.end();++it)
|
|
{
|
|
STATEMANAGER.DrawPrimitiveUP(D3DPT_TRIANGLESTRIP, 4, it->second.v, sizeof(TVertex));
|
|
}
|
|
STATEMANAGER.RestoreRenderState(D3DRS_DESTBLEND);
|
|
STATEMANAGER.RestoreRenderState(D3DRS_SRCBLEND);
|
|
STATEMANAGER.RestoreRenderState(D3DRS_ALPHABLENDENABLE);
|
|
STATEMANAGER.RestoreRenderState(D3DRS_CULLMODE);
|
|
STATEMANAGER.RestoreVertexShader();
|
|
STATEMANAGER.RestoreTransform(D3DTS_WORLD);
|
|
//STATEMANAGER.RestoreRenderState(D3DRS_ZWRITEENABLE);
|
|
STATEMANAGER.RestoreRenderState(D3DRS_ZFUNC);
|
|
STATEMANAGER.RestoreRenderState(D3DRS_BLENDOP);
|
|
|
|
STATEMANAGER.RestoreRenderState(D3DRS_ALPHATESTENABLE);
|
|
STATEMANAGER.RestoreRenderState(D3DRS_ALPHAFUNC);
|
|
STATEMANAGER.RestoreRenderState(D3DRS_ALPHAREF);
|
|
|
|
} |