diff options
author | Topi Reinio <topi.reinio@digia.com> | 2014-10-15 13:50:27 +0200 |
---|---|---|
committer | Topi Reiniƶ <topi.reinio@digia.com> | 2014-10-17 14:57:13 +0200 |
commit | cf8f369f8575dcb9ca4d5116f3afc7cff4a080af (patch) | |
tree | a685f393b50786a892fcd3ad638b4c01e9002894 /examples/threads/queuedcustomtype/window.cpp | |
parent | 45485d9eb47d3129b8a74c2e9d854c07673161cd (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.cpp | 136 |
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); -} |