author | Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> |
Wed, 13 Oct 2010 14:32:09 +0300 | |
branch | RCL_3 |
changeset 75 | 01504893d9cb |
parent 60 | 5b3385a43d68 |
permissions | -rw-r--r-- |
60 | 1 |
/* |
2 |
* Copyright (c) 2008-2009 Nokia Corporation and/or its subsidiary(-ies). |
|
3 |
* All rights reserved. |
|
4 |
* This component and the accompanying materials are made available |
|
5 |
* under the terms of "Eclipse Public License v1.0" |
|
6 |
* which accompanies this distribution, and is available |
|
7 |
* at the URL "http://www.eclipse.org/legal/epl-v10.html". |
|
8 |
* |
|
9 |
* Initial Contributors: |
|
10 |
* Nokia Corporation - initial contribution. |
|
11 |
* |
|
12 |
* Contributors: |
|
13 |
* |
|
14 |
* Description: Texture Manager component/Decodes the Image in step for large sized images |
|
15 |
* |
|
16 |
*/ |
|
17 |
||
18 |
||
19 |
||
20 |
||
21 |
// INCLUDE FILES |
|
22 |
#include "glxbitmapdecoderwrapper.h" |
|
23 |
#include <glxtracer.h> // For Log |
|
24 |
#include <bitmaptransforms.h> |
|
25 |
#include <imageconversion.h> |
|
26 |
#include <ExifRead.h> |
|
27 |
#include <glxlog.h> |
|
28 |
#include <hal.h> |
|
29 |
#include <hal_data.h> |
|
30 |
#include <mglxcache.h> |
|
31 |
#include <oommonitorsession.h> |
|
32 |
#include <e32math.h> |
|
33 |
#include <apgcli.h> |
|
34 |
||
35 |
namespace |
|
36 |
{ |
|
37 |
const TInt KGlxDecodingThreshold = 3000000; |
|
38 |
const TInt KGlxDecodingThresholdDimension = 2000; |
|
39 |
||
40 |
// Photos low_ram_threshold [8.637 MB] as in oomconfig.xml |
|
41 |
const TInt KGlxCriticalRAMForPhotos = 9056550; |
|
42 |
const TInt KGlxDecodeBitmapFactor = 3; |
|
43 |
||
44 |
} |
|
45 |
||
46 |
// --------------------------------------------------------------------------- |
|
47 |
// Two-phased constructor. |
|
48 |
// --------------------------------------------------------------------------- |
|
49 |
// |
|
50 |
CGlxBitmapDecoderWrapper* CGlxBitmapDecoderWrapper::NewL( |
|
51 |
MGlxBitmapDecoderObserver* aObserver) |
|
52 |
{ |
|
53 |
TRACER("CGlxBitmapDecoderWrapper::NewL()"); |
|
54 |
CGlxBitmapDecoderWrapper* self = new (ELeave) CGlxBitmapDecoderWrapper(); |
|
55 |
CleanupStack::PushL(self); |
|
56 |
self->ConstructL(aObserver); |
|
57 |
CleanupStack::Pop(self); |
|
58 |
return self; |
|
59 |
} |
|
60 |
||
61 |
// --------------------------------------------------------------------------- |
|
62 |
// Constructor |
|
63 |
// --------------------------------------------------------------------------- |
|
64 |
// |
|
75
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
65 |
CGlxBitmapDecoderWrapper::CGlxBitmapDecoderWrapper() |
60 | 66 |
{ |
67 |
TRACER("CGlxBitmapDecoderWrapper::CGlxBitmapDecoderWrapper()"); |
|
68 |
} |
|
69 |
||
70 |
// --------------------------------------------------------------------------- |
|
71 |
// Destructor |
|
72 |
// --------------------------------------------------------------------------- |
|
73 |
// |
|
74 |
CGlxBitmapDecoderWrapper::~CGlxBitmapDecoderWrapper() |
|
75 |
{ |
|
76 |
TRACER("CGlxBitmapDecoderWrapper::~CGlxBitmapDecoderWrapper()"); |
|
75
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
77 |
if (iTnManager) |
60 | 78 |
{ |
75
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
79 |
iTnManager->CancelRequest(iTnReqId); |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
80 |
delete iTnManager; |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
81 |
iTnManager = NULL; |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
82 |
} |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
83 |
if(iBitmap) |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
84 |
{ |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
85 |
delete iBitmap; |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
86 |
iBitmap = NULL; |
60 | 87 |
} |
88 |
if (iImagePath) |
|
89 |
{ |
|
90 |
delete iImagePath; |
|
91 |
iImagePath = NULL; |
|
92 |
} |
|
93 |
} |
|
94 |
||
95 |
// --------------------------------------------------------------------------- |
|
96 |
// ConstructL |
|
97 |
// --------------------------------------------------------------------------- |
|
98 |
void CGlxBitmapDecoderWrapper::ConstructL(MGlxBitmapDecoderObserver* aObserver) |
|
99 |
{ |
|
100 |
TRACER("CGlxBitmapDecoderWrapper::ConstructL "); |
|
101 |
iObserver = aObserver; |
|
102 |
} |
|
103 |
||
104 |
// --------------------------------------------------------------------------- |
|
105 |
// DoDecodeImageL |
|
106 |
// --------------------------------------------------------------------------- |
|
75
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
107 |
void CGlxBitmapDecoderWrapper::DoDecodeImageL(const TGlxMedia& aMedia, |
60 | 108 |
TInt aIndex) |
109 |
{ |
|
110 |
TRACER("CGlxBitmapDecoderWrapper::DoDecodeImageL()"); |
|
111 |
||
112 |
iThumbnailIndex = aIndex; |
|
75
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
113 |
TSize originalDim; |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
114 |
aMedia.GetDimensions(originalDim); |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
115 |
iOriginalSize.iWidth = originalDim.iWidth; |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
116 |
iOriginalSize.iHeight = originalDim.iHeight; |
60 | 117 |
|
118 |
if (iImagePath) |
|
119 |
{ |
|
120 |
delete iImagePath; |
|
121 |
iImagePath = NULL; |
|
122 |
} |
|
75
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
123 |
|
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
124 |
const TDesC& uri = aMedia.Uri(); |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
125 |
GLX_LOG_URI("CGlxBitmapDecoderWrapper::DoDecodeImageL(%S)", &uri); |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
126 |
iImagePath = uri.Alloc(); |
60 | 127 |
|
128 |
DecodeImageL(); |
|
129 |
} |
|
130 |
||
131 |
// --------------------------------------------------------------------------- |
|
132 |
// DecodeImageL |
|
133 |
// --------------------------------------------------------------------------- |
|
134 |
// |
|
135 |
void CGlxBitmapDecoderWrapper::DecodeImageL() |
|
136 |
{ |
|
137 |
TRACER("CGlxBitmapDecoderWrapper::DecodeImageL()"); |
|
138 |
TReal32 mFactor = 1; |
|
139 |
TReal mFactor1 = 1; |
|
140 |
TReal32 mFactor2 = 1; |
|
141 |
//Set Size according to level and state |
|
142 |
TReal32 width = iOriginalSize.iWidth; |
|
143 |
TReal32 height = iOriginalSize.iHeight; |
|
144 |
||
145 |
if (KGlxDecodingThreshold < (width * height)) |
|
146 |
{ |
|
147 |
TReal tempFactor = TReal32(KGlxDecodingThreshold) |
|
148 |
/ (width * height); |
|
149 |
User::LeaveIfError(Math::Sqrt(mFactor1, tempFactor)); |
|
150 |
GLX_DEBUG2("DecodeImageL() - mFactor1 = %f", mFactor1); |
|
151 |
} |
|
152 |
||
153 |
if (KGlxDecodingThresholdDimension < width |
|
154 |
|| KGlxDecodingThresholdDimension < height) |
|
155 |
{ |
|
156 |
mFactor2 = TReal32(KGlxDecodingThresholdDimension) / Max(width, |
|
157 |
height); |
|
158 |
GLX_DEBUG2("DecodeImageL() - mFactor2 = %f", mFactor2); |
|
159 |
} |
|
160 |
||
161 |
mFactor = Min(TReal32(mFactor1), mFactor2); |
|
162 |
GLX_DEBUG2("DecodeImageL() - Final mFactor = %f", mFactor); |
|
163 |
||
164 |
// create the destination bitmap |
|
165 |
if (!iBitmap) |
|
166 |
{ |
|
167 |
TInt freeMemory = 0; |
|
168 |
HAL::Get(HALData::EMemoryRAMFree, freeMemory); |
|
169 |
width *= mFactor; |
|
170 |
height *= mFactor; |
|
171 |
TInt minmemorytodecode = KGlxDecodeBitmapFactor * width * height; |
|
172 |
GLX_DEBUG3("DecodeImageL: minmemorytodecode=%d, freememory=%d", |
|
173 |
minmemorytodecode, freeMemory); |
|
174 |
||
175 |
iTargetBitmapSize.iWidth = width; |
|
176 |
iTargetBitmapSize.iHeight = height; |
|
177 |
GLX_DEBUG3("DecodeImageL: iTargetBitmapSize w=%d, h=%d", |
|
178 |
iTargetBitmapSize.iWidth, iTargetBitmapSize.iHeight); |
|
179 |
__ASSERT_DEBUG(width > 0 && height > 0, Panic(EGlxPanicIllegalArgument)); |
|
180 |
||
181 |
if (minmemorytodecode < (freeMemory - KGlxCriticalRAMForPhotos)) |
|
182 |
{ |
|
183 |
GLX_DEBUG1("DecodeImageL:RAM available decoding image"); |
|
75
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
184 |
|
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
185 |
GetThumbnailL(iImagePath); |
60 | 186 |
} |
187 |
else |
|
188 |
{ |
|
189 |
//case when sufficient memory is not available |
|
190 |
//request OOM FW to release the required memory |
|
191 |
GLX_DEBUG1("DecodeImageL:insufficient RAM - request OOM"); |
|
192 |
TInt err = OOMRequestFreeMemoryL(minmemorytodecode); |
|
193 |
if (err == KErrNoMemory) |
|
194 |
{ |
|
195 |
//if OOM fails, release Photos Cache |
|
196 |
GLX_DEBUG1("DecodeImageL:insufficient RAM - OOM failed" |
|
197 |
" - request Cache"); |
|
198 |
MGlxCache* cacheManager = MGlxCache::InstanceL(); |
|
199 |
cacheManager->ReleaseRAML(ETrue); |
|
200 |
cacheManager->Close(); |
|
201 |
//Try and release memory again |
|
202 |
err = OOMRequestFreeMemoryL(minmemorytodecode); |
|
203 |
} |
|
204 |
if (err != KErrNoMemory) |
|
205 |
{ |
|
206 |
GLX_DEBUG1("DecodeImageL:Sufficient RAM available"); |
|
75
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
207 |
GetThumbnailL(iImagePath); |
60 | 208 |
} |
209 |
else |
|
210 |
{ |
|
211 |
GLX_DEBUG1("NOT ENOUGH MEMORY - " |
|
212 |
"Using the Fullscreen Thumbnail For Zoom"); |
|
213 |
//Inform the client that there is no decode happened and there we take care |
|
214 |
//of showing the fullscreen thumbnail. |
|
215 |
iObserver->HandleBitmapDecodedL(iThumbnailIndex, NULL); |
|
216 |
return; |
|
217 |
} |
|
218 |
} |
|
219 |
} |
|
220 |
} |
|
221 |
||
222 |
// --------------------------------------------------------------------------- |
|
223 |
// OOMRequestFreeMemoryL |
|
224 |
// --------------------------------------------------------------------------- |
|
225 |
// |
|
226 |
TInt CGlxBitmapDecoderWrapper::OOMRequestFreeMemoryL(TInt aBytesRequested) |
|
227 |
{ |
|
228 |
TRACER("CGlxBitmapDecoderWrapper::OOMRequestFreeMemoryL"); |
|
229 |
GLX_LOG_INFO1("CGlxBitmapDecoderWrapper::OOMRequestFreeMemoryL() " |
|
230 |
"aBytesRequested=%d", aBytesRequested); |
|
231 |
ROomMonitorSession oomMonitor; |
|
232 |
User::LeaveIfError(oomMonitor.Connect()); |
|
233 |
// No leaving code after this point, so no need to use cleanup stack |
|
234 |
// for oomMonitor |
|
235 |
TInt errorCode = oomMonitor.RequestFreeMemory(aBytesRequested); |
|
236 |
GLX_LOG_INFO1("CGlxBitmapDecoderWrapper::OOMRequestFreeMemoryL(1) " |
|
237 |
"errorCode=%d",errorCode); |
|
238 |
if (errorCode != KErrNone) |
|
239 |
{ |
|
240 |
// try one more time |
|
241 |
errorCode = oomMonitor.RequestFreeMemory(aBytesRequested); |
|
242 |
GLX_LOG_INFO1("CGlxBitmapDecoderWrapper::OOMRequestFreeMemoryL(2) " |
|
243 |
"errorCode=%d",errorCode); |
|
244 |
} |
|
245 |
oomMonitor.Close(); |
|
246 |
return errorCode; |
|
247 |
} |
|
248 |
||
249 |
// ----------------------------------------------------------------------------- |
|
75
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
250 |
// CGlxBitmapDecoderWrapper::GetThumbnailL() |
60 | 251 |
// ----------------------------------------------------------------------------- |
252 |
// |
|
75
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
253 |
void CGlxBitmapDecoderWrapper::GetThumbnailL( HBufC* aImagePath ) |
60 | 254 |
{ |
75
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
255 |
TRACER("CGlxBitmapDecoderWrapper::GetThumbnailL"); |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
256 |
if (!iTnManager) |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
257 |
{ |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
258 |
iTnManager = CThumbnailManager::NewL(*this); |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
259 |
iTnManager->SetDisplayModeL(EColor16M); |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
260 |
} |
60 | 261 |
|
75
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
262 |
iTnManager->SetFlagsL(CThumbnailManager::EDefaultFlags); |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
263 |
iTnManager->SetThumbnailSizeL(iTargetBitmapSize); |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
264 |
iTnManager->SetQualityPreferenceL(CThumbnailManager::EOptimizeForQuality); |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
265 |
const TDesC& uri = aImagePath->Des(); |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
266 |
GLX_LOG_URI("CGlxBitmapDecoderWrapper::GetThumbnailL: (%S)", aImagePath ); |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
267 |
CThumbnailObjectSource* source = CThumbnailObjectSource::NewLC(uri, 0); |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
268 |
#ifdef _DEBUG |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
269 |
iStartTime.HomeTime(); // Get home time |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
270 |
#endif |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
271 |
iTnReqId = iTnManager->GetThumbnailL(*source); |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
272 |
CleanupStack::PopAndDestroy(source); |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
273 |
} |
60 | 274 |
|
75
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
275 |
// ----------------------------------------------------------------------------- |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
276 |
// CGlxBitmapDecoderWrapper::ThumbnailPreviewReady |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
277 |
// From MThumbnailManagerObserver |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
278 |
// ----------------------------------------------------------------------------- |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
279 |
// |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
280 |
void CGlxBitmapDecoderWrapper::ThumbnailPreviewReady( MThumbnailData& /*aThumbnail*/, |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
281 |
TThumbnailRequestId /*aId*/ ) |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
282 |
{ |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
283 |
TRACER("CGlxBitmapDecoderWrapper::ThumbnailPreviewReady"); |
60 | 284 |
} |
285 |
||
286 |
// ----------------------------------------------------------------------------- |
|
75
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
287 |
// CGlxBitmapDecoderWrapper::ThumbnailReady |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
288 |
// From MThumbnailManagerObserver |
60 | 289 |
// ----------------------------------------------------------------------------- |
75
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
290 |
// |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
291 |
void CGlxBitmapDecoderWrapper::ThumbnailReady( TInt aError, |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
292 |
MThumbnailData& aThumbnail, |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
293 |
TThumbnailRequestId /*aId*/ ) |
60 | 294 |
{ |
75
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
295 |
TRACER("CGlxBitmapDecoderWrapper::ThumbnailReady"); |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
296 |
#ifdef _DEBUG |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
297 |
iStopTime.HomeTime(); |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
298 |
GLX_DEBUG2("*** CGlxBitmapDecoderWrapper::ThumbnailReady() TNM took <%d> us to decode***", |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
299 |
(TInt)iStopTime.MicroSecondsFrom(iStartTime).Int64()); |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
300 |
#endif |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
301 |
|
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
302 |
if (aError == KErrNone) |
60 | 303 |
{ |
75
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
304 |
if (iBitmap) |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
305 |
{ |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
306 |
delete iBitmap; |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
307 |
iBitmap = NULL; |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
308 |
} |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
309 |
iBitmap = aThumbnail.DetachBitmap(); |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
310 |
iObserver->HandleBitmapDecodedL(iThumbnailIndex, iBitmap); |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
311 |
iBitmap = NULL; |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
312 |
} |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
313 |
} |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
314 |
|
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
315 |
// ----------------------------------------------------------------------------- |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
316 |
// CGlxBitmapDecoderWrapper::CancelRequest() |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
317 |
// Cancels all the pending requests and release resources |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
318 |
// ----------------------------------------------------------------------------- |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
319 |
// |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
320 |
void CGlxBitmapDecoderWrapper::CancelRequest() |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
321 |
{ |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
322 |
TRACER("CGlxBitmapDecoderWrapper::CancelRequest"); |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
323 |
if (iTnManager) |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
324 |
{ |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
325 |
iTnManager->CancelRequest(iTnReqId); |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
326 |
delete iTnManager; |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
327 |
iTnManager = NULL; |
60 | 328 |
} |
75
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
329 |
|
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
330 |
if (iBitmap) |
60 | 331 |
{ |
75
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
332 |
delete iBitmap; |
01504893d9cb
Revision: 201039
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
60
diff
changeset
|
333 |
iBitmap = NULL; |
60 | 334 |
} |
335 |
} |