blob: 09cdcbbf779c3777e937f6531e6a0d1b690c80e9 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
|
// Copyright (C) 2022 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0+ OR GPL-3.0 WITH Qt-GPL-exception-1.0
#include "smallimagecacheprovider.h"
#include <asynchronousimagecache.h>
#include <QMetaObject>
namespace QmlDesigner {
QQuickTextureFactory *ImageResponse::textureFactory() const
{
return QQuickTextureFactory::textureFactoryForImage(m_image);
}
void ImageResponse::setImage(const QImage &image)
{
m_image = image;
emit finished();
}
void ImageResponse::abort()
{
emit finished();
}
QQuickImageResponse *SmallImageCacheProvider::requestImageResponse(const QString &id, const QSize &)
{
auto response = std::make_unique<QmlDesigner::ImageResponse>(m_defaultImage);
m_cache.requestSmallImage(
id,
[response = QPointer<QmlDesigner::ImageResponse>(response.get())](const QImage &image) {
QMetaObject::invokeMethod(
response,
[response, image] {
if (response)
response->setImage(image);
},
Qt::QueuedConnection);
},
[response = QPointer<QmlDesigner::ImageResponse>(response.get())](
ImageCache::AbortReason abortReason) {
QMetaObject::invokeMethod(
response,
[response, abortReason] {
switch (abortReason) {
case ImageCache::AbortReason::Failed:
if (response)
response->abort();
break;
case ImageCache::AbortReason::Abort:
response->cancel();
break;
}
},
Qt::QueuedConnection);
});
return response.release();
}
} // namespace QmlDesigner
|