4#include <Crousti/GfxNode.hpp>
9template <
typename Node_T>
11 (avnd::texture_output_introspection<Node_T>::size + avnd::buffer_output_introspection<Node_T>::size + avnd::geometry_output_introspection<Node_T>::size) == 0
15 std::shared_ptr<Node_T> state;
17 ossia::time_value m_last_time{-1};
19 AVND_NO_UNIQUE_ADDRESS texture_inputs_storage<Node_T> texture_ins;
20 AVND_NO_UNIQUE_ADDRESS buffer_inputs_storage<Node_T> buffer_ins;
21 AVND_NO_UNIQUE_ADDRESS geometry_inputs_storage<Node_T> geometry_ins;
23 const GfxNode<Node_T>& node() const noexcept
25 return static_cast<const GfxNode<Node_T>&
>(score::gfx::NodeRenderer::node);
28 GfxRenderer(
const GfxNode<Node_T>& p)
29 :
score::gfx::OutputNodeRenderer{p}
30 , state{
std::make_shared<Node_T>()}
32 prepareNewState<Node_T>(state, p);
38 if constexpr(avnd::texture_input_introspection<Node_T>::size > 0)
40 auto it = texture_ins.m_rts.find(&p);
41 SCORE_ASSERT(it != texture_ins.m_rts.end());
49 auto& parent = node();
50 if constexpr(
requires { state->prepare(); })
52 this->node().processControlIn(
53 *
this, *state, m_last_message, this->node().last_message, this->node().m_ctx);
58 if constexpr(avnd::texture_input_introspection<Node_T>::size > 0)
59 texture_ins.init(*
this, renderer);
61 if_possible(state->init(renderer, res));
104 if_possible(state->update(renderer, res, e));
109 if constexpr(avnd::texture_input_introspection<Node_T>::size > 0)
110 texture_ins.release();
112 if constexpr(avnd::geometry_input_introspection<Node_T>::size > 0)
113 geometry_ins.release(r);
116 avnd::texture_input_introspection<Node_T>::size > 0
117 || avnd::texture_output_introspection<Node_T>::size > 0)
122 if_possible(state->release(r));
125 void inputAboutToFinish(
127 QRhiResourceUpdateBatch*& res)
override
130 avnd::texture_input_introspection<Node_T>::size > 0
131 || avnd::buffer_input_introspection<Node_T>::size > 0
132 || avnd::geometry_input_introspection<Node_T>::size > 0)
134 res = renderer.
state.rhi->nextResourceUpdateBatch();
136 if constexpr(avnd::texture_input_introspection<Node_T>::size > 0)
137 texture_ins.inputAboutToFinish(this->node(), p, res);
138 if constexpr(avnd::buffer_input_introspection<Node_T>::size > 0)
139 buffer_ins.inputAboutToFinish(renderer, res, *state, this->node());
140 if constexpr(avnd::geometry_input_introspection<Node_T>::size > 0)
141 geometry_ins.inputAboutToFinish(
142 renderer, res, this->geometry, *state, this->node());
145 if_possible(state->inputAboutToFinish(renderer, p, res));
148 void runInitialPasses(
152 auto& parent = this->node();
153 auto& rhi = *renderer.
state.rhi;
159 if(parent.last_message.token.date == m_last_time)
161 m_last_time = parent.last_message.token.date;
163 if constexpr(avnd::texture_input_introspection<Node_T>::size > 0)
164 texture_ins.runInitialPasses(*
this, rhi);
165 if constexpr(avnd::buffer_input_introspection<Node_T>::size > 0)
166 buffer_ins.readInputBuffers(renderer, parent, *state);
167 if constexpr(avnd::geometry_input_introspection<Node_T>::size > 0)
168 geometry_ins.readInputGeometries(renderer, this->geometry, parent, *state);
170 parent.processControlIn(
171 *
this, *state, m_last_message, parent.last_message, parent.m_ctx);
174 if_possible(state->runInitialPasses(renderer, commands, res, edge));
175 if_possible((*state)());
178 parent.processControlOut(*this->state);
182template <
typename Node_T>
184 (avnd::texture_output_introspection<Node_T>::size + avnd::buffer_output_introspection<Node_T>::size + avnd::geometry_output_introspection<Node_T>::size) == 0
186struct GfxNode<Node_T> final
187 : CustomGpuOutputNodeBase
188 , GpuNodeElements<Node_T>
193 std::weak_ptr<Execution::ExecutionCommandQueue> q, Gfx::exec_controls ctls,
195 : CustomGpuOutputNodeBase{
std::move(q),
std::move(ctls), ctx}
196 , processModel{element}
200 initGfxPorts<Node_T>(
this, this->input, this->output);
206 return new GfxRenderer<Node_T>{*
this};
Definition score-plugin-avnd/Crousti/ProcessModel.hpp:86
Definition OutputNode.hpp:11
List of nodes to be rendered to an output.
Definition RenderList.hpp:19
RenderState & state
RenderState corresponding to this RenderList.
Definition RenderList.hpp:94
Definition Factories.hpp:19
Base toolkit upon which the software is built.
Definition Application.cpp:99
Definition DocumentContext.hpp:18
Connection between two score::gfx::Port.
Definition score-plugin-gfx/Gfx/Graph/Utils.hpp:71
Definition score-plugin-gfx/Gfx/Graph/Node.hpp:46
Port of a score::gfx::Node.
Definition score-plugin-gfx/Gfx/Graph/Utils.hpp:53
Useful abstraction for storing all the data related to a render target.
Definition score-plugin-gfx/Gfx/Graph/Utils.hpp:116