forked from DadSchoorse/vkBasalt
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy patheffect_fxaa.cpp
57 lines (47 loc) · 2.13 KB
/
effect_fxaa.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
#include "effect_fxaa.hpp"
#include <cstring>
#include "image_view.hpp"
#include "descriptor_set.hpp"
#include "buffer.hpp"
#include "renderpass.hpp"
#include "graphics_pipeline.hpp"
#include "framebuffer.hpp"
#include "shader.hpp"
#include "sampler.hpp"
#include "shader_sources.hpp"
namespace vkBasalt
{
FxaaEffect::FxaaEffect(LogicalDevice* pLogicalDevice,
VkFormat format,
VkExtent2D imageExtent,
std::vector<VkImage> inputImages,
std::vector<VkImage> outputImages,
Config* pConfig)
{
float fxaaQualitySubpix = pConfig->getOption<float>("fxaaQualitySubpix", 0.75f);
float fxaaQualityEdgeThreshold = pConfig->getOption<float>("fxaaQualityEdgeThreshold", 0.125f);
float fxaaQualityEdgeThresholdMin = pConfig->getOption<float>("fxaaQualityEdgeThresholdMin", 0.0312f);
vertexCode = full_screen_triangle_vert;
fragmentCode = fxaa_frag;
std::vector<VkSpecializationMapEntry> specMapEntrys(5);
for (uint32_t i = 0; i < specMapEntrys.size(); i++)
{
specMapEntrys[i].constantID = i;
specMapEntrys[i].offset = sizeof(float) * i;
specMapEntrys[i].size = sizeof(float);
}
std::vector<float> specData = {
fxaaQualitySubpix, fxaaQualityEdgeThreshold, fxaaQualityEdgeThresholdMin, (float) imageExtent.width, (float) imageExtent.height};
VkSpecializationInfo fragmentSpecializationInfo;
fragmentSpecializationInfo.mapEntryCount = specMapEntrys.size();
fragmentSpecializationInfo.pMapEntries = specMapEntrys.data();
fragmentSpecializationInfo.dataSize = sizeof(float) * specData.size();
fragmentSpecializationInfo.pData = specData.data();
pVertexSpecInfo = nullptr;
pFragmentSpecInfo = &fragmentSpecializationInfo;
init(pLogicalDevice, format, imageExtent, inputImages, outputImages, pConfig);
}
FxaaEffect::~FxaaEffect()
{
}
} // namespace vkBasalt