source: trunk/examples/qtconcurrent/progressdialog/main.cpp@ 5

Last change on this file since 5 was 2, checked in by Dmitry A. Kuminov, 16 years ago

Initially imported qt-all-opensource-src-4.5.1 from Trolltech.

File size: 3.5 KB
Line 
1/****************************************************************************
2**
3** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
4** Contact: Qt Software Information ([email protected])
5**
6** This file is part of the examples of the Qt Toolkit.
7**
8** $QT_BEGIN_LICENSE:LGPL$
9** Commercial Usage
10** Licensees holding valid Qt Commercial licenses may use this file in
11** accordance with the Qt Commercial License Agreement provided with the
12** Software or, alternatively, in accordance with the terms contained in
13** a written agreement between you and Nokia.
14**
15** GNU Lesser General Public License Usage
16** Alternatively, this file may be used under the terms of the GNU Lesser
17** General Public License version 2.1 as published by the Free Software
18** Foundation and appearing in the file LICENSE.LGPL included in the
19** packaging of this file. Please review the following information to
20** ensure the GNU Lesser General Public License version 2.1 requirements
21** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
22**
23** In addition, as a special exception, Nokia gives you certain
24** additional rights. These rights are described in the Nokia Qt LGPL
25** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
26** package.
27**
28** GNU General Public License Usage
29** Alternatively, this file may be used under the terms of the GNU
30** General Public License version 3.0 as published by the Free Software
31** Foundation and appearing in the file LICENSE.GPL included in the
32** packaging of this file. Please review the following information to
33** ensure the GNU General Public License version 3.0 requirements will be
34** met: http://www.gnu.org/copyleft/gpl.html.
35**
36** If you are unsure which license is appropriate for your use, please
37** contact the sales department at [email protected].
38** $QT_END_LICENSE$
39**
40****************************************************************************/
41
42#include <QtGui>
43
44#ifndef QT_NO_CONCURRENT
45
46using namespace QtConcurrent;
47
48const int iterations = 20;
49
50void spin(int &iteration)
51{
52 const int work = 1000 * 1000 * 40;
53 volatile int v = 0;
54 for (int j = 0; j < work; ++j)
55 ++v;
56
57 qDebug() << "iteration" << iteration << "in thread" << QThread::currentThreadId();
58}
59
60int main(int argc, char **argv)
61{
62 QApplication app(argc, argv);
63
64 // Prepare the vector.
65 QVector<int> vector;
66 for (int i = 0; i < iterations; ++i)
67 vector.append(i);
68
69 // Create a progress dialog.
70 QProgressDialog dialog;
71 dialog.setLabelText(QString("Progressing using %1 thread(s)...").arg(QThread::idealThreadCount()));
72
73 // Create a QFutureWatcher and conncect signals and slots.
74 QFutureWatcher<void> futureWatcher;
75 QObject::connect(&futureWatcher, SIGNAL(finished()), &dialog, SLOT(reset()));
76 QObject::connect(&dialog, SIGNAL(canceled()), &futureWatcher, SLOT(cancel()));
77 QObject::connect(&futureWatcher, SIGNAL(progressRangeChanged(int, int)), &dialog, SLOT(setRange(int, int)));
78 QObject::connect(&futureWatcher, SIGNAL(progressValueChanged(int)), &dialog, SLOT(setValue(int)));
79
80 // Start the computation.
81 futureWatcher.setFuture(QtConcurrent::map(vector, spin));
82
83 // Display the dialog and start the event loop.
84 dialog.exec();
85
86 futureWatcher.waitForFinished();
87
88 // Query the future to check if was canceled.
89 qDebug() << "Canceled?" << futureWatcher.future().isCanceled();
90}
91
92#else
93
94int main()
95{
96 qDebug() << "Qt Concurrent is not yet supported on this platform";
97}
98
99#endif
100
Note: See TracBrowser for help on using the repository browser.