summaryrefslogtreecommitdiff
path: root/src/gpu/effects/circle_mask_effect.cc
diff options
context:
space:
mode:
Diffstat (limited to 'src/gpu/effects/circle_mask_effect.cc')
-rw-r--r--src/gpu/effects/circle_mask_effect.cc14
1 files changed, 4 insertions, 10 deletions
diff --git a/src/gpu/effects/circle_mask_effect.cc b/src/gpu/effects/circle_mask_effect.cc
index 08a9e33..f34ffb7 100644
--- a/src/gpu/effects/circle_mask_effect.cc
+++ b/src/gpu/effects/circle_mask_effect.cc
@@ -26,6 +26,9 @@ CircleMaskEffect::~CircleMaskEffect() {
void CircleMaskEffect::init(MainSequence* demo) {
demo_ = demo;
+ // Register auxiliary texture (width_/height_ set by resize() before init())
+ demo_->register_auxiliary_texture("circle_mask", width_, height_);
+
compute_params_.init(ctx_.device);
// Initialize uniforms BEFORE bind group creation
@@ -152,20 +155,13 @@ void CircleMaskEffect::init(MainSequence* demo) {
render_bind_group_ = wgpuDeviceCreateBindGroup(ctx_.device, &render_bg_desc);
}
-void CircleMaskEffect::ensure_texture() {
- if (!texture_initialized_ && demo_) {
- demo_->register_auxiliary_texture("circle_mask", width_, height_);
- texture_initialized_ = true;
- }
-}
-
void CircleMaskEffect::resize(int width, int height) {
if (width == width_ && height == height_)
return;
Effect::resize(width, height);
- if (!demo_ || !texture_initialized_)
+ if (!demo_)
return;
// Resize auxiliary texture
@@ -193,8 +189,6 @@ void CircleMaskEffect::resize(int width, int height) {
void CircleMaskEffect::compute(WGPUCommandEncoder encoder,
const CommonPostProcessUniforms& uniforms) {
- ensure_texture();
-
uniforms_.update(ctx_.queue, uniforms);
const CircleMaskParams params = {