/**************************************************************************** ** ** Copyright (C) 2016 The Qt Company Ltd. ** Contact: https://www.qt.io/licensing/ ** ** This file is part of the Qt Data Visualization module of the Qt Toolkit. ** ** $QT_BEGIN_LICENSE:GPL$ ** Commercial License Usage ** Licensees holding valid commercial Qt licenses may use this file in ** accordance with the commercial license agreement provided with the ** Software or, alternatively, in accordance with the terms contained in ** a written agreement between you and The Qt Company. For licensing terms ** and conditions see https://www.qt.io/terms-conditions. For further ** information use the contact form at https://www.qt.io/contact-us. ** ** GNU General Public License Usage ** Alternatively, this file may be used under the terms of the GNU ** General Public License version 3 or (at your option) any later version ** approved by the KDE Free Qt Foundation. The licenses are as published by ** the Free Software Foundation and appearing in the file LICENSE.GPL3 ** included in the packaging of this file. Please review the following ** information to ensure the GNU General Public License requirements will ** be met: https://www.gnu.org/licenses/gpl-3.0.html. ** ** $QT_END_LICENSE$ ** ****************************************************************************/ #include "volumetrictest.h" #include #include #include #include #include #include #include #include #include #include int main(int argc, char **argv) { QApplication app(argc, argv); //Q3DScatter *graph = new Q3DScatter(); //Q3DSurface *graph = new Q3DSurface(); Q3DBars *graph = new Q3DBars(); QWidget *container = QWidget::createWindowContainer(graph); QSize screenSize = graph->screen()->size(); container->setMinimumSize(QSize(screenSize.width() / 4, screenSize.height() / 4)); container->setMaximumSize(screenSize); container->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Expanding); container->setFocusPolicy(Qt::StrongFocus); QWidget *widget = new QWidget; QHBoxLayout *hLayout = new QHBoxLayout(widget); QVBoxLayout *vLayout = new QVBoxLayout(); hLayout->addWidget(container, 1); hLayout->addLayout(vLayout); widget->setWindowTitle(QStringLiteral("Volumetric TEST")); widget->resize(QSize(screenSize.width() / 1.5, screenSize.height() / 1.5)); QCheckBox *sliceXCheckBox = new QCheckBox(widget); sliceXCheckBox->setText(QStringLiteral("Slice volume on X axis")); sliceXCheckBox->setChecked(false); QCheckBox *sliceYCheckBox = new QCheckBox(widget); sliceYCheckBox->setText(QStringLiteral("Slice volume on Y axis")); sliceYCheckBox->setChecked(false); QCheckBox *sliceZCheckBox = new QCheckBox(widget); sliceZCheckBox->setText(QStringLiteral("Slice volume on Z axis")); sliceZCheckBox->setChecked(false); QSlider *sliceXSlider = new QSlider(Qt::Horizontal, widget); sliceXSlider->setMinimum(0); sliceXSlider->setMaximum(1024); sliceXSlider->setValue(512); sliceXSlider->setEnabled(true); QSlider *sliceYSlider = new QSlider(Qt::Horizontal, widget); sliceYSlider->setMinimum(0); sliceYSlider->setMaximum(1024); sliceYSlider->setValue(512); sliceYSlider->setEnabled(true); QSlider *sliceZSlider = new QSlider(Qt::Horizontal, widget); sliceZSlider->setMinimum(0); sliceZSlider->setMaximum(1024); sliceZSlider->setValue(512); sliceZSlider->setEnabled(true); QLabel *fpsLabel = new QLabel(QStringLiteral("Fps: "), widget); QLabel *sliceImageXLabel = new QLabel(widget); QLabel *sliceImageYLabel = new QLabel(widget); QLabel *sliceImageZLabel = new QLabel(widget); sliceImageXLabel->setMinimumSize(QSize(200, 100)); sliceImageYLabel->setMinimumSize(QSize(200, 200)); sliceImageZLabel->setMinimumSize(QSize(200, 100)); sliceImageXLabel->setMaximumSize(QSize(200, 100)); sliceImageYLabel->setMaximumSize(QSize(200, 200)); sliceImageZLabel->setMaximumSize(QSize(200, 100)); sliceImageXLabel->setFrameShape(QFrame::Box); sliceImageYLabel->setFrameShape(QFrame::Box); sliceImageZLabel->setFrameShape(QFrame::Box); sliceImageXLabel->setScaledContents(true); sliceImageYLabel->setScaledContents(true); sliceImageZLabel->setScaledContents(true); QPushButton *testSubTextureSetting = new QPushButton(widget); testSubTextureSetting->setText(QStringLiteral("Test subtexture settings")); QLabel *rangeSliderLabel = new QLabel(QStringLiteral("Adjust ranges:"), widget); QSlider *rangeXSlider = new QSlider(Qt::Horizontal, widget); rangeXSlider->setMinimum(0); rangeXSlider->setMaximum(1024); rangeXSlider->setValue(512); rangeXSlider->setEnabled(true); QSlider *rangeYSlider = new QSlider(Qt::Horizontal, widget); rangeYSlider->setMinimum(0); rangeYSlider->setMaximum(1024); rangeYSlider->setValue(512); rangeYSlider->setEnabled(true); QSlider *rangeZSlider = new QSlider(Qt::Horizontal, widget); rangeZSlider->setMinimum(0); rangeZSlider->setMaximum(1024); rangeZSlider->setValue(512); rangeZSlider->setEnabled(true); QPushButton *testBoundsSetting = new QPushButton(widget); testBoundsSetting->setText(QStringLiteral("Test data bounds")); vLayout->addWidget(fpsLabel); vLayout->addWidget(sliceXCheckBox); vLayout->addWidget(sliceXSlider); vLayout->addWidget(sliceImageXLabel); vLayout->addWidget(sliceYCheckBox); vLayout->addWidget(sliceYSlider); vLayout->addWidget(sliceImageYLabel); vLayout->addWidget(sliceZCheckBox); vLayout->addWidget(sliceZSlider); vLayout->addWidget(sliceImageZLabel); vLayout->addWidget(rangeSliderLabel); vLayout->addWidget(rangeXSlider); vLayout->addWidget(rangeYSlider); vLayout->addWidget(rangeZSlider); vLayout->addWidget(testBoundsSetting); vLayout->addWidget(testSubTextureSetting, 1, Qt::AlignTop); VolumetricModifier *modifier = new VolumetricModifier(graph); modifier->setFpsLabel(fpsLabel); modifier->setSliceLabels(sliceImageXLabel, sliceImageYLabel, sliceImageZLabel); QObject::connect(sliceXCheckBox, &QCheckBox::stateChanged, modifier, &VolumetricModifier::sliceX); QObject::connect(sliceYCheckBox, &QCheckBox::stateChanged, modifier, &VolumetricModifier::sliceY); QObject::connect(sliceZCheckBox, &QCheckBox::stateChanged, modifier, &VolumetricModifier::sliceZ); QObject::connect(sliceXSlider, &QSlider::valueChanged, modifier, &VolumetricModifier::adjustSliceX); QObject::connect(sliceYSlider, &QSlider::valueChanged, modifier, &VolumetricModifier::adjustSliceY); QObject::connect(sliceZSlider, &QSlider::valueChanged, modifier, &VolumetricModifier::adjustSliceZ); QObject::connect(testSubTextureSetting, &QPushButton::clicked, modifier, &VolumetricModifier::testSubtextureSetting); QObject::connect(rangeXSlider, &QSlider::valueChanged, modifier, &VolumetricModifier::adjustRangeX); QObject::connect(rangeYSlider, &QSlider::valueChanged, modifier, &VolumetricModifier::adjustRangeY); QObject::connect(rangeZSlider, &QSlider::valueChanged, modifier, &VolumetricModifier::adjustRangeZ); QObject::connect(testBoundsSetting, &QPushButton::clicked, modifier, &VolumetricModifier::testBoundsSetting); widget->show(); return app.exec(); }