summaryrefslogtreecommitdiffstats
path: root/examples/threads/queuedcustomtype/window.cpp
diff options
context:
space:
mode:
authorTopi Reinio <topi.reinio@digia.com>2014-10-15 13:50:27 +0200
committerTopi Reiniƶ <topi.reinio@digia.com>2014-10-17 14:57:13 +0200
commitcf8f369f8575dcb9ca4d5116f3afc7cff4a080af (patch)
treea685f393b50786a892fcd3ad638b4c01e9002894 /examples/threads/queuedcustomtype/window.cpp
parent45485d9eb47d3129b8a74c2e9d854c07673161cd (diff)
Move Qt Core examples under a common subdirectory
Qt Core examples were scattered into several subdirectories under qtbase/examples. This caused an issue with the example manifest file generated by QDoc; it expects to find all examples under a common directory in order to produde correct paths to the example .pro files. Qt Creator will not find the examples without a valid manifest file. This change moves the examples and edits the documentation files accordingly. Task-number: QTBUG-41963 Change-Id: I51d86782e0ba21c5c9bae5f15401ec774abe5cf8 Reviewed-by: Friedemann Kleint <Friedemann.Kleint@digia.com> Reviewed-by: Oswald Buddenhagen <oswald.buddenhagen@theqtcompany.com> Reviewed-by: Leena Miettinen <riitta-leena.miettinen@digia.com>
Diffstat (limited to 'examples/threads/queuedcustomtype/window.cpp')
-rw-r--r--examples/threads/queuedcustomtype/window.cpp136
1 files changed, 0 insertions, 136 deletions
diff --git a/examples/threads/queuedcustomtype/window.cpp b/examples/threads/queuedcustomtype/window.cpp
deleted file mode 100644
index 8afb8b6782..0000000000
--- a/examples/threads/queuedcustomtype/window.cpp
+++ /dev/null
@@ -1,136 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2013 Digia Plc and/or its subsidiary(-ies).
-** Contact: http://www.qt-project.org/legal
-**
-** This file is part of the examples of the Qt Toolkit.
-**
-** $QT_BEGIN_LICENSE:BSD$
-** You may use this file under the terms of the BSD license as follows:
-**
-** "Redistribution and use in source and binary forms, with or without
-** modification, are permitted provided that the following conditions are
-** met:
-** * Redistributions of source code must retain the above copyright
-** notice, this list of conditions and the following disclaimer.
-** * Redistributions in binary form must reproduce the above copyright
-** notice, this list of conditions and the following disclaimer in
-** the documentation and/or other materials provided with the
-** distribution.
-** * Neither the name of Digia Plc and its Subsidiary(-ies) nor the names
-** of its contributors may be used to endorse or promote products derived
-** from this software without specific prior written permission.
-**
-**
-** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-** "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-** LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-** A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-** OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-** SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-** LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-** DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-** THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-** (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-** OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE."
-**
-** $QT_END_LICENSE$
-**
-****************************************************************************/
-
-#include <QtWidgets>
-#include "window.h"
-
-//! [Window constructor start]
-Window::Window()
-{
- thread = new RenderThread();
-//! [Window constructor start] //! [set up widgets and connections]
-
- label = new QLabel();
- label->setAlignment(Qt::AlignCenter);
-
- loadButton = new QPushButton(tr("&Load image..."));
- resetButton = new QPushButton(tr("&Stop"));
- resetButton->setEnabled(false);
-
- connect(loadButton, SIGNAL(clicked()), this, SLOT(loadImage()));
- connect(resetButton, SIGNAL(clicked()), thread, SLOT(stopProcess()));
- connect(thread, SIGNAL(finished()), this, SLOT(resetUi()));
-//! [set up widgets and connections] //! [connecting signal with custom type]
- connect(thread, SIGNAL(sendBlock(Block)), this, SLOT(addBlock(Block)));
-//! [connecting signal with custom type]
-
- QHBoxLayout *buttonLayout = new QHBoxLayout();
- buttonLayout->addStretch();
- buttonLayout->addWidget(loadButton);
- buttonLayout->addWidget(resetButton);
- buttonLayout->addStretch();
-
- QVBoxLayout *layout = new QVBoxLayout(this);
- layout->addWidget(label);
- layout->addLayout(buttonLayout);
-
-//! [Window constructor finish]
- setWindowTitle(tr("Queued Custom Type"));
-}
-//! [Window constructor finish]
-
-void Window::loadImage()
-{
- QStringList formats;
- foreach (QByteArray format, QImageReader::supportedImageFormats())
- if (format.toLower() == format)
- formats.append("*." + format);
-
- QString newPath = QFileDialog::getOpenFileName(this, tr("Open Image"),
- path, tr("Image files (%1)").arg(formats.join(' ')));
-
- if (newPath.isEmpty())
- return;
-
- QImage image(newPath);
- if (!image.isNull()) {
- loadImage(image);
- path = newPath;
- }
-}
-
-void Window::loadImage(const QImage &image)
-{
- QDesktopWidget desktop;
- QImage useImage;
- QRect space = desktop.availableGeometry();
- if (image.width() > 0.75*space.width() || image.height() > 0.75*space.height())
- useImage = image.scaled(0.75*space.width(), 0.75*space.height(),
- Qt::KeepAspectRatio, Qt::SmoothTransformation);
- else
- useImage = image;
-
- pixmap = QPixmap(useImage.width(), useImage.height());
- pixmap.fill(qRgb(255, 255, 255));
- label->setPixmap(pixmap);
- loadButton->setEnabled(false);
- resetButton->setEnabled(true);
- thread->processImage(useImage);
-}
-
-//! [Adding blocks to the display]
-void Window::addBlock(const Block &block)
-{
- QColor color = block.color();
- color.setAlpha(64);
-
- QPainter painter;
- painter.begin(&pixmap);
- painter.fillRect(block.rect(), color);
- painter.end();
- label->setPixmap(pixmap);
-}
-//! [Adding blocks to the display]
-
-void Window::resetUi()
-{
- loadButton->setEnabled(true);
- resetButton->setEnabled(false);
-}