1 #ifndef __DALI_INTERNAL_NATIVE_IMAGE_SOURCE_H__
2 #define __DALI_INTERNAL_NATIVE_IMAGE_SOURCE_H__
5 * Copyright (c) 2014 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 <tbm_surface.h>
23 #include <dali/devel-api/images/native-image-interface-extension.h>
26 #include <native-image-source.h>
36 class EglImageExtensions;
39 * Dali internal NativeImageSource.
41 class NativeImageSource: public NativeImageInterface::Extension
46 * Create a new NativeImageSource internally.
47 * Depending on hardware the width and height may have to be a power of two.
48 * @param[in] width The width of the image.
49 * @param[in] height The height of the image.
50 * @param[in] depth color depth of the image.
51 * @param[in] nativeImageSource contains either: pixmap of type X11 Pixmap , a Ecore_X_Pixmap or is empty
52 * @return A smart-pointer to a newly allocated image.
54 static NativeImageSource* New(unsigned int width,
56 Dali::NativeImageSource::ColorDepth depth,
57 Any nativeImageSource);
60 * @copydoc Dali::NativeImageSource::GetNativeImageSource()
62 Any GetNativeImageSource() const;
65 * @copydoc Dali::NativeImageSource::GetPixels()
67 bool GetPixels(std::vector<unsigned char> &pixbuf, unsigned int &width, unsigned int &height, Pixel::Format& pixelFormat ) const;
70 * @copydoc Dali::NativeImageSource::EncodeToFile(const std::string& )
72 bool EncodeToFile(const std::string& filename) const;
75 * @copydoc Dali::NativeImageSource::SetSource( Any source )
77 void SetSource( Any source );
85 * @copydoc Dali::NativeImageSource::GlExtensionCreate()
87 bool GlExtensionCreate();
90 * @copydoc Dali::NativeImageSource::GlExtensionDestroy()
92 void GlExtensionDestroy();
95 * @copydoc Dali::NativeImageSource::TargetTexture()
97 unsigned int TargetTexture();
100 * @copydoc Dali::NativeImageSource::GetWidth()
102 unsigned int GetWidth() const
108 * @copydoc Dali::NativeImageSource::GetHeight()
110 unsigned int GetHeight() const
116 * @copydoc Dali::NativeImageSource::RequiresBlending()
118 bool RequiresBlending() const
120 return mBlendingRequired;
124 * @copydoc Dali::NativeImageInterface::GetExtension()
126 NativeImageInterface::Extension* GetNativeImageInterfaceExtension()
132 * @copydoc Dali::NativeImageInterface::Extension::GetCustomFragmentPreFix()
134 const char* GetCustomFragmentPreFix();
137 * @copydoc Dali::NativeImageInterface::Extension::GetCustomSamplerTypename()
139 const char* GetCustomSamplerTypename();
144 * Private constructor; @see NativeImageSource::New()
145 * @param[in] width The width of the image.
146 * @param[in] height The height of the image.
147 * @param[in] colour depth of the image.
148 * @param[in] nativeImageSource contains either: pixmap of type X11 Pixmap , a Ecore_X_Pixmap or is empty
150 NativeImageSource(unsigned int width,
152 Dali::NativeImageSource::ColorDepth depth,
153 Any nativeImageSource);
157 int GetPixelDepth(Dali::NativeImageSource::ColorDepth depth) const;
159 tbm_surface_h GetSurfaceFromAny( Any source ) const;
163 unsigned int mWidth; ///< image width
164 unsigned int mHeight; ///< image heights
165 bool mOwnTbmsurface; ///< Whether we created pixmap or not
166 tbm_surface_h mTbmsurface;
167 bool mBlendingRequired; ///< Whether blending is required
168 Dali::NativeImageSource::ColorDepth mColorDepth; ///< color depth of image
169 void* mEglImageKHR; ///< From EGL extension
170 EglImageExtensions* mEglImageExtensions; ///< The EGL Image Extensions
173 } // namespace Adaptor
175 } // namespace Internal
179 #endif // __DALI_INTERNAL_NATIVE_IMAGE_SOURCE_H__