forked from scantailor/scantailor
-
Notifications
You must be signed in to change notification settings - Fork 1
/
DebugImageView.cpp
110 lines (95 loc) · 2.91 KB
/
DebugImageView.cpp
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
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
/*
Scan Tailor - Interactive post-processing tool for scanned pages.
Copyright (C) Joseph Artsimovich <[email protected]>
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#include "DebugImageView.h"
#include "AbstractCommand.h"
#include "BackgroundExecutor.h"
#include "ImageViewBase.h"
#include "BasicImageView.h"
#include "ProcessingIndicationWidget.h"
#include <QImage>
#include <QPointer>
#include <memory>
class DebugImageView::ImageLoadResult : public AbstractCommand0<void>
{
public:
ImageLoadResult(QPointer<DebugImageView> const& owner, QImage const& image)
: m_ptrOwner(owner), m_image(image) {}
// This method is called from the main thread.
virtual void operator()() {
if (DebugImageView* owner = m_ptrOwner) {
owner->imageLoaded(m_image);
}
}
private:
QPointer<DebugImageView> m_ptrOwner;
QImage m_image;
};
class DebugImageView::ImageLoader :
public AbstractCommand0<BackgroundExecutor::TaskResultPtr>
{
public:
ImageLoader(DebugImageView* owner, QString const& file_path)
: m_ptrOwner(owner), m_filePath(file_path) {}
virtual BackgroundExecutor::TaskResultPtr operator()() {
QImage image(m_filePath);
return BackgroundExecutor::TaskResultPtr(new ImageLoadResult(m_ptrOwner, image));
}
private:
QPointer<DebugImageView> m_ptrOwner;
QString m_filePath;
};
DebugImageView::DebugImageView(AutoRemovingFile file,
boost::function<QWidget* (QImage const&)> const& image_view_factory, QWidget* parent)
: QStackedWidget(parent),
m_file(file),
m_imageViewFactory(image_view_factory),
m_pPlaceholderWidget(new ProcessingIndicationWidget(this)),
m_isLive(false)
{
addWidget(m_pPlaceholderWidget);
}
void
DebugImageView::setLive(bool const live)
{
if (live && !m_isLive) {
ImageViewBase::backgroundExecutor().enqueueTask(
BackgroundExecutor::TaskPtr(new ImageLoader(this, m_file.get()))
);
} else if (!live && m_isLive) {
if (QWidget* wgt = currentWidget()) {
if (wgt != m_pPlaceholderWidget) {
removeWidget(wgt);
delete wgt;
}
}
}
m_isLive = live;
}
void
DebugImageView::imageLoaded(QImage const& image)
{
if (!m_isLive) {
return;
}
if (currentWidget() == m_pPlaceholderWidget) {
std::auto_ptr<QWidget> image_view;
if (m_imageViewFactory.empty()) {
image_view.reset(new BasicImageView(image));
} else {
image_view.reset(m_imageViewFactory(image));
}
setCurrentIndex(addWidget(image_view.release()));
}
}