Do not trace image decoding process
[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(gTraceFilter, "DALI_SVG_LOADING_TASK"); ///< TODO : Open it if we can control trace log level
93     DALI_LOG_RELEASE_INFO("BEGIN: DALI_SVG_LOADING_TASK %s", oss.str().c_str());
94   }
95 #endif
96
97   bool loadFailed = false;
98
99   Dali::Vector<uint8_t> buffer;
100
101   if(!mImageUrl.IsLocalResource())
102   {
103     if(!Dali::FileLoader::DownloadFileSynchronously(mImageUrl.GetUrl(), buffer))
104     {
105       DALI_LOG_ERROR("Failed to download file! [%s]\n", mImageUrl.GetUrl().c_str());
106       loadFailed = true;
107     }
108   }
109   else
110   {
111     if(!Dali::FileLoader::ReadFile(mImageUrl.GetUrl(), buffer))
112     {
113       DALI_LOG_ERROR("Failed to read file! [%s]\n", mImageUrl.GetUrl().c_str());
114       loadFailed = true;
115     }
116   }
117
118   if(!loadFailed)
119   {
120     buffer.PushBack('\0');
121
122     if(!mVectorRenderer.Load(buffer, mDpi))
123     {
124       DALI_LOG_ERROR("Failed to load data! [%s]\n", mImageUrl.GetUrl().c_str());
125       loadFailed = true;
126     }
127   }
128
129   mHasSucceeded = !loadFailed;
130 #ifdef TRACE_ENABLED
131   if(gTraceFilter && gTraceFilter->IsTraceEnabled())
132   {
133     std::ostringstream oss;
134     oss << "[success:" << mHasSucceeded << " ";
135     oss << "url:" << mImageUrl.GetUrl() << "]";
136     // DALI_TRACE_END(gTraceFilter, "DALI_SVG_LOADING_TASK"); ///< TODO : Open it if we can control trace log level
137     DALI_LOG_RELEASE_INFO("END: DALI_SVG_LOADING_TASK %s", oss.str().c_str());
138   }
139 #endif
140 }
141
142 bool SvgLoadingTask::IsReady()
143 {
144   return true;
145 }
146
147 SvgRasterizingTask::SvgRasterizingTask(VectorImageRenderer vectorRenderer, uint32_t width, uint32_t height, CallbackBase* callback)
148 : SvgTask(vectorRenderer, callback),
149   mWidth(width),
150   mHeight(height)
151 {
152 }
153
154 SvgRasterizingTask::~SvgRasterizingTask()
155 {
156 }
157
158 void SvgRasterizingTask::Process()
159 {
160   if(!mVectorRenderer.IsLoaded())
161   {
162     DALI_LOG_ERROR("File is not loaded!\n");
163     return;
164   }
165
166 #ifdef TRACE_ENABLED
167   if(gTraceFilter && gTraceFilter->IsTraceEnabled())
168   {
169     std::ostringstream oss;
170     oss << "[size:" << mWidth << "x" << mHeight << " ";
171     oss << "url:" << mImageUrl.GetUrl() << "]";
172     DALI_TRACE_BEGIN_WITH_MESSAGE(gTraceFilter, "DALI_SVG_RASTERIZE_TASK", oss.str().c_str());
173   }
174 #endif
175
176   Devel::PixelBuffer pixelBuffer = mVectorRenderer.Rasterize(mWidth, mHeight);
177   if(!pixelBuffer)
178   {
179     DALI_LOG_ERROR("Rasterize is failed!\n");
180 #ifdef TRACE_ENABLED
181     if(gTraceFilter && gTraceFilter->IsTraceEnabled())
182     {
183       std::ostringstream oss;
184       oss << "[size:" << mWidth << "x" << mHeight << " ";
185       oss << "url:" << mImageUrl.GetUrl() << "]";
186       DALI_TRACE_END_WITH_MESSAGE(gTraceFilter, "DALI_SVG_RASTERIZE_TASK", oss.str().c_str());
187     }
188 #endif
189     return;
190   }
191
192   mPixelData    = Devel::PixelBuffer::Convert(pixelBuffer);
193   mHasSucceeded = true;
194
195 #ifdef TRACE_ENABLED
196   if(gTraceFilter && gTraceFilter->IsTraceEnabled())
197   {
198     std::ostringstream oss;
199     oss << "[size:" << mWidth << "x" << mHeight << " ";
200     oss << "url:" << mImageUrl.GetUrl() << "]";
201     DALI_TRACE_END_WITH_MESSAGE(gTraceFilter, "DALI_SVG_RASTERIZE_TASK", oss.str().c_str());
202   }
203 #endif
204 }
205
206 bool SvgRasterizingTask::IsReady()
207 {
208   return mVectorRenderer.IsLoaded();
209 }
210
211 PixelData SvgRasterizingTask::GetPixelData() const
212 {
213   return mPixelData;
214 }
215
216 } // namespace Internal
217
218 } // namespace Toolkit
219
220 } // namespace Dali