forked from KhronosGroup/Vulkan-Samples
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathhdr.h
150 lines (132 loc) · 3.68 KB
/
hdr.h
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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
/* Copyright (c) 2019-2020, Sascha Willems
*
* SPDX-License-Identifier: Apache-2.0
*
* Licensed under the Apache License, Version 2.0 the "License";
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/*
* High dynamic range rendering
*/
#pragma once
#include "api_vulkan_sample.h"
class HDR : public ApiVulkanSample
{
public:
bool bloom = true;
bool display_skybox = true;
struct
{
Texture envmap;
} textures;
struct Models
{
std::unique_ptr<vkb::sg::SubMesh> skybox;
std::vector<std::unique_ptr<vkb::sg::SubMesh>> objects;
std::vector<glm::mat4> transforms;
int32_t object_index = 0;
} models;
struct
{
std::unique_ptr<vkb::core::Buffer> matrices;
std::unique_ptr<vkb::core::Buffer> params;
} uniform_buffers;
struct UBOVS
{
glm::mat4 projection;
glm::mat4 modelview;
glm::mat4 skybox_modelview;
float modelscale = 0.05f;
} ubo_vs;
struct UBOParams
{
float exposure = 1.0f;
} ubo_params;
struct
{
VkPipeline skybox;
VkPipeline reflect;
VkPipeline composition;
VkPipeline bloom[2];
} pipelines;
struct
{
VkPipelineLayout models;
VkPipelineLayout composition;
VkPipelineLayout bloom_filter;
} pipeline_layouts;
struct
{
VkDescriptorSet object;
VkDescriptorSet skybox;
VkDescriptorSet composition;
VkDescriptorSet bloom_filter;
} descriptor_sets;
struct
{
VkDescriptorSetLayout models;
VkDescriptorSetLayout composition;
VkDescriptorSetLayout bloom_filter;
} descriptor_set_layouts;
// Framebuffer for offscreen rendering
struct FrameBufferAttachment
{
VkImage image;
VkDeviceMemory mem;
VkImageView view;
VkFormat format;
void destroy(VkDevice device)
{
vkDestroyImageView(device, view, nullptr);
vkDestroyImage(device, image, nullptr);
vkFreeMemory(device, mem, nullptr);
}
};
struct FrameBuffer
{
int32_t width, height;
VkFramebuffer framebuffer;
FrameBufferAttachment color[2];
FrameBufferAttachment depth;
VkRenderPass render_pass;
VkSampler sampler;
} offscreen;
struct
{
int32_t width, height;
VkFramebuffer framebuffer;
FrameBufferAttachment color[1];
VkRenderPass render_pass;
VkSampler sampler;
} filter_pass;
std::vector<std::string> object_names;
HDR();
~HDR();
virtual void request_gpu_features(vkb::PhysicalDevice &gpu) override;
void build_command_buffers() override;
void create_attachment(VkFormat format, VkImageUsageFlagBits usage, FrameBufferAttachment *attachment);
void prepare_offscreen_buffer();
void load_assets();
void setup_descriptor_pool();
void setup_descriptor_set_layout();
void setup_descriptor_sets();
void prepare_pipelines();
void prepare_uniform_buffers();
void update_uniform_buffers();
void update_params();
void draw();
bool prepare(vkb::Platform &platform) override;
virtual void render(float delta_time) override;
virtual void on_update_ui_overlay(vkb::Drawer &drawer) override;
virtual void resize(const uint32_t width, const uint32_t height) override;
};
std::unique_ptr<vkb::Application> create_hdr();