outline toon shader
This commit is contained in:
parent
b2e003f394
commit
4bd3589ba6
5 changed files with 65 additions and 2 deletions
|
@ -212,6 +212,12 @@
|
||||||
<ShaderType Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">Vertex</ShaderType>
|
<ShaderType Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">Vertex</ShaderType>
|
||||||
<ShaderType Condition="'$(Configuration)|$(Platform)'=='Release|x64'">Vertex</ShaderType>
|
<ShaderType Condition="'$(Configuration)|$(Platform)'=='Release|x64'">Vertex</ShaderType>
|
||||||
</FxCompile>
|
</FxCompile>
|
||||||
|
<FxCompile Include="ToonShader.hlsl">
|
||||||
|
<ShaderType Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">Pixel</ShaderType>
|
||||||
|
<ShaderType Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">Pixel</ShaderType>
|
||||||
|
<ShaderType Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">Pixel</ShaderType>
|
||||||
|
<ShaderType Condition="'$(Configuration)|$(Platform)'=='Release|x64'">Pixel</ShaderType>
|
||||||
|
</FxCompile>
|
||||||
<FxCompile Include="VertexShader.hlsl">
|
<FxCompile Include="VertexShader.hlsl">
|
||||||
<ShaderType Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">Vertex</ShaderType>
|
<ShaderType Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">Vertex</ShaderType>
|
||||||
<ShaderModel Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">5.0</ShaderModel>
|
<ShaderModel Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">5.0</ShaderModel>
|
||||||
|
|
|
@ -139,6 +139,9 @@
|
||||||
<FxCompile Include="SimpleVertexPBR.hlsl">
|
<FxCompile Include="SimpleVertexPBR.hlsl">
|
||||||
<Filter>Shaders</Filter>
|
<Filter>Shaders</Filter>
|
||||||
</FxCompile>
|
</FxCompile>
|
||||||
|
<FxCompile Include="ToonShader.hlsl">
|
||||||
|
<Filter>Shaders</Filter>
|
||||||
|
</FxCompile>
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<CopyFileToFolders Include="Assets\Models\cube.obj">
|
<CopyFileToFolders Include="Assets\Models\cube.obj">
|
||||||
|
|
20
Game.cpp
20
Game.cpp
|
@ -76,6 +76,7 @@ void Game::LoadShadersAndMaterials()
|
||||||
pixelShader = std::make_shared<SimplePixelShader>(device, context, GetFullPathTo_Wide(L"SimplePixelShader.cso").c_str());
|
pixelShader = std::make_shared<SimplePixelShader>(device, context, GetFullPathTo_Wide(L"SimplePixelShader.cso").c_str());
|
||||||
vertexShaderPBR = std::make_shared<SimpleVertexShader>(device, context, GetFullPathTo_Wide(L"SimpleVertexPBR.cso").c_str());
|
vertexShaderPBR = std::make_shared<SimpleVertexShader>(device, context, GetFullPathTo_Wide(L"SimpleVertexPBR.cso").c_str());
|
||||||
pixelShaderPBR = std::make_shared<SimplePixelShader>(device, context, GetFullPathTo_Wide(L"SimplePixelPBR.cso").c_str());
|
pixelShaderPBR = std::make_shared<SimplePixelShader>(device, context, GetFullPathTo_Wide(L"SimplePixelPBR.cso").c_str());
|
||||||
|
pixelShaderToon = std::make_shared<SimplePixelShader>(device, context, GetFullPathTo_Wide(L"ToonShader.cso").c_str());
|
||||||
|
|
||||||
XMFLOAT3 white = XMFLOAT3(1.0f, 1.0f, 1.0f);
|
XMFLOAT3 white = XMFLOAT3(1.0f, 1.0f, 1.0f);
|
||||||
|
|
||||||
|
@ -88,6 +89,7 @@ void Game::LoadShadersAndMaterials()
|
||||||
std::make_shared<Material>(true, white, 0, vertexShaderPBR, pixelShaderPBR),
|
std::make_shared<Material>(true, white, 0, vertexShaderPBR, pixelShaderPBR),
|
||||||
std::make_shared<Material>(true, white, 0, vertexShaderPBR, pixelShaderPBR),
|
std::make_shared<Material>(true, white, 0, vertexShaderPBR, pixelShaderPBR),
|
||||||
std::make_shared<Material>(true, white, 0, vertexShaderPBR, pixelShaderPBR),
|
std::make_shared<Material>(true, white, 0, vertexShaderPBR, pixelShaderPBR),
|
||||||
|
std::make_shared<Material>(true, white, 0, vertexShader, pixelShaderToon),
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -222,11 +224,25 @@ void Game::CreateBasicGeometry()
|
||||||
std::make_shared<Entity>(materials[6], shapes[3]),
|
std::make_shared<Entity>(materials[6], shapes[3]),
|
||||||
std::make_shared<Entity>(materials[7], shapes[3]),
|
std::make_shared<Entity>(materials[7], shapes[3]),
|
||||||
std::make_shared<Entity>(materials[0], shapes[3]),
|
std::make_shared<Entity>(materials[0], shapes[3]),
|
||||||
|
|
||||||
|
std::make_shared<Entity>(materials[8], shapes[3]),
|
||||||
|
std::make_shared<Entity>(materials[8], shapes[3]),
|
||||||
|
std::make_shared<Entity>(materials[8], shapes[3]),
|
||||||
|
std::make_shared<Entity>(materials[8], shapes[3]),
|
||||||
|
std::make_shared<Entity>(materials[8], shapes[3]),
|
||||||
|
std::make_shared<Entity>(materials[8], shapes[3]),
|
||||||
|
std::make_shared<Entity>(materials[8], shapes[3]),
|
||||||
|
std::make_shared<Entity>(materials[8], shapes[3]),
|
||||||
};
|
};
|
||||||
|
|
||||||
for (int i = 0; i < entities.size(); ++i)
|
for (int i = 0; i < entities.size() / 2; ++i)
|
||||||
{
|
{
|
||||||
entities[i]->GetTransform()->SetPosition((-(int)(entities.size() / 2) + i + 0.5f) * 2.5f, 0, 0);
|
entities[i]->GetTransform()->SetPosition((-(int)(entities.size() / 4) + i + 0.5f) * 2.5f, -1.5f, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
for (int i = entities.size() / 2; i < entities.size(); ++i)
|
||||||
|
{
|
||||||
|
entities[i]->GetTransform()->SetPosition((-(int)(entities.size() / 4) + (i - (int)entities.size() / 2) + 0.5f) * 2.5f, 1.5f, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
skybox = std::make_shared<Sky>(
|
skybox = std::make_shared<Sky>(
|
||||||
|
|
1
Game.h
1
Game.h
|
@ -49,6 +49,7 @@ private:
|
||||||
std::shared_ptr<SimpleVertexShader> vertexShader;
|
std::shared_ptr<SimpleVertexShader> vertexShader;
|
||||||
std::shared_ptr<SimplePixelShader> pixelShaderPBR;
|
std::shared_ptr<SimplePixelShader> pixelShaderPBR;
|
||||||
std::shared_ptr<SimpleVertexShader> vertexShaderPBR;
|
std::shared_ptr<SimpleVertexShader> vertexShaderPBR;
|
||||||
|
std::shared_ptr<SimplePixelShader> pixelShaderToon;
|
||||||
|
|
||||||
// A2 shapes
|
// A2 shapes
|
||||||
std::vector<std::shared_ptr<Mesh>> shapes;
|
std::vector<std::shared_ptr<Mesh>> shapes;
|
||||||
|
|
37
ToonShader.hlsl
Normal file
37
ToonShader.hlsl
Normal file
|
@ -0,0 +1,37 @@
|
||||||
|
#include "Defines.hlsli"
|
||||||
|
#include "Helpers.hlsli"
|
||||||
|
#include "Lights.hlsli"
|
||||||
|
|
||||||
|
#define MAX_LIGHTS 128
|
||||||
|
|
||||||
|
cbuffer ExternalData : register(b0)
|
||||||
|
{
|
||||||
|
float3 cameraPosition;
|
||||||
|
float roughness;
|
||||||
|
|
||||||
|
float2 offset;
|
||||||
|
float2 scale;
|
||||||
|
|
||||||
|
float3 ambient;
|
||||||
|
float emitAmount;
|
||||||
|
|
||||||
|
float3 tint;
|
||||||
|
float lightCount;
|
||||||
|
|
||||||
|
int hasEmissiveMap;
|
||||||
|
int hasSpecularMap;
|
||||||
|
int hasNormalMap;
|
||||||
|
|
||||||
|
Light lights[MAX_LIGHTS];
|
||||||
|
}
|
||||||
|
|
||||||
|
Texture2D Albedo : register(t0);
|
||||||
|
Texture2D Specular : register(t1);
|
||||||
|
Texture2D Emissive : register(t2);
|
||||||
|
Texture2D Normal : register(t3);
|
||||||
|
SamplerState BasicSampler : register(s0);
|
||||||
|
|
||||||
|
float4 main(VertexToPixel input) : SV_TARGET
|
||||||
|
{
|
||||||
|
return float4(1.0f, 1.0f, 1.0f, 1.0f);
|
||||||
|
}
|
Reference in a new issue