1 #ifndef DALI_TOOLKIT_INTERNAL_BLUR_TWO_PASS_FILTER_H
2 #define DALI_TOOLKIT_INTERNAL_BLUR_TWO_PASS_FILTER_H
5 * Copyright (c) 2019 Samsung Electronics Co., Ltd.
7 * Licensed under the Apache License, Version 2.0 (the "License");
8 * you may not use this file except in compliance with the License.
9 * You may obtain a copy of the License at
11 * http://www.apache.org/licenses/LICENSE-2.0
13 * Unless required by applicable law or agreed to in writing, software
14 * distributed under the License is distributed on an "AS IS" BASIS,
15 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 * See the License for the specific language governing permissions and
17 * limitations under the License.
22 #include <dali/public-api/render-tasks/render-task.h>
25 #include "image-filter.h"
37 * A two pass blur filter, pass one performs a horizontal blur and pass two performs a
38 * vertical blur on the result of pass one.
40 class BlurTwoPassFilter : public ImageFilter
51 virtual ~BlurTwoPassFilter();
53 public: // From ImageFilter
54 /// @copydoc Dali::Toolkit::Internal::ImageFilter::Enable
55 virtual void Enable();
57 /// @copydoc Dali::Toolkit::Internal::ImageFilter::Disable
58 virtual void Disable();
60 /// @copydoc Dali::Toolkit::Internal::ImageFilter::Refresh
61 virtual void Refresh();
63 /// @copydoc Dali::Toolkit::Internal::ImageFilter::SetSize
64 virtual void SetSize( const Vector2& size );
67 * Get the property index that controls the strength of the blur applied to the image. Useful for animating this property.
68 * This property represents a value in the range [0.0 - 1.0] where 0.0 is no blur and 1.0 is full blur.
70 Property::Index GetBlurStrengthPropertyIndex() const {return mBlurStrengthPropertyIndex;}
73 * Retrieve the handle to the object in order to animate or constrain the blur strength property
74 * @return The hadnle to the object which blends the output image according to the blur strength
76 Handle GetHandleForAnimateBlurStrength();
81 * Setup render tasks for blur
83 void CreateRenderTasks();
86 BlurTwoPassFilter( const BlurTwoPassFilter& );
87 BlurTwoPassFilter& operator=( const BlurTwoPassFilter& );
89 private: // Attributes
91 // To perform horizontal blur from mInputTexture to mFrameBufferForHorz
92 RenderTask mRenderTaskForHorz;
94 FrameBuffer mFrameBufferForHorz;
96 // To perform vertical blur from mFrameBufferForHorz to mOutputFrameBuffer
97 RenderTask mRenderTaskForVert;
99 FrameBuffer mBlurredFrameBuffer;
101 // To blend the blurred image and input image according to the blur strength
102 RenderTask mRenderTaskForBlending;
103 Actor mActorForBlending;
104 Actor mRootActorForBlending;
105 Property::Index mBlurStrengthPropertyIndex;
107 }; // class BlurTwoPassFilter
109 } // namespace Internal
111 } // namespace Toolkit
115 #endif // DALI_TOOLKIT_INTERNAL_BLUR_TWO_PASS_FILTER_H