1 #ifndef DALI_INTERNAL_NATIVE_IMAGE_SOURCE_H
2 #define DALI_INTERNAL_NATIVE_IMAGE_SOURCE_H
5 * Copyright (c) 2023 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/internal/system/linux/dali-ecore-x.h>
26 #include <dali/internal/imaging/common/native-image-source-impl.h>
27 #include <dali/public-api/adaptor-framework/native-image-source.h>
36 class EglImageExtensions;
39 * Dali internal NativeImageSource.
41 class NativeImageSourceX : public Internal::Adaptor::NativeImageSource
45 * Create a new NativeImageSource internally.
46 * Depending on hardware the width and height may have to be a power of two.
47 * @param[in] width The width of the image.
48 * @param[in] height The height of the image.
49 * @param[in] depth color depth of the image.
50 * @param[in] nativeImageSource contains either: pixmap of type X11 Pixmap , a Ecore_X_Pixmap or is empty
51 * @return A smart-pointer to a newly allocated image.
53 static NativeImageSourceX* New(uint32_t width,
55 Dali::NativeImageSource::ColorDepth depth,
56 Any nativeImageSource);
58 * @copydoc Dali::NativeImageSource::GetNativeImageSource()
60 Any GetNativeImageSource() const override;
63 * @copydoc Dali::NativeImageSource::GetPixels()
65 bool GetPixels(std::vector<uint8_t>& pixbuf, uint32_t& width, uint32_t& height, Pixel::Format& pixelFormat) const override;
68 * @copydoc Dali::NativeImageSource::SetSource( Any source )
70 void SetSource(Any source) override;
73 * @copydoc Dali::NativeImageSource::IsColorDepthSupported( ColorDepth colorDepth )
75 bool IsColorDepthSupported(Dali::NativeImageSource::ColorDepth colorDepth) override;
80 ~NativeImageSourceX() override;
83 * @copydoc Dali::NativeImageSource::CreateResource()
85 bool CreateResource() override;
88 * @copydoc Dali::NativeImageSource::DestroyResource()
90 void DestroyResource() override;
93 * @copydoc Dali::NativeImageSource::TargetTexture()
95 uint32_t TargetTexture() override;
98 * @copydoc Dali::NativeImageSource::PrepareTexture()
100 void PrepareTexture() override;
103 * @copydoc Dali::NativeImageSource::GetWidth()
105 uint32_t GetWidth() const override
111 * @copydoc Dali::NativeImageSource::GetHeight()
113 uint32_t GetHeight() const override
119 * @copydoc Dali::NativeImageSource::RequiresBlending()
121 bool RequiresBlending() const override
123 return mBlendingRequired;
127 * @copydoc Dali::NativeImageSource::GetTextureTarget()
129 int GetTextureTarget() const override;
132 * @copydoc Dali::NativeImageSource::ApplyNativeFragmentShader()
134 bool ApplyNativeFragmentShader(std::string& shader) override;
137 * @copydoc Dali::NativeImageSource::GetCustomSamplerTypename()
139 const char* GetCustomSamplerTypename() const override;
142 * @copydoc Dali::NativeImageSource::GetNativeImageHandle()
144 Any GetNativeImageHandle() const override;
147 * @copydoc Dali::NativeImageSource::SourceChanged()
149 bool SourceChanged() const override;
152 * @copydoc Dali::NativeImageInterface::GetUpdatedArea()
154 Rect<uint32_t> GetUpdatedArea() override
156 return Rect<uint32_t>{0, 0, mWidth, mHeight};
160 * @copydoc Dali::NativeImageInterface::GetExtension()
162 NativeImageInterface::Extension* GetNativeImageInterfaceExtension() override
168 * @copydoc Dali::Internal::Adaptor::NativeImageSource::AcquireBuffer()
170 uint8_t* AcquireBuffer(uint32_t& width, uint32_t& height, uint32_t& stride) override;
173 * @copydoc Dali::Internal::Adaptor::NativeImageSource::ReleaseBuffer()
175 bool ReleaseBuffer(const Rect<uint32_t>& updatedArea) override;
178 * @copydoc Dali::NativeImageSource::SetResourceDestructionCallback()
180 void SetResourceDestructionCallback(EventThreadCallback* callback) override;
183 * @copydoc Dali::DevelNativeImageSource::EnableBackBuffer()
185 void EnableBackBuffer(bool enable) override;
189 * Private constructor; @see NativeImageSource::New()
190 * @param[in] width The width of the image.
191 * @param[in] height The height of the image.
192 * @param[in] colour depth of the image.
193 * @param[in] nativeImageSource contains either: pixmap of type X11 Pixmap , a Ecore_X_Pixmap or is empty
195 NativeImageSourceX(uint32_t width,
197 Dali::NativeImageSource::ColorDepth depth,
198 Any nativeImageSource);
201 * 2nd phase construction.
206 * Uses X11 to get the default depth.
207 * @param depth the PixelImage depth enum
208 * @return default x11 pixel depth
210 int GetPixelDepth(Dali::NativeImageSource::ColorDepth depth) const;
213 * Gets the pixmap from the Any parameter
214 * @param pixmap contains either: pixmap of type X11 Pixmap , a Ecore_X_Pixmap or is empty
215 * @return pixmap x11 pixmap
217 Ecore_X_Pixmap GetPixmapFromAny(Any pixmap) const;
220 * Given an existing pixmap, the function uses X to find out
221 * the width, heigth and depth of that pixmap.
223 void GetPixmapDetails();
226 uint32_t mWidth; ///< image width
227 uint32_t mHeight; ///< image heights
228 bool mOwnPixmap; ///< Whether we created pixmap or not
229 Ecore_X_Pixmap mPixmap; ///< From Xlib
230 bool mBlendingRequired; ///< Whether blending is required
231 Dali::NativeImageSource::ColorDepth mColorDepth; ///< color depth of image
232 void* mEglImageKHR; ///< From EGL extension
233 EglGraphics* mEglGraphics; ///< EGL Graphics
234 EglImageExtensions* mEglImageExtensions; ///< The EGL Image Extensions
235 std::unique_ptr<EventThreadCallback> mResourceDestructionCallback; ///< The Resource Destruction Callback
238 } // namespace Adaptor
240 } // namespace Internal
244 #endif // DALI_INTERNAL_NATIVE_IMAGE_SOURCE_H