1 #ifndef DALI_GRAPHICS_GLES_RENDER_TARGET_H
2 #define DALI_GRAPHICS_GLES_RENDER_TARGET_H
5 * Copyright (c) 2021 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/graphics-api/graphics-render-target-create-info.h>
23 #include <dali/graphics-api/graphics-render-target.h>
26 #include "gles-graphics-resource.h"
28 namespace Dali::Graphics::GLES
31 using RenderTargetResource = Resource<Graphics::RenderTarget, Graphics::RenderTargetCreateInfo>;
33 class RenderTarget : public RenderTargetResource
38 * @param[in] createInfo Valid createInfo structure
39 * @param[in] controller Reference to the controller
41 RenderTarget(const Graphics::RenderTargetCreateInfo& createInfo, Graphics::EglGraphicsController& controller);
46 ~RenderTarget() override;
49 * @brief Called when GL resources are destroyed
51 void DestroyResource() override;
54 * @brief Called when initializing the resource
56 * @return True on success
58 bool InitializeResource() override
60 // There is no graphic resource here. return true.
65 * @brief Called when UniquePtr<> on client-side dies
67 void DiscardResource() override;
70 * @brief Returns framebuffer associated with the render target
72 GLES::Framebuffer* GetFramebuffer() const;
75 * @brief Returns surface associated with the render target
77 Surface* GetSurface() const;
80 } // namespace Dali::Graphics::GLES