Merge branch 'devel/master' into devel/new_mesh
[platform/core/uifw/dali-toolkit.git] / dali-toolkit / internal / atlas-manager / atlas-manager-impl.h
1 #ifndef __DALI_TOOLKIT_ATLAS_MANAGER_IMPL_H__
2 #define __DALI_TOOLKIT_ATLAS_MANAGER_IMPL_H__
3
4 /*
5  * Copyright (c) 2015 Samsung Electronics Co., Ltd.
6  *
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
10  *
11  * http://www.apache.org/licenses/LICENSE-2.0
12  *
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.
18  */
19
20
21 // EXTERNAL INCLUDES
22 #include <dali/public-api/common/vector-wrapper.h>
23 #include <dali/public-api/object/base-object.h>
24
25 // INTERNAL INCLUDES
26 #include <dali-toolkit/internal/atlas-manager/atlas-manager.h>
27
28 namespace Dali
29 {
30
31 namespace Toolkit
32 {
33
34 class AtlasManager;
35
36 } // namespace Toolkit
37
38 namespace Toolkit
39 {
40
41 namespace Internal
42 {
43
44 typedef Dali::Vector< Toolkit::AtlasManager::AtlasSlot > slotContainer;
45
46 class AtlasManager;
47 typedef IntrusivePtr<AtlasManager> AtlasManagerPtr;
48
49 class AtlasManager : public Dali::BaseObject, public ConnectionTracker
50 {
51 public:
52
53   typedef uint32_t SizeType;
54   typedef SizeType AtlasId;
55   typedef SizeType ImageId;
56
57   /**
58    * @brief Internal storage of atlas attributes and image upload results
59    */
60   struct AtlasDescriptor
61   {
62     Dali::Atlas mAtlas;                                                 // atlas image
63     Toolkit::AtlasManager::AtlasSize mSize;                             // size of atlas
64     Pixel::Format mPixelFormat;                                         // pixel format used by atlas
65     BufferImage mHorizontalStrip;                                       // Image used to pad upload
66     BufferImage mVerticalStrip;                                         // Image used to pad upload
67     BufferImage mFilledPixelImage;                                      // Image used by atlas for operations such as underline
68     PixelBuffer* mStripBuffer;                                          // Blank image buffer used to pad upload
69     Material mMaterial;                                                 // material used for atlas texture
70     Sampler mSampler;                                                   // sampler used for atlas texture
71     SizeType mNextFreeBlock;                                            // next free block will be placed here ( actually +1 )
72     Dali::Vector< SizeType > mFreeBlocksList;                           // unless there are any previously freed blocks
73   };
74
75   struct AtlasSlotDescriptor
76   {
77     SizeType mCount;                                                    // Reference count for this slot
78     SizeType mImageWidth;                                               // Width of image stored
79     SizeType mImageHeight;                                              // Height of image stored
80     AtlasId mAtlasId;                                                   // Image is stored in this Atlas
81     Dali::Vector< SizeType > mBlocksList;                               // List of blocks within atlas used for image
82   };
83
84   AtlasManager();
85
86   /**
87    * Create a new AtlasManager
88    */
89   static AtlasManagerPtr New();
90
91   virtual ~AtlasManager();
92
93   /**
94    * @copydoc: Toolkit::AtlasManager::CreateAtlas
95    */
96   AtlasId CreateAtlas( const Toolkit::AtlasManager::AtlasSize& size, Pixel::Format pixelformat );
97
98   /**
99    * @copydoc Toolkit::AtlasManager::SetAddPolicy
100    */
101   void SetAddPolicy( Toolkit::AtlasManager::AddFailPolicy policy );
102
103   /**
104    * @copydoc Toolkit::AtlasManager::Add
105    */
106   void Add( const BufferImage& image,
107             Toolkit::AtlasManager::AtlasSlot& slot,
108             Toolkit::AtlasManager::AtlasId atlas );
109
110   /**
111    * @copydoc Toolkit::AtlasManager::GenerateMeshData
112    */
113   void GenerateMeshData( ImageId id,
114                          const Vector2& position,
115                          Toolkit::AtlasManager::Mesh2D& mesh,
116                          bool addReference );
117
118   /**
119    * @copydoc Toolkit::AtlasManager::StitchMesh
120    */
121   void StitchMesh( Toolkit::AtlasManager::Mesh2D& first,
122                    const Toolkit::AtlasManager::Mesh2D& second,
123                    bool optimize );
124
125   /**
126    * @copydoc Toolkit::AtlasManager::StitchMesh
127    */
128   void StitchMesh(  const Toolkit::AtlasManager::Mesh2D& first,
129                     const Toolkit::AtlasManager::Mesh2D& second,
130                     Toolkit::AtlasManager::Mesh2D& out,
131                     bool optimize );
132
133   /**
134    * @copydoc Toolkit::AtlasManager::Remove
135    */
136   bool Remove( ImageId id );
137
138   /**
139    * @copydoc Toolkit::AtlasManager::GetAtlasContainer
140    */
141   Dali::Atlas GetAtlasContainer( AtlasId atlas ) const;
142
143   /**
144    * @copydoc Toolkit::AtlasManager::GetAtlas
145    */
146   AtlasId GetAtlas( ImageId id ) const;
147
148   /**
149    * @copydoc Toolkit::AtlasManager::SetNewAtlasSize
150    */
151   void SetNewAtlasSize( const Toolkit::AtlasManager::AtlasSize& size );
152
153   /**
154    * @copydoc Toolkit::AtlasManager::GetAtlasSize
155    */
156   const Toolkit::AtlasManager::AtlasSize& GetAtlasSize( AtlasId atlas );
157
158   /**
159    * @copydoc Toolkit::AtlasManager::GetBlockSize
160    */
161   Vector2 GetBlockSize( AtlasId atlas );
162
163   /**
164    * @copydoc Toolkit::AtlasManager::GetFreeBlocks
165    */
166   SizeType GetFreeBlocks( AtlasId atlas ) const;
167
168   /*
169    * @copydoc Toolkit::AtlasManager::GetAtlasCount
170    */
171   SizeType GetAtlasCount() const;
172
173   /**
174    * @copydoc Toolkit::AtlasManager::GetPixelFormat
175    */
176   Pixel::Format GetPixelFormat( AtlasId atlas );
177
178   /**
179    * @copydoc Toolkit::AtlasManager::GetMetrics
180    */
181   void GetMetrics( Toolkit::AtlasManager::Metrics& metrics );
182
183   /**
184    * @copydoc Toolkit::AtlasManager::GetMaterial
185    */
186   Material GetMaterial( AtlasId atlas ) const;
187
188 /**
189    * @copydoc Toolkit::AtlasManager::GetSampler
190    */
191   Sampler GetSampler( AtlasId atlas ) const;
192
193 private:
194
195   std::vector< AtlasDescriptor > mAtlasList;            // List of atlases created
196   std::vector< AtlasSlotDescriptor > mImageList;        // List of bitmaps store in atlases
197   Vector< PixelBuffer* > mUploadedImages;               // List of PixelBuffers passed to UploadedSignal
198   Toolkit::AtlasManager::AtlasSize mNewAtlasSize;       // Atlas size to use in next creation
199   Toolkit::AtlasManager::AddFailPolicy mAddFailPolicy;  // Policy for faling to add an Image
200   SizeType mFilledPixel;                                // 32Bit pixel image for underlining
201
202   SizeType CheckAtlas( SizeType atlas,
203                        SizeType width,
204                        SizeType height,
205                        Pixel::Format pixelFormat,
206                        SizeType& blockArea,
207                        SizeType& totalBlocks );
208
209   void CreateMesh( SizeType atlas,
210                    SizeType imageWidth,
211                    SizeType imageHeight,
212                    const Vector2& position,
213                    SizeType widthInBlocks,
214                    SizeType heightInBlocks,
215                    Toolkit::AtlasManager::Mesh2D& mesh,
216                    AtlasSlotDescriptor& desc );
217
218   void OptimizeMesh( const Toolkit::AtlasManager::Mesh2D& in,
219                      Toolkit::AtlasManager::Mesh2D& out );
220
221   void UploadImage( const BufferImage& image,
222                     const AtlasSlotDescriptor& desc );
223
224   void PrintMeshData( const Toolkit::AtlasManager::Mesh2D& mesh );
225
226   void OnUpload( Image image );
227
228   Shader mShaderL8;
229   Shader mShaderRgba;
230
231 };
232
233 } // namespace Internal
234
235 inline const Internal::AtlasManager& GetImplementation(const Toolkit::AtlasManager& manager)
236 {
237   DALI_ASSERT_ALWAYS( manager && "AtlasManager handle is empty" );
238
239   const BaseObject& handle = manager.GetBaseObject();
240
241   return static_cast<const Internal::AtlasManager&>(handle);
242 }
243
244 inline Internal::AtlasManager& GetImplementation(Toolkit::AtlasManager& manager)
245 {
246   DALI_ASSERT_ALWAYS( manager && "AtlasManager handle is empty" );
247
248   BaseObject& handle = manager.GetBaseObject();
249
250   return static_cast<Internal::AtlasManager&>(handle);
251 }
252
253 } // namespace Toolkit
254
255 } // namespace Dali
256
257
258  #endif // __DALI_TOOLKIT_ATLAS_MANAGER_IMPL_H__