mirror of
https://bitbucket.org/mfeemster/fractorium.git
synced 2025-01-21 21:20:07 -05:00
1dfbd4eff2
-Add new preset dimensions to the right click menu of the width and height fields in the editor. -Change QSS stylesheets to properly handle tabs. -Make tabs rectangular by default. For some reason, they had always been triangular. --Bug fixes -Incremental rendering times in the editor were wrong. --Code changes -Migrate to Qt6. There is probably more work to be done here. -Migrate to VS2022. -Migrate to Wix 4 installer. -Change installer to install to program files for all users. -Fix many VS2022 code analysis warnings. -No longer use byte typedef, because std::byte is now a type. Revert all back to unsigned char. -Upgrade OpenCL headers to version 3.0 and keep locally now rather than trying to look for system files. -No longer link to Nvidia or AMD specific OpenCL libraries. Use the generic installer located at OCL_ROOT too. -Add the ability to change OpenCL grid dimensions. This was attempted for investigating possible performance improvments, but made no difference. This has not been verified on Linux or Mac yet.
231 lines
7.0 KiB
C++
231 lines
7.0 KiB
C++
#pragma once
|
|
|
|
#include "FractoriumPch.h"
|
|
#include "SpinBox.h"
|
|
#include "DoubleSpinBox.h"
|
|
|
|
/// <summary>
|
|
/// TwoButtonComboWidget and SpinnerButtonWidget classes.
|
|
/// </summary>
|
|
|
|
/// <summary>
|
|
/// Thin container that is both a widget and a container of two QPushButtons.
|
|
/// Used for when a layout expects a single widget, but two need to go in its place.
|
|
/// The buttons are public so the caller can easily use them individually.
|
|
/// </summary>
|
|
class TwoButtonComboWidget : public QWidget
|
|
{
|
|
Q_OBJECT
|
|
|
|
public:
|
|
/// <summary>
|
|
/// Constructor that passes the parent to the base, then creates two QPushButtons,
|
|
/// and sets up their captions and dimensions.
|
|
/// </summary>
|
|
/// <param name="caption1">The caption of the first button</param>
|
|
/// <param name="caption2">The caption of the second button</param>
|
|
/// <param name="w1">The width of the first button</param>
|
|
/// <param name="w2">The width of the second button</param>
|
|
/// <param name="h">The height of both buttons</param>
|
|
/// <param name="p">The parent widget</param>
|
|
TwoButtonComboWidget(const QString& caption1, const QString& caption2, QStringList comboStrings, int w1, int w2, int h, QWidget* p)
|
|
: QWidget(p)
|
|
{
|
|
QHBoxLayout* l = new QHBoxLayout(this);
|
|
m_Button1 = new QPushButton(caption1, p);
|
|
m_Button2 = new QPushButton(caption2, p);
|
|
m_Combo = new QComboBox(p);
|
|
m_Combo->addItems(comboStrings);
|
|
|
|
if (w1 != -1)
|
|
{
|
|
m_Button1->setMinimumWidth(w1);
|
|
m_Button1->setMaximumWidth(w1);
|
|
}
|
|
|
|
if (w2 != -1)
|
|
{
|
|
m_Button2->setMinimumWidth(w2);
|
|
m_Button2->setMaximumWidth(w2);
|
|
}
|
|
|
|
m_Button1->setMinimumHeight(h);
|
|
m_Button1->setMaximumHeight(h);
|
|
m_Button2->setMinimumHeight(h);
|
|
m_Button2->setMaximumHeight(h);
|
|
m_Combo->setMinimumHeight(h - 3);
|
|
m_Combo->setMaximumHeight(h - 3);
|
|
l->addWidget(m_Combo);
|
|
l->addWidget(m_Button1);
|
|
l->addWidget(m_Button2);
|
|
l->setAlignment(Qt::AlignLeft);
|
|
l->setContentsMargins(0, 0, 0, 0);
|
|
l->setSpacing(2);
|
|
setLayout(l);
|
|
}
|
|
|
|
QPushButton* m_Button1;
|
|
QPushButton* m_Button2;
|
|
QComboBox* m_Combo;
|
|
};
|
|
|
|
/// <summary>
|
|
/// Thin container that is both a widget and a container of one DoubleSpinBox and one QPushButton.
|
|
/// Used for when a layout expects a single widget, but two need to go in its place.
|
|
/// The widgets are public so the caller can easily use them individually.
|
|
/// </summary>
|
|
class SpinnerButtonWidget : public QWidget
|
|
{
|
|
Q_OBJECT
|
|
|
|
public:
|
|
/// <summary>
|
|
/// Constructor that passes the parent to the base, then creates a QPushButton and
|
|
/// sets up its caption and dimensions, then assigns the DoubleSpinBox.
|
|
/// </summary>
|
|
/// <param name="spinBox">The pre-created DoubleSpinBox</param>
|
|
/// <param name="buttonCaption">The caption of the button</param>
|
|
/// <param name="w">The width of the button</param>
|
|
/// <param name="h">The height of the button</param>
|
|
/// <param name="p">The parent widget</param>
|
|
SpinnerButtonWidget(DoubleSpinBox* spinBox, QString buttonCaption, int w, int h, QWidget* p)
|
|
: QWidget(p)
|
|
{
|
|
QHBoxLayout* l = new QHBoxLayout(this);
|
|
m_Button = new QPushButton(buttonCaption, p);
|
|
m_SpinBox = spinBox;
|
|
|
|
if (w != -1)
|
|
{
|
|
m_Button->setMinimumWidth(w);
|
|
m_Button->setMaximumWidth(w);
|
|
}
|
|
|
|
m_Button->setMinimumHeight(h);
|
|
m_Button->setMaximumHeight(h);
|
|
l->addWidget(spinBox);
|
|
l->addWidget(m_Button);
|
|
l->setAlignment(Qt::AlignLeft | Qt::AlignVCenter);
|
|
l->setContentsMargins(0, 0, 0, 0);
|
|
l->setSpacing(0);
|
|
setLayout(l);
|
|
}
|
|
|
|
DoubleSpinBox* m_SpinBox;
|
|
QPushButton* m_Button;
|
|
};
|
|
|
|
/// <summary>
|
|
/// Thin container that is both a widget and a container of one DoubleSpinBox and one QLabel.
|
|
/// Used for when a layout expects a single widget, but two need to go in its place.
|
|
/// The widgets are public so the caller can easily use them individually.
|
|
/// </summary>
|
|
class SpinnerLabelWidget : public QWidget
|
|
{
|
|
Q_OBJECT
|
|
|
|
public:
|
|
/// <summary>
|
|
/// Constructor that passes the parent to the base, then creates a QLabel,
|
|
/// then creates a QPushButton and sets up its caption and dimensions, then
|
|
/// assigns the DoubleSpinBox.
|
|
/// </summary>
|
|
/// <param name="spinBox">The pre-created DoubleSpinBox</param>
|
|
/// <param name="h">The height of the label</param>
|
|
/// <param name="p">The parent widget</param>
|
|
SpinnerLabelWidget(DoubleSpinBox* spinBox, int h, QWidget* p)
|
|
: QWidget(p)
|
|
{
|
|
m_L = new QHBoxLayout(this);
|
|
m_SpinBox = spinBox;
|
|
m_Label = new QLabel(p);
|
|
m_Label->setMinimumHeight(h);
|
|
m_Label->setMaximumHeight(h);
|
|
m_L->addWidget(spinBox);
|
|
m_L->addWidget(m_Label);
|
|
m_L->setAlignment(Qt::AlignLeft | Qt::AlignVCenter);
|
|
m_L->setContentsMargins(0, 0, 0, 0);
|
|
m_L->setSpacing(0);
|
|
setLayout(m_L);
|
|
}
|
|
DoubleSpinBox* m_SpinBox;
|
|
QLabel* m_Label;
|
|
|
|
protected:
|
|
QHBoxLayout* m_L;
|
|
};
|
|
|
|
/// <summary>
|
|
/// Thin derivation that adds a button to a SpinnerLabelWidget.
|
|
/// </summary>
|
|
class SpinnerLabelButtonWidget : public SpinnerLabelWidget
|
|
{
|
|
Q_OBJECT
|
|
|
|
public:
|
|
/// <summary>
|
|
/// Constructor that passes the parent to the base, then creates a QLabel,
|
|
/// then creates a QPushButton and sets up its caption and dimensions, then
|
|
/// assigns the DoubleSpinBox.
|
|
/// </summary>
|
|
/// <param name="spinBox">The pre-created DoubleSpinBox</param>
|
|
/// <param name="buttonCaption">The caption of the button</param>
|
|
/// <param name="w">The width of the button</param>
|
|
/// <param name="h">The height of the button</param>
|
|
/// <param name="p">The parent widget</param>
|
|
SpinnerLabelButtonWidget(DoubleSpinBox* spinBox, QString buttonCaption, int w, int h, QWidget* p)
|
|
: SpinnerLabelWidget(spinBox, h, p)
|
|
{
|
|
m_Button = new QPushButton(buttonCaption, p);
|
|
|
|
if (w != -1)
|
|
{
|
|
m_Button->setMinimumWidth(w);
|
|
m_Button->setMaximumWidth(w);
|
|
}
|
|
|
|
m_Button->setMinimumHeight(h);
|
|
m_Button->setMaximumHeight(h);
|
|
m_L->addWidget(m_Button);
|
|
}
|
|
|
|
QPushButton* m_Button;
|
|
};
|
|
|
|
/// <summary>
|
|
/// Thin container that is both a widget and a container of one DoubleSpinBox and one SpinBox.
|
|
/// Used for when a layout expects a single widget, but two need to go in its place.
|
|
/// The widgets are public so the caller can easily use them individually.
|
|
/// </summary>
|
|
class DoubleIntSpinnerWidget : public QWidget
|
|
{
|
|
Q_OBJECT
|
|
|
|
public:
|
|
/// <summary>
|
|
/// Constructor that passes the parent to the base, then creates a QHBoxLayout,
|
|
/// and adds the passed in DoubleSpinBox and SpinBox to the layout.
|
|
/// </summary>
|
|
/// <param name="doubleSpinBox">The pre-created DoubleSpinBox</param>
|
|
/// <param name="spinBox">The pre-created SpinBox</param>
|
|
/// <param name="p">The parent widget</param>
|
|
DoubleIntSpinnerWidget(DoubleSpinBox* doubleSpinBox, SpinBox* spinBox, QWidget* p)
|
|
: QWidget(p)
|
|
{
|
|
m_L = new QHBoxLayout(this);
|
|
m_DoubleSpinBox = doubleSpinBox;
|
|
m_SpinBox = spinBox;
|
|
m_L->addWidget(doubleSpinBox);
|
|
m_L->addWidget(spinBox);
|
|
m_L->setAlignment(Qt::AlignLeft | Qt::AlignVCenter);
|
|
m_L->setContentsMargins(0, 0, 0, 0);
|
|
m_L->setSpacing(0);
|
|
setLayout(m_L);
|
|
}
|
|
DoubleSpinBox* m_DoubleSpinBox;
|
|
SpinBox* m_SpinBox;
|
|
|
|
protected:
|
|
QHBoxLayout* m_L;
|
|
};
|