finish transparency work
This commit is contained in:
parent
bc53755242
commit
b07b4fbda0
2 changed files with 48 additions and 10 deletions
55
Game.cpp
55
Game.cpp
|
@ -2,6 +2,7 @@
|
||||||
#include "Vertex.h"
|
#include "Vertex.h"
|
||||||
#include "Input.h"
|
#include "Input.h"
|
||||||
#include "SimpleShader.h"
|
#include "SimpleShader.h"
|
||||||
|
#include <algorithm>
|
||||||
|
|
||||||
// Needed for a helper function to read compiled shader files from the hard drive
|
// Needed for a helper function to read compiled shader files from the hard drive
|
||||||
#pragma comment(lib, "d3dcompiler.lib")
|
#pragma comment(lib, "d3dcompiler.lib")
|
||||||
|
@ -90,7 +91,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>(false, white, 0, vertexShader, pixelShader),
|
std::make_shared<Material>(false, white, 0, vertexShader, pixelShader),
|
||||||
std::make_shared<Material>(true, white, 0, vertexShader, pixelShaderToon),
|
std::make_shared<Material>(false, white, 0, vertexShader, pixelShaderToon),
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -118,6 +119,11 @@ void Game::LoadTextures()
|
||||||
blendDesc.RenderTarget[0].SrcBlendAlpha = D3D11_BLEND_SRC_ALPHA;
|
blendDesc.RenderTarget[0].SrcBlendAlpha = D3D11_BLEND_SRC_ALPHA;
|
||||||
blendDesc.RenderTarget[0].DestBlendAlpha = D3D11_BLEND_INV_SRC_ALPHA;
|
blendDesc.RenderTarget[0].DestBlendAlpha = D3D11_BLEND_INV_SRC_ALPHA;
|
||||||
device->CreateBlendState(&blendDesc, alphaBlendState.GetAddressOf());
|
device->CreateBlendState(&blendDesc, alphaBlendState.GetAddressOf());
|
||||||
|
D3D11_RASTERIZER_DESC rastDesc = {};
|
||||||
|
rastDesc.DepthClipEnable = true;
|
||||||
|
rastDesc.CullMode = D3D11_CULL_FRONT;
|
||||||
|
rastDesc.FillMode = D3D11_FILL_SOLID;
|
||||||
|
device->CreateRasterizerState(&rastDesc, backfaceRasterState.GetAddressOf());
|
||||||
|
|
||||||
demoCubemap = CreateCubemap(
|
demoCubemap = CreateCubemap(
|
||||||
device,
|
device,
|
||||||
|
@ -180,8 +186,6 @@ void Game::LoadTextures()
|
||||||
materials[7]->LoadTexture(L"Assets/Textures/PBR/wood_normals.png", TEXTYPE_NORMAL, device.Get(), context.Get());
|
materials[7]->LoadTexture(L"Assets/Textures/PBR/wood_normals.png", TEXTYPE_NORMAL, device.Get(), context.Get());
|
||||||
|
|
||||||
materials[8]->PushSampler("BasicSampler", sampler);
|
materials[8]->PushSampler("BasicSampler", sampler);
|
||||||
materials[8]->PushTexture(TEXTYPE_REFLECTION, demoCubemap);
|
|
||||||
materials[8]->hasReflectionMap = true;
|
|
||||||
materials[8]->LoadTexture(L"Assets/Textures/HQGame/structure-endgame-floor_albedo.png", TEXTYPE_ALBEDO, device.Get(), context.Get());
|
materials[8]->LoadTexture(L"Assets/Textures/HQGame/structure-endgame-floor_albedo.png", TEXTYPE_ALBEDO, device.Get(), context.Get());
|
||||||
materials[8]->LoadTexture(L"Assets/Textures/HQGame/structure-endgame-floor_specular.png", TEXTYPE_SPECULAR, device.Get(), context.Get());
|
materials[8]->LoadTexture(L"Assets/Textures/HQGame/structure-endgame-floor_specular.png", TEXTYPE_SPECULAR, device.Get(), context.Get());
|
||||||
}
|
}
|
||||||
|
@ -243,11 +247,17 @@ void Game::CreateBasicGeometry()
|
||||||
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[9], shapes[3]),
|
||||||
std::make_shared<Entity>(materials[8], shapes[3]),
|
std::make_shared<Entity>(materials[9], shapes[3]),
|
||||||
std::make_shared<Entity>(materials[8], shapes[3]),
|
std::make_shared<Entity>(materials[9], shapes[3]),
|
||||||
std::make_shared<Entity>(materials[8], shapes[3]),
|
std::make_shared<Entity>(materials[9], shapes[3]),
|
||||||
std::make_shared<Entity>(materials[8], shapes[3]),
|
std::make_shared<Entity>(materials[9], shapes[3]),
|
||||||
|
std::make_shared<Entity>(materials[9], shapes[3]),
|
||||||
|
std::make_shared<Entity>(materials[9], shapes[3]),
|
||||||
|
std::make_shared<Entity>(materials[9], shapes[3]),
|
||||||
|
};
|
||||||
|
|
||||||
|
transpEntities = {
|
||||||
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]),
|
||||||
|
@ -263,6 +273,11 @@ void Game::CreateBasicGeometry()
|
||||||
entities[i]->GetTransform()->SetPosition((-(int)(entities.size() / 4) + (i - (int)entities.size() / 2) + 0.5f) * 2.5f, 1.5f, 0);
|
entities[i]->GetTransform()->SetPosition((-(int)(entities.size() / 4) + (i - (int)entities.size() / 2) + 0.5f) * 2.5f, 1.5f, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
for (int i = 0; i < transpEntities.size(); ++i)
|
||||||
|
{
|
||||||
|
transpEntities[i]->GetTransform()->SetPosition(0, -3.5f, (-(int)(transpEntities.size() / 2) + i) * 2.5f);
|
||||||
|
}
|
||||||
|
|
||||||
skybox = std::make_shared<Sky>(
|
skybox = std::make_shared<Sky>(
|
||||||
shapes[0],
|
shapes[0],
|
||||||
std::make_shared<SimpleVertexShader>(device, context, GetFullPathTo_Wide(L"SkyboxVertexShader.cso").c_str()),
|
std::make_shared<SimpleVertexShader>(device, context, GetFullPathTo_Wide(L"SkyboxVertexShader.cso").c_str()),
|
||||||
|
@ -321,15 +336,35 @@ void Game::Draw(float deltaTime, float totalTime)
|
||||||
1.0f,
|
1.0f,
|
||||||
0);
|
0);
|
||||||
|
|
||||||
context->OMSetBlendState(alphaBlendState.Get(), 0, 0xFFFFFFFF);
|
|
||||||
|
|
||||||
for (auto entity : entities)
|
for (auto entity : entities)
|
||||||
{
|
{
|
||||||
entity->Draw(camera, ambient, lights);
|
entity->Draw(camera, ambient, lights);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
std::sort(transpEntities.begin(), transpEntities.end(), [&](std::shared_ptr<Entity> a, std::shared_ptr<Entity> b) -> bool
|
||||||
|
{
|
||||||
|
XMFLOAT3 positionA = a->GetTransform()->GetPosition();
|
||||||
|
XMFLOAT3 positionB = b->GetTransform()->GetPosition();
|
||||||
|
XMFLOAT3 camPos = camera->GetTransform()->GetPosition();
|
||||||
|
|
||||||
|
// compare distance
|
||||||
|
float aDist = XMVectorGetX(XMVector3Length(XMLoadFloat3(&positionA) - XMLoadFloat3(&camPos)));
|
||||||
|
float bDist = XMVectorGetX(XMVector3Length(XMLoadFloat3(&positionB) - XMLoadFloat3(&camPos)));
|
||||||
|
return aDist > bDist;
|
||||||
|
});
|
||||||
|
|
||||||
skybox->Draw(context, camera);
|
skybox->Draw(context, camera);
|
||||||
|
|
||||||
|
context->OMSetBlendState(alphaBlendState.Get(), 0, 0xFFFFFFFF);
|
||||||
|
for (auto entity : transpEntities)
|
||||||
|
{
|
||||||
|
context->RSSetState(backfaceRasterState.Get());
|
||||||
|
entity->Draw(camera, ambient, lights);
|
||||||
|
context->RSSetState(0);
|
||||||
|
entity->Draw(camera, ambient, lights);
|
||||||
|
}
|
||||||
|
context->OMSetBlendState(0, 0, 0xFFFFFFFF);
|
||||||
|
|
||||||
// Present the back buffer to the user
|
// Present the back buffer to the user
|
||||||
// - Puts the final frame we're drawing into the window so the user can see it
|
// - Puts the final frame we're drawing into the window so the user can see it
|
||||||
// - Do this exactly ONCE PER FRAME (always at the very end of the frame)
|
// - Do this exactly ONCE PER FRAME (always at the very end of the frame)
|
||||||
|
|
3
Game.h
3
Game.h
|
@ -67,7 +67,10 @@ private:
|
||||||
Microsoft::WRL::ComPtr<ID3D11SamplerState> sampler;
|
Microsoft::WRL::ComPtr<ID3D11SamplerState> sampler;
|
||||||
Microsoft::WRL::ComPtr<ID3D11ShaderResourceView> demoCubemap;
|
Microsoft::WRL::ComPtr<ID3D11ShaderResourceView> demoCubemap;
|
||||||
|
|
||||||
|
std::vector<std::shared_ptr<Entity>> transpEntities;
|
||||||
|
|
||||||
Microsoft::WRL::ComPtr<ID3D11Buffer> constantBufferVS;
|
Microsoft::WRL::ComPtr<ID3D11Buffer> constantBufferVS;
|
||||||
Microsoft::WRL::ComPtr<ID3D11BlendState> alphaBlendState;
|
Microsoft::WRL::ComPtr<ID3D11BlendState> alphaBlendState;
|
||||||
|
Microsoft::WRL::ComPtr<ID3D11RasterizerState> backfaceRasterState;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
Reference in a new issue