add emissive support
- does not effect other objects in scene
This commit is contained in:
parent
32f0916f97
commit
cbb05cac56
8 changed files with 68 additions and 8 deletions
BIN
Assets/Textures/HQGame/structure-endgame-deepfloor_emissive.png
Normal file
BIN
Assets/Textures/HQGame/structure-endgame-deepfloor_emissive.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 372 KiB |
BIN
Assets/Textures/HQGame/structure-endgame-floor_emissive.png
Normal file
BIN
Assets/Textures/HQGame/structure-endgame-floor_emissive.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 60 KiB |
|
@ -655,6 +655,36 @@
|
||||||
<DestinationFolders Condition="'$(Configuration)|$(Platform)'=='Release|x64'">$(OutDir)/Assets/Textures/HQGame</DestinationFolders>
|
<DestinationFolders Condition="'$(Configuration)|$(Platform)'=='Release|x64'">$(OutDir)/Assets/Textures/HQGame</DestinationFolders>
|
||||||
</CopyFileToFolders>
|
</CopyFileToFolders>
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
<ItemGroup>
|
||||||
|
<CopyFileToFolders Include="Assets\Textures\HQGame\structure-endgame-deepfloor_emissive.png">
|
||||||
|
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">false</ExcludedFromBuild>
|
||||||
|
<DeploymentContent Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</DeploymentContent>
|
||||||
|
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">false</ExcludedFromBuild>
|
||||||
|
<DeploymentContent Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</DeploymentContent>
|
||||||
|
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">false</ExcludedFromBuild>
|
||||||
|
<DeploymentContent Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</DeploymentContent>
|
||||||
|
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">false</ExcludedFromBuild>
|
||||||
|
<DeploymentContent Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</DeploymentContent>
|
||||||
|
<DestinationFolders Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">$(OutDir)/Assets/Textures/HQGame</DestinationFolders>
|
||||||
|
<DestinationFolders Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">$(OutDir)/Assets/Textures/HQGame</DestinationFolders>
|
||||||
|
<DestinationFolders Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">$(OutDir)/Assets/Textures/HQGame</DestinationFolders>
|
||||||
|
<DestinationFolders Condition="'$(Configuration)|$(Platform)'=='Release|x64'">$(OutDir)/Assets/Textures/HQGame</DestinationFolders>
|
||||||
|
</CopyFileToFolders>
|
||||||
|
<CopyFileToFolders Include="Assets\Textures\HQGame\structure-endgame-floor_emissive.png">
|
||||||
|
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">false</ExcludedFromBuild>
|
||||||
|
<DeploymentContent Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">true</DeploymentContent>
|
||||||
|
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">false</ExcludedFromBuild>
|
||||||
|
<DeploymentContent Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">true</DeploymentContent>
|
||||||
|
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">false</ExcludedFromBuild>
|
||||||
|
<DeploymentContent Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">true</DeploymentContent>
|
||||||
|
<ExcludedFromBuild Condition="'$(Configuration)|$(Platform)'=='Release|x64'">false</ExcludedFromBuild>
|
||||||
|
<DeploymentContent Condition="'$(Configuration)|$(Platform)'=='Release|x64'">true</DeploymentContent>
|
||||||
|
<DestinationFolders Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">$(OutDir)/Assets/Textures/HQGame</DestinationFolders>
|
||||||
|
<DestinationFolders Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">$(OutDir)/Assets/Textures/HQGame</DestinationFolders>
|
||||||
|
<DestinationFolders Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">$(OutDir)/Assets/Textures/HQGame</DestinationFolders>
|
||||||
|
<DestinationFolders Condition="'$(Configuration)|$(Platform)'=='Release|x64'">$(OutDir)/Assets/Textures/HQGame</DestinationFolders>
|
||||||
|
</CopyFileToFolders>
|
||||||
|
</ItemGroup>
|
||||||
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" />
|
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" />
|
||||||
<ImportGroup Label="ExtensionTargets">
|
<ImportGroup Label="ExtensionTargets">
|
||||||
<Import Project="packages\Microsoft.XAudio2.Redist.1.2.8\build\native\Microsoft.XAudio2.Redist.targets" Condition="Exists('packages\Microsoft.XAudio2.Redist.1.2.8\build\native\Microsoft.XAudio2.Redist.targets')" />
|
<Import Project="packages\Microsoft.XAudio2.Redist.1.2.8\build\native\Microsoft.XAudio2.Redist.targets" Condition="Exists('packages\Microsoft.XAudio2.Redist.1.2.8\build\native\Microsoft.XAudio2.Redist.targets')" />
|
||||||
|
|
|
@ -204,6 +204,12 @@
|
||||||
<CopyFileToFolders Include="Assets\Textures\HQGame\structure-endgame-floor_specular.png">
|
<CopyFileToFolders Include="Assets\Textures\HQGame\structure-endgame-floor_specular.png">
|
||||||
<Filter>Assets\Textures\HQGame</Filter>
|
<Filter>Assets\Textures\HQGame</Filter>
|
||||||
</CopyFileToFolders>
|
</CopyFileToFolders>
|
||||||
|
<CopyFileToFolders Include="Assets\Textures\HQGame\structure-endgame-deepfloor_emissive.png">
|
||||||
|
<Filter>Assets\Textures\HQGame</Filter>
|
||||||
|
</CopyFileToFolders>
|
||||||
|
<CopyFileToFolders Include="Assets\Textures\HQGame\structure-endgame-floor_emissive.png">
|
||||||
|
<Filter>Assets\Textures\HQGame</Filter>
|
||||||
|
</CopyFileToFolders>
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<None Include="Helpers.hlsli">
|
<None Include="Helpers.hlsli">
|
||||||
|
|
19
Game.cpp
19
Game.cpp
|
@ -106,61 +106,67 @@ void Game::LoadTextures()
|
||||||
device->CreateSamplerState(&sampDesc, sampler.GetAddressOf());
|
device->CreateSamplerState(&sampDesc, sampler.GetAddressOf());
|
||||||
|
|
||||||
Microsoft::WRL::ComPtr<ID3D11ShaderResourceView>
|
Microsoft::WRL::ComPtr<ID3D11ShaderResourceView>
|
||||||
|
deepFloorEmissive,
|
||||||
deepFloorSpecular,
|
deepFloorSpecular,
|
||||||
deepFloorAlbedo,
|
deepFloorAlbedo,
|
||||||
|
floorEmissive,
|
||||||
floorSpecular,
|
floorSpecular,
|
||||||
floorAlbedo;
|
floorAlbedo;
|
||||||
|
|
||||||
// taking the preprocessor macro from the demo because I don't like typing
|
// taking the preprocessor macro from the demo because I don't like typing
|
||||||
#define GetTex(pathToTexture, shaderResourceView) CreateWICTextureFromFile(device.Get(), context.Get(), GetFullPathTo_Wide(pathToTexture).c_str(), 0, shaderResourceView.GetAddressOf());
|
#define GetTex(pathToTexture, shaderResourceView) CreateWICTextureFromFile(device.Get(), context.Get(), GetFullPathTo_Wide(pathToTexture).c_str(), 0, shaderResourceView.GetAddressOf());
|
||||||
|
|
||||||
|
GetTex(L"Assets/Textures/HQGame/structure-endgame-deepfloor_emissive.png", deepFloorEmissive);
|
||||||
GetTex(L"Assets/Textures/HQGame/structure-endgame-deepfloor_specular.png", deepFloorSpecular);
|
GetTex(L"Assets/Textures/HQGame/structure-endgame-deepfloor_specular.png", deepFloorSpecular);
|
||||||
GetTex(L"Assets/Textures/HQGame/structure-endgame-deepfloor_albedo.png", deepFloorAlbedo);
|
GetTex(L"Assets/Textures/HQGame/structure-endgame-deepfloor_albedo.png", deepFloorAlbedo);
|
||||||
|
GetTex(L"Assets/Textures/HQGame/structure-endgame-floor_emissive.png", floorEmissive);
|
||||||
GetTex(L"Assets/Textures/HQGame/structure-endgame-floor_specular.png", floorSpecular);
|
GetTex(L"Assets/Textures/HQGame/structure-endgame-floor_specular.png", floorSpecular);
|
||||||
GetTex(L"Assets/Textures/HQGame/structure-endgame-floor_albedo.png", floorAlbedo);
|
GetTex(L"Assets/Textures/HQGame/structure-endgame-floor_albedo.png", floorAlbedo);
|
||||||
|
|
||||||
materials[0]->PushSampler("BasicSampler", sampler);
|
materials[0]->PushSampler("BasicSampler", sampler);
|
||||||
materials[0]->PushTexture("Albedo", deepFloorAlbedo);
|
materials[0]->PushTexture("Albedo", deepFloorAlbedo);
|
||||||
materials[0]->PushTexture("Specular", deepFloorSpecular);
|
materials[0]->PushTexture("Specular", deepFloorSpecular);
|
||||||
|
materials[0]->PushTexture("Emissive", deepFloorEmissive);
|
||||||
materials[1]->PushSampler("BasicSampler", sampler);
|
materials[1]->PushSampler("BasicSampler", sampler);
|
||||||
materials[1]->PushTexture("Albedo", floorAlbedo);
|
materials[1]->PushTexture("Albedo", floorAlbedo);
|
||||||
materials[1]->PushTexture("Specular", floorSpecular);
|
materials[1]->PushTexture("Specular", floorSpecular);
|
||||||
|
materials[1]->PushTexture("Emissive", floorEmissive);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Game::LoadLighting()
|
void Game::LoadLighting()
|
||||||
{
|
{
|
||||||
ambient = XMFLOAT3(0.1f, 0.1f, 0.25f);
|
ambient = XMFLOAT3(0.1f, 0.1f, 0.15f);
|
||||||
|
|
||||||
Light directionalLight0 = {};
|
Light directionalLight0 = {};
|
||||||
directionalLight0.Type = LIGHT_TYPE_DIRECTIONAL;
|
directionalLight0.Type = LIGHT_TYPE_DIRECTIONAL;
|
||||||
directionalLight0.Direction = XMFLOAT3(1, 0.5f, 0.5f);
|
directionalLight0.Direction = XMFLOAT3(1, 0.5f, 0.5f);
|
||||||
directionalLight0.Color = XMFLOAT3(1, 1, 1);
|
directionalLight0.Color = XMFLOAT3(1, 1, 1);
|
||||||
directionalLight0.Intensity = 1.0f;
|
directionalLight0.Intensity = 0.5f;
|
||||||
|
|
||||||
Light directionalLight1 = {};
|
Light directionalLight1 = {};
|
||||||
directionalLight1.Type = LIGHT_TYPE_DIRECTIONAL;
|
directionalLight1.Type = LIGHT_TYPE_DIRECTIONAL;
|
||||||
directionalLight1.Direction = XMFLOAT3(-0.25f, -1, 0.75f);
|
directionalLight1.Direction = XMFLOAT3(-0.25f, -1, 0.75f);
|
||||||
directionalLight1.Color = XMFLOAT3(1, 1, 1);
|
directionalLight1.Color = XMFLOAT3(1, 1, 1);
|
||||||
directionalLight1.Intensity = 1.0f;
|
directionalLight1.Intensity = 0.5f;
|
||||||
|
|
||||||
Light directionalLight2 = {};
|
Light directionalLight2 = {};
|
||||||
directionalLight2.Type = LIGHT_TYPE_DIRECTIONAL;
|
directionalLight2.Type = LIGHT_TYPE_DIRECTIONAL;
|
||||||
directionalLight2.Direction = XMFLOAT3(-1, 1, -0.5f);
|
directionalLight2.Direction = XMFLOAT3(-1, 1, -0.5f);
|
||||||
directionalLight2.Color = XMFLOAT3(1, 1, 1);
|
directionalLight2.Color = XMFLOAT3(1, 1, 1);
|
||||||
directionalLight2.Intensity = 1.0f;
|
directionalLight2.Intensity = 0.5f;
|
||||||
|
|
||||||
Light pointLight0 = {};
|
Light pointLight0 = {};
|
||||||
pointLight0.Type = LIGHT_TYPE_POINT;
|
pointLight0.Type = LIGHT_TYPE_POINT;
|
||||||
pointLight0.Position = XMFLOAT3(-1.5f, 0, 0);
|
pointLight0.Position = XMFLOAT3(-1.5f, 0, 0);
|
||||||
pointLight0.Color = XMFLOAT3(1, 1, 1);
|
pointLight0.Color = XMFLOAT3(1, 1, 1);
|
||||||
pointLight0.Intensity = 1.0f;
|
pointLight0.Intensity = 0.5f;
|
||||||
pointLight0.Range = 10;
|
pointLight0.Range = 10;
|
||||||
|
|
||||||
Light pointLight1 = {};
|
Light pointLight1 = {};
|
||||||
pointLight1.Type = LIGHT_TYPE_POINT;
|
pointLight1.Type = LIGHT_TYPE_POINT;
|
||||||
pointLight1.Position = XMFLOAT3(1.5f, 0, 0);
|
pointLight1.Position = XMFLOAT3(1.5f, 0, 0);
|
||||||
pointLight1.Color = XMFLOAT3(1, 1, 1);
|
pointLight1.Color = XMFLOAT3(1, 1, 1);
|
||||||
pointLight1.Intensity = 0.5f;
|
pointLight1.Intensity = 0.25f;
|
||||||
pointLight1.Range = 10;
|
pointLight1.Range = 10;
|
||||||
|
|
||||||
lights = {
|
lights = {
|
||||||
|
@ -248,6 +254,7 @@ void Game::Update(float deltaTime, float totalTime)
|
||||||
entities[i]->GetMaterial()->SetRoughness(sin(totalTime) * 0.5f + 0.49f);
|
entities[i]->GetMaterial()->SetRoughness(sin(totalTime) * 0.5f + 0.49f);
|
||||||
entities[i]->GetMaterial()->SetUVOffset(DirectX::XMFLOAT2(cos(totalTime * 4) * 0.5f + 0.49f, cos(totalTime * 4) * 0.5f + 0.49f));
|
entities[i]->GetMaterial()->SetUVOffset(DirectX::XMFLOAT2(cos(totalTime * 4) * 0.5f + 0.49f, cos(totalTime * 4) * 0.5f + 0.49f));
|
||||||
entities[i]->GetMaterial()->SetUVScale(DirectX::XMFLOAT2(sin(totalTime) * 0.5f + 0.49f, sin(totalTime) * 0.5f + 0.49f));
|
entities[i]->GetMaterial()->SetUVScale(DirectX::XMFLOAT2(sin(totalTime) * 0.5f + 0.49f, sin(totalTime) * 0.5f + 0.49f));
|
||||||
|
entities[i]->GetMaterial()->SetEmitAmount(cos(totalTime) * 0.5f + 0.49f);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
13
Material.cpp
13
Material.cpp
|
@ -31,8 +31,9 @@ void Material::Activate(Transform* _transform, std::shared_ptr<Camera> _camera,
|
||||||
pixelShader->SetFloat("roughness", GetRoughness());
|
pixelShader->SetFloat("roughness", GetRoughness());
|
||||||
pixelShader->SetFloat2("scale", GetUVScale());
|
pixelShader->SetFloat2("scale", GetUVScale());
|
||||||
pixelShader->SetFloat2("offset", GetUVOffset());
|
pixelShader->SetFloat2("offset", GetUVOffset());
|
||||||
pixelShader->SetFloat3("tint", GetTint());
|
|
||||||
pixelShader->SetFloat3("ambient", _ambient);
|
pixelShader->SetFloat3("ambient", _ambient);
|
||||||
|
pixelShader->SetFloat("emitAmount", GetEmitAmount());
|
||||||
|
pixelShader->SetFloat3("tint", GetTint());
|
||||||
pixelShader->SetData("lights", &_lights[0], sizeof(Light) * (int)_lights.size());
|
pixelShader->SetData("lights", &_lights[0], sizeof(Light) * (int)_lights.size());
|
||||||
pixelShader->CopyAllBufferData();
|
pixelShader->CopyAllBufferData();
|
||||||
pixelShader->SetShader();
|
pixelShader->SetShader();
|
||||||
|
@ -67,6 +68,11 @@ float Material::GetRoughness()
|
||||||
return roughness;
|
return roughness;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
float Material::GetEmitAmount()
|
||||||
|
{
|
||||||
|
return emitAmount;
|
||||||
|
}
|
||||||
|
|
||||||
std::shared_ptr<SimpleVertexShader> Material::GetVertexShader()
|
std::shared_ptr<SimpleVertexShader> Material::GetVertexShader()
|
||||||
{
|
{
|
||||||
return vertexShader;
|
return vertexShader;
|
||||||
|
@ -108,6 +114,11 @@ void Material::SetRoughness(float _roughness)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Material::SetEmitAmount(float _emit)
|
||||||
|
{
|
||||||
|
emitAmount = _emit;
|
||||||
|
}
|
||||||
|
|
||||||
void Material::SetVertexShader(std::shared_ptr<SimpleVertexShader> _vertexShader)
|
void Material::SetVertexShader(std::shared_ptr<SimpleVertexShader> _vertexShader)
|
||||||
{
|
{
|
||||||
vertexShader = _vertexShader;
|
vertexShader = _vertexShader;
|
||||||
|
|
|
@ -27,6 +27,7 @@ public:
|
||||||
DirectX::XMFLOAT2 GetUVScale();
|
DirectX::XMFLOAT2 GetUVScale();
|
||||||
DirectX::XMFLOAT2 GetUVOffset();
|
DirectX::XMFLOAT2 GetUVOffset();
|
||||||
float GetRoughness();
|
float GetRoughness();
|
||||||
|
float GetEmitAmount();
|
||||||
std::shared_ptr<SimpleVertexShader> GetVertexShader();
|
std::shared_ptr<SimpleVertexShader> GetVertexShader();
|
||||||
std::shared_ptr<SimplePixelShader> GetPixelShader();
|
std::shared_ptr<SimplePixelShader> GetPixelShader();
|
||||||
|
|
||||||
|
@ -34,6 +35,7 @@ public:
|
||||||
void SetUVScale(DirectX::XMFLOAT2 _scale);
|
void SetUVScale(DirectX::XMFLOAT2 _scale);
|
||||||
void SetUVOffset(DirectX::XMFLOAT2 _offset);
|
void SetUVOffset(DirectX::XMFLOAT2 _offset);
|
||||||
void SetRoughness(float _roughness);
|
void SetRoughness(float _roughness);
|
||||||
|
void SetEmitAmount(float _emit);
|
||||||
void SetVertexShader(std::shared_ptr<SimpleVertexShader> _vertexShader);
|
void SetVertexShader(std::shared_ptr<SimpleVertexShader> _vertexShader);
|
||||||
void SetPixelShader(std::shared_ptr<SimplePixelShader> _pixelShader);
|
void SetPixelShader(std::shared_ptr<SimplePixelShader> _pixelShader);
|
||||||
|
|
||||||
|
@ -43,6 +45,7 @@ public:
|
||||||
private:
|
private:
|
||||||
DirectX::XMFLOAT3 tint;
|
DirectX::XMFLOAT3 tint;
|
||||||
float roughness;
|
float roughness;
|
||||||
|
float emitAmount;
|
||||||
DirectX::XMFLOAT2 uvScale;
|
DirectX::XMFLOAT2 uvScale;
|
||||||
DirectX::XMFLOAT2 uvOffset;
|
DirectX::XMFLOAT2 uvOffset;
|
||||||
std::shared_ptr<SimpleVertexShader> vertexShader;
|
std::shared_ptr<SimpleVertexShader> vertexShader;
|
||||||
|
|
|
@ -12,12 +12,14 @@ cbuffer ExternalData : register(b0)
|
||||||
float2 offset;
|
float2 offset;
|
||||||
float2 scale;
|
float2 scale;
|
||||||
float3 ambient;
|
float3 ambient;
|
||||||
|
float emitAmount;
|
||||||
float3 tint;
|
float3 tint;
|
||||||
Light lights[LIGHT_COUNT];
|
Light lights[LIGHT_COUNT];
|
||||||
}
|
}
|
||||||
|
|
||||||
Texture2D Albedo : register(t0);
|
Texture2D Albedo : register(t0);
|
||||||
Texture2D Specular : register(t1);
|
Texture2D Specular : register(t1);
|
||||||
|
Texture2D Emissive : register(t2);
|
||||||
SamplerState BasicSampler : register(s0);
|
SamplerState BasicSampler : register(s0);
|
||||||
|
|
||||||
// Gets the specular value for any light
|
// Gets the specular value for any light
|
||||||
|
@ -63,6 +65,7 @@ float4 main(VertexToPixel input) : SV_TARGET
|
||||||
|
|
||||||
float4 albedo = Albedo.Sample(BasicSampler, input.uv).rgba;
|
float4 albedo = Albedo.Sample(BasicSampler, input.uv).rgba;
|
||||||
float specular = Specular.Sample(BasicSampler, input.uv).r;
|
float specular = Specular.Sample(BasicSampler, input.uv).r;
|
||||||
|
float3 emit = Emissive.Sample(BasicSampler, input.uv).rgb;
|
||||||
float3 surface = albedo.rgb * tint;
|
float3 surface = albedo.rgb * tint;
|
||||||
float3 light = ambient * surface;
|
float3 light = ambient * surface;
|
||||||
|
|
||||||
|
@ -80,5 +83,5 @@ float4 main(VertexToPixel input) : SV_TARGET
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return float4(light, albedo.a);
|
return float4(light + (emit * emitAmount), albedo.a);
|
||||||
}
|
}
|
||||||
|
|
Reference in a new issue