- additional fixed to make the viewer work without shaders. Still dummy, though, but now useful enough to allow me to work

git-svn-id: https://assimp.svn.sourceforge.net/svnroot/assimp/trunk@175 67173fc5-114c-0410-ac8e-9d2fd5bffc1f
pull/1/head
ulfjorensen 2008-10-13 15:50:12 +00:00
parent 366562e5d1
commit f204ff0d45
4 changed files with 61 additions and 26 deletions

View File

@ -1671,6 +1671,10 @@ int CDisplay::HandleInputEmptyScene()
//------------------------------------------------------------------------------- //-------------------------------------------------------------------------------
int CDisplay::DrawHUD() int CDisplay::DrawHUD()
{ {
// HACK: (thom) can't get the effect to work on non-shader cards, therefore deactivated for the moment
if( g_sCaps.PixelShaderVersion < D3DPS_VERSION(2,0))
return 1;
// get the dimension of the back buffer // get the dimension of the back buffer
RECT sRect; RECT sRect;
GetWindowRect(GetDlgItem(g_hDlg,IDC_RT),&sRect); GetWindowRect(GetDlgItem(g_hDlg,IDC_RT),&sRect);
@ -1688,7 +1692,10 @@ int CDisplay::DrawHUD()
// NOTE: The shader might be used for other purposes, too. // NOTE: The shader might be used for other purposes, too.
// So ensure the right technique is there // So ensure the right technique is there
g_piPassThroughEffect->SetTechnique("PassThrough"); if( g_sCaps.PixelShaderVersion < D3DPS_VERSION(2,0))
g_piPassThroughEffect->SetTechnique( "PassThrough_FF");
else
g_piPassThroughEffect->SetTechnique("PassThrough");
// build vertices for drawing from system memory // build vertices for drawing from system memory
UINT dw; UINT dw;
@ -1877,9 +1884,11 @@ int CDisplay::RenderNode (aiNode* piNode,const aiMatrix4x4& piMatrix,
apcVec[0].x = g_avLightDirs[0].x; apcVec[0].x = g_avLightDirs[0].x;
apcVec[0].y = g_avLightDirs[0].y; apcVec[0].y = g_avLightDirs[0].y;
apcVec[0].z = g_avLightDirs[0].z; apcVec[0].z = g_avLightDirs[0].z;
apcVec[0].w = 0.0f;
apcVec[1].x = g_avLightDirs[0].x * -1.0f; apcVec[1].x = g_avLightDirs[0].x * -1.0f;
apcVec[1].y = g_avLightDirs[0].y * -1.0f; apcVec[1].y = g_avLightDirs[0].y * -1.0f;
apcVec[1].z = g_avLightDirs[0].z * -1.0f; apcVec[1].z = g_avLightDirs[0].z * -1.0f;
apcVec[1].w = 0.0f;
D3DXVec4Normalize(&apcVec[0],&apcVec[0]); D3DXVec4Normalize(&apcVec[0],&apcVec[0]);
D3DXVec4Normalize(&apcVec[1],&apcVec[1]); D3DXVec4Normalize(&apcVec[1],&apcVec[1]);
@ -1890,10 +1899,19 @@ int CDisplay::RenderNode (aiNode* piNode,const aiMatrix4x4& piMatrix,
apcVec[0].z = ((g_avLightColors[0]) & 0xFF) / 255.0f; apcVec[0].z = ((g_avLightColors[0]) & 0xFF) / 255.0f;
apcVec[0].w = 1.0f; apcVec[0].w = 1.0f;
apcVec[1].x = ((g_avLightColors[1] >> 16) & 0xFF) / 255.0f; if( g_sOptions.b3Lights)
apcVec[1].y = ((g_avLightColors[1] >> 8) & 0xFF) / 255.0f; {
apcVec[1].z = ((g_avLightColors[1]) & 0xFF) / 255.0f; apcVec[1].x = ((g_avLightColors[1] >> 16) & 0xFF) / 255.0f;
apcVec[1].w = 0.0f; apcVec[1].y = ((g_avLightColors[1] >> 8) & 0xFF) / 255.0f;
apcVec[1].z = ((g_avLightColors[1]) & 0xFF) / 255.0f;
apcVec[1].w = 0.0f;
} else
{
apcVec[1].x = 0.0f;
apcVec[1].y = 0.0f;
apcVec[1].z = 0.0f;
apcVec[1].w = 0.0f;
}
apcVec[0] *= g_fLightIntensity; apcVec[0] *= g_fLightIntensity;
apcVec[1] *= g_fLightIntensity; apcVec[1] *= g_fLightIntensity;
@ -2143,7 +2161,10 @@ int CDisplay::RenderTextureView()
{ {
g_piPassThroughEffect->SetTechnique("PassThroughAlphaFromA"); g_piPassThroughEffect->SetTechnique("PassThroughAlphaFromA");
} }
else g_piPassThroughEffect->SetTechnique("PassThrough"); else if( g_sCaps.PixelShaderVersion < D3DPS_VERSION(2,0))
g_piPassThroughEffect->SetTechnique( "PassThrough_FF");
else
g_piPassThroughEffect->SetTechnique("PassThrough");
UINT dw; UINT dw;
g_piPassThroughEffect->Begin(&dw,0); g_piPassThroughEffect->Begin(&dw,0);

View File

@ -1129,9 +1129,11 @@ int CMaterialManager::SetupMaterial (
apcVec[0].x = g_avLightDirs[0].x; apcVec[0].x = g_avLightDirs[0].x;
apcVec[0].y = g_avLightDirs[0].y; apcVec[0].y = g_avLightDirs[0].y;
apcVec[0].z = g_avLightDirs[0].z; apcVec[0].z = g_avLightDirs[0].z;
apcVec[0].w = 0.0f;
apcVec[1].x = g_avLightDirs[0].x * -1.0f; apcVec[1].x = g_avLightDirs[0].x * -1.0f;
apcVec[1].y = g_avLightDirs[0].y * -1.0f; apcVec[1].y = g_avLightDirs[0].y * -1.0f;
apcVec[1].z = g_avLightDirs[0].z * -1.0f; apcVec[1].z = g_avLightDirs[0].z * -1.0f;
apcVec[1].w = 0.0f;
D3DXVec4Normalize(&apcVec[0],&apcVec[0]); D3DXVec4Normalize(&apcVec[0],&apcVec[0]);
D3DXVec4Normalize(&apcVec[1],&apcVec[1]); D3DXVec4Normalize(&apcVec[1],&apcVec[1]);
piEnd->SetVectorArray("afLightDir",apcVec,5); piEnd->SetVectorArray("afLightDir",apcVec,5);
@ -1141,10 +1143,19 @@ int CMaterialManager::SetupMaterial (
apcVec[0].z = ((g_avLightColors[0]) & 0xFF) / 255.0f; apcVec[0].z = ((g_avLightColors[0]) & 0xFF) / 255.0f;
apcVec[0].w = 1.0f; apcVec[0].w = 1.0f;
apcVec[1].x = ((g_avLightColors[1] >> 16) & 0xFF) / 255.0f; if( g_sOptions.b3Lights)
apcVec[1].y = ((g_avLightColors[1] >> 8) & 0xFF) / 255.0f; {
apcVec[1].z = ((g_avLightColors[1]) & 0xFF) / 255.0f; apcVec[1].x = ((g_avLightColors[1] >> 16) & 0xFF) / 255.0f;
apcVec[1].w = 0.0f; apcVec[1].y = ((g_avLightColors[1] >> 8) & 0xFF) / 255.0f;
apcVec[1].z = ((g_avLightColors[1]) & 0xFF) / 255.0f;
apcVec[1].w = 0.0f;
} else
{
apcVec[1].x = 0.0f;
apcVec[1].y = 0.0f;
apcVec[1].z = 0.0f;
apcVec[1].w = 0.0f;
}
apcVec[0] *= g_fLightIntensity; apcVec[0] *= g_fLightIntensity;
apcVec[1] *= g_fLightIntensity; apcVec[1] *= g_fLightIntensity;

View File

@ -302,11 +302,11 @@ std::string g_szDefaultShader = std::string(
// Multiply with the WorldViewProjection matrix // Multiply with the WorldViewProjection matrix
"Out.Position = mul(float4(IN.Position,1.0f),WorldViewProjection);\n" "Out.Position = mul(float4(IN.Position,1.0f),WorldViewProjection);\n"
"float3 worldNormal = mul( IN.Normal, (float3x3) WorldInverseTranspose); \n" "float3 worldNormal = normalize( mul( IN.Normal, (float3x3) WorldInverseTranspose)); \n"
// per-vertex lighting. We simply assume light colors of unused lights to be black // per-vertex lighting. We simply assume light colors of unused lights to be black
"Out.Color = float4( 0.2f, 0.2f, 0.2f, 1.0f); \n" "Out.Color = float4( 0.2f, 0.2f, 0.2f, 1.0f); \n"
"for( int a = 0; a < 5; a++)\n" "for( int a = 0; a < 2; a++)\n"
" Out.Color.rgb += saturate( dot( afLightDir[a], worldNormal)) * afLightColor[a].rgb; \n" " Out.Color.rgb += saturate( dot( afLightDir[a], worldNormal)) * afLightColor[a].rgb; \n"
"return Out;\n" "return Out;\n"
"}\n" "}\n"
@ -702,12 +702,12 @@ std::string g_szMaterialShader = std::string(
// Multiply with the WorldViewProjection matrix // Multiply with the WorldViewProjection matrix
"Out.Position = mul( float4( IN.Position, 1.0f), WorldViewProjection);\n" "Out.Position = mul( float4( IN.Position, 1.0f), WorldViewProjection);\n"
"float3 worldPos = mul( float4( IN.Position, 1.0f), World);\n" "float3 worldPos = mul( float4( IN.Position, 1.0f), World);\n"
"float3 worldNormal = mul( IN.Normal, (float3x3) WorldInverseTranspose); \n" "float3 worldNormal = normalize( mul( IN.Normal, (float3x3) WorldInverseTranspose)); \n"
"Out.TexCoord0 = IN.TexCoord0;\n" "Out.TexCoord0 = IN.TexCoord0;\n"
// calculate per-vertex diffuse lighting including ambient part // calculate per-vertex diffuse lighting including ambient part
"float4 diffuseColor = float4( 0.0f, 0.0f, 0.0f, 1.0f); \n" "float4 diffuseColor = float4( 0.0f, 0.0f, 0.0f, 1.0f); \n"
"for( int a = 0; a < 5; a++) \n" "for( int a = 0; a < 2; a++) \n"
" diffuseColor.rgb += saturate( dot( afLightDir[a], worldNormal)) * afLightColor[a].rgb; \n" " diffuseColor.rgb += saturate( dot( afLightDir[a], worldNormal)) * afLightColor[a].rgb; \n"
// factor in material properties and a bit of ambient lighting // factor in material properties and a bit of ambient lighting
"Out.DiffuseColor = diffuseColor * DIFFUSE_COLOR + float4( 0.2f, 0.2f, 0.2f, 1.0f) * AMBIENT_COLOR; ; \n" "Out.DiffuseColor = diffuseColor * DIFFUSE_COLOR + float4( 0.2f, 0.2f, 0.2f, 1.0f) * AMBIENT_COLOR; ; \n"
@ -716,10 +716,10 @@ std::string g_szMaterialShader = std::string(
"float4 specularColor = float4( 0.0f, 0.0f, 0.0f, 1.0f); \n" "float4 specularColor = float4( 0.0f, 0.0f, 0.0f, 1.0f); \n"
"#ifdef AV_SPECULAR_COMPONENT\n" "#ifdef AV_SPECULAR_COMPONENT\n"
"float3 viewDir = normalize( worldPos - vCameraPos); \n" "float3 viewDir = normalize( worldPos - vCameraPos); \n"
"for( int a = 0; a < 5; a++) \n" "for( int a = 0; a < 2; a++) \n"
"{ \n" "{ \n"
" float3 reflDir = reflect( afLightDir[a], worldNormal); \n" " float3 reflDir = reflect( afLightDir[a], worldNormal); \n"
" float specIntensity = pow( dot( -reflDir, viewDir), SPECULAR_STRENGTH) * SPECULARITY; \n" " float specIntensity = pow( saturate( dot( reflDir, viewDir)), SPECULARITY) * SPECULAR_STRENGTH; \n"
" specularColor.rgb += afLightColor[a] * specIntensity; \n" " specularColor.rgb += afLightColor[a] * specIntensity; \n"
"} \n" "} \n"
"#endif // AV_SPECULAR_COMPONENT\n" "#endif // AV_SPECULAR_COMPONENT\n"

View File

@ -910,17 +910,20 @@ int CreateDevice (bool p_bMultiSample,bool p_bSuperSample,bool bHW /*= true*/)
sParams.MultiSampleType = sMSOut; sParams.MultiSampleType = sMSOut;
} }
// create the D3D9 device object // preget the device capabilities. If the hardware vertex shader is too old, we prefer software vertex processing
if(FAILED(g_piD3D->CreateDevice(0,eType, g_piD3D->GetDeviceCaps( 0, D3DDEVTYPE_HAL, &g_sCaps);
g_hDlg,D3DCREATE_HARDWARE_VERTEXPROCESSING | D3DCREATE_MULTITHREADED,&sParams,&g_piDevice))) DWORD creationFlags = D3DCREATE_MULTITHREADED;
if( g_sCaps.VertexShaderVersion >= D3DVS_VERSION( 2, 0))
creationFlags |= D3DCREATE_HARDWARE_VERTEXPROCESSING;
else
creationFlags |= D3DCREATE_SOFTWARE_VERTEXPROCESSING;
// create the D3D9 device object. with software-vertexprocessing if VS2.0 isn`t supported in hardware
if(FAILED(g_piD3D->CreateDevice(0,eType, g_hDlg, creationFlags ,&sParams,&g_piDevice)))
{ {
if(FAILED(g_piD3D->CreateDevice(0,eType, // if hardware fails use software rendering instead
g_hDlg,D3DCREATE_SOFTWARE_VERTEXPROCESSING | D3DCREATE_MULTITHREADED,&sParams,&g_piDevice))) if (bHW)return CreateDevice(p_bMultiSample,p_bSuperSample,false);
{ return 0;
// if hardware fails use software rendering instead
if (bHW)return CreateDevice(p_bMultiSample,p_bSuperSample,false);
return 0;
}
} }
g_piDevice->SetFVF(AssetHelper::Vertex::GetFVF()); g_piDevice->SetFVF(AssetHelper::Vertex::GetFVF());