Содержание
DirectXTK | PostProcess |
---|
Performs basic post-processing with a built-in set of shaders which operate using two input textures.
Header
#include "PostProcess.h"
Initialization
Construction requires a Direct3D 11 device.
std::unique_ptr<DualPostProcess> postProcess;
postProcess = std::make_unique<DualPostProcess>(device);
For exception safety, it is recommended you make use of the C++ RAII pattern and use a std::unique_ptr
or std::shared_ptr
Shader selection
DualPostProcess can be configured to use various pixel shaders by calling SetEffect
:
- Merge: Combines two images using provided weights.
- BloomCombine: Combines the bloom texture produced by BasicPostProcess in a final pass with the original scene texture.
Properties
-
SetSourceTexture
,SetSourceTexture2
is used to set the input texture as a Shader Resource View. -
SetMergeParameters
is used to set the two weights for the Merge shader. Setting these to 0.5,0.5 will blend two images, while setting them both to 1.0 will add the two images together. -
SetBloomCombineParameters
sets the various parameters for the BloomCombine shader as the final pass of implementing a bloom effect.
Example
A simple use of the Merge effect would be to dissolve between two textures (either or both of which could be render textures):
// texture1SRV is the first image
// texture2SRV is the second image
dualPostProcess->SetEffect(DualPostProcess::Merge);
dualPostProcess->SetSourceTexture(texture1SRV.Get());
dualPostProcess->SetSourceTexture2(texture2SRV.Get());
// Smoothly animate the value t from 0.0 to 1.0 over the time you want the dissolve to take.
dualPostProcess->SetMergeParameters(t, 1.f - t);
dualPostProcess->Process(context);
For Use
- Universal Windows Platform apps
- Windows desktop apps
- Windows 11
- Windows 10
- Windows 8.1
- Windows 7 Service Pack 1
- Xbox One
Architecture
- x86
- x64
- ARM64
For Development
- Visual Studio 2022
- Visual Studio 2019 (16.11)
- clang/LLVM v12 - v18
- MinGW 12.2, 13.2
- CMake 3.20
Related Projects
DirectX Tool Kit for DirectX 12
Tools
All content and source code for this package are subject to the terms of the MIT License.
This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact opencode@microsoft.com with any additional questions or comments.