Merge branch 'devel/master' into tizen
[platform/core/uifw/dali-toolkit.git] / dali-toolkit / internal / visuals / svg / svg-task.cpp
1 /*
2  * Copyright (c) 2023 Samsung Electronics Co., Ltd.
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  * http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  *
16  */
17
18 // CLASS HEADER
19 #include "svg-task.h"
20
21 // EXTERNAL INCLUDES
22 #include <dali/devel-api/adaptor-framework/file-loader.h>
23 #include <dali/integration-api/adaptor-framework/adaptor.h>
24 #include <dali/integration-api/debug.h>
25 #include <dali/integration-api/trace.h>
26
27 // INTERNAL INCLUDES
28 #include <dali-toolkit/internal/visuals/svg/svg-visual.h>
29
30 #ifdef TRACE_ENABLED
31 #include <sstream>
32 #endif
33
34 namespace Dali
35 {
36 namespace Toolkit
37 {
38 namespace Internal
39 {
40 namespace
41 {
42 DALI_INIT_TRACE_FILTER(gTraceFilter, DALI_TRACE_IMAGE_PERFORMANCE_MARKER, false);
43 }
44
45 SvgTask::SvgTask(VectorImageRenderer vectorRenderer, CallbackBase* callback, AsyncTask::PriorityType priorityType)
46 : AsyncTask(callback, priorityType),
47   mVectorRenderer(vectorRenderer),
48   mHasSucceeded(false)
49 {
50 }
51
52 PixelData SvgTask::GetPixelData() const
53 {
54   return PixelData();
55 }
56
57 bool SvgTask::HasSucceeded() const
58 {
59   return mHasSucceeded;
60 }
61
62 VectorImageRenderer SvgTask::GetRenderer()
63 {
64   return mVectorRenderer;
65 }
66
67 SvgLoadingTask::SvgLoadingTask(VectorImageRenderer vectorRenderer, const VisualUrl& url, float dpi, CallbackBase* callback)
68 : SvgTask(vectorRenderer, callback, url.GetProtocolType() == VisualUrl::ProtocolType::REMOTE ? AsyncTask::PriorityType::LOW : AsyncTask::PriorityType::HIGH),
69   mImageUrl(url),
70   mDpi(dpi)
71 {
72 }
73
74 SvgLoadingTask::~SvgLoadingTask()
75 {
76 }
77
78 void SvgLoadingTask::Process()
79 {
80   if(mVectorRenderer.IsLoaded())
81   {
82     // Already loaded
83     mHasSucceeded = true;
84     return;
85   }
86
87 #ifdef TRACE_ENABLED
88   if(gTraceFilter && gTraceFilter->IsTraceEnabled())
89   {
90     std::ostringstream oss;
91     oss << "[url:" << mImageUrl.GetUrl() << "]";
92     DALI_TRACE_BEGIN_WITH_MESSAGE(gTraceFilter, "DALI_SVG_LOADING_TASK", oss.str().c_str());
93   }
94 #endif
95
96   bool loadFailed = false;
97
98   Dali::Vector<uint8_t> buffer;
99
100   if(!mImageUrl.IsLocalResource())
101   {
102     if(!Dali::FileLoader::DownloadFileSynchronously(mImageUrl.GetUrl(), buffer))
103     {
104       DALI_LOG_ERROR("Failed to download file! [%s]\n", mImageUrl.GetUrl().c_str());
105       loadFailed = true;
106     }
107   }
108   else
109   {
110     if(!Dali::FileLoader::ReadFile(mImageUrl.GetUrl(), buffer))
111     {
112       DALI_LOG_ERROR("Failed to read file! [%s]\n", mImageUrl.GetUrl().c_str());
113       loadFailed = true;
114     }
115   }
116
117   if(!loadFailed)
118   {
119     buffer.PushBack('\0');
120
121     if(!mVectorRenderer.Load(buffer, mDpi))
122     {
123       DALI_LOG_ERROR("Failed to load data! [%s]\n", mImageUrl.GetUrl().c_str());
124       loadFailed = true;
125     }
126   }
127
128   mHasSucceeded = !loadFailed;
129 #ifdef TRACE_ENABLED
130   if(gTraceFilter && gTraceFilter->IsTraceEnabled())
131   {
132     std::ostringstream oss;
133     oss << "[success:" << mHasSucceeded << " ";
134     oss << "url:" << mImageUrl.GetUrl() << "]";
135     DALI_TRACE_END_WITH_MESSAGE(gTraceFilter, "DALI_SVG_LOADING_TASK", oss.str().c_str());
136   }
137 #endif
138 }
139
140 bool SvgLoadingTask::IsReady()
141 {
142   return true;
143 }
144
145 SvgRasterizingTask::SvgRasterizingTask(VectorImageRenderer vectorRenderer, uint32_t width, uint32_t height, CallbackBase* callback)
146 : SvgTask(vectorRenderer, callback),
147   mWidth(width),
148   mHeight(height)
149 {
150 }
151
152 SvgRasterizingTask::~SvgRasterizingTask()
153 {
154 }
155
156 void SvgRasterizingTask::Process()
157 {
158   if(!mVectorRenderer.IsLoaded())
159   {
160     DALI_LOG_ERROR("File is not loaded!\n");
161     return;
162   }
163
164 #ifdef TRACE_ENABLED
165   if(gTraceFilter && gTraceFilter->IsTraceEnabled())
166   {
167     std::ostringstream oss;
168     oss << "[size:" << mWidth << "x" << mHeight << " ";
169     oss << "url:" << mImageUrl.GetUrl() << "]";
170     DALI_TRACE_BEGIN_WITH_MESSAGE(gTraceFilter, "DALI_SVG_RASTERIZE_TASK", oss.str().c_str());
171   }
172 #endif
173
174   Devel::PixelBuffer pixelBuffer = mVectorRenderer.Rasterize(mWidth, mHeight);
175   if(!pixelBuffer)
176   {
177     DALI_LOG_ERROR("Rasterize is failed!\n");
178 #ifdef TRACE_ENABLED
179     if(gTraceFilter && gTraceFilter->IsTraceEnabled())
180     {
181       std::ostringstream oss;
182       oss << "[size:" << mWidth << "x" << mHeight << " ";
183       oss << "url:" << mImageUrl.GetUrl() << "]";
184       DALI_TRACE_END_WITH_MESSAGE(gTraceFilter, "DALI_SVG_RASTERIZE_TASK", oss.str().c_str());
185     }
186 #endif
187     return;
188   }
189
190   mPixelData    = Devel::PixelBuffer::Convert(pixelBuffer);
191   mHasSucceeded = true;
192
193 #ifdef TRACE_ENABLED
194   if(gTraceFilter && gTraceFilter->IsTraceEnabled())
195   {
196     std::ostringstream oss;
197     oss << "[size:" << mWidth << "x" << mHeight << " ";
198     oss << "url:" << mImageUrl.GetUrl() << "]";
199     DALI_TRACE_END_WITH_MESSAGE(gTraceFilter, "DALI_SVG_RASTERIZE_TASK", oss.str().c_str());
200   }
201 #endif
202 }
203
204 bool SvgRasterizingTask::IsReady()
205 {
206   return mVectorRenderer.IsLoaded();
207 }
208
209 PixelData SvgRasterizingTask::GetPixelData() const
210 {
211   return mPixelData;
212 }
213
214 } // namespace Internal
215
216 } // namespace Toolkit
217
218 } // namespace Dali