[RFC PATCH] WIP: add a SpinBoxDelegate for DivePlannerPointsModel
Dirk Hohndel
dirk at hohndel.org
Wed Jul 9 08:44:46 PDT 2014
I haven't seen any discussion on this... I assume this isn't intended for
master at this stage (with the empty, commented out functions...)?
/D
On Mon, Jul 07, 2014 at 11:42:23PM +0200, Anton Lundin wrote:
> This is something to show what we need to do for the
> DivePlannerPointsModel, to fix entering of negative values there.
> ---
> qt-ui/diveplanner.cpp | 6 ++++++
> qt-ui/modeldelegates.cpp | 43 +++++++++++++++++++++++++++++++++++++++++++
> qt-ui/modeldelegates.h | 16 ++++++++++++++++
> 3 files changed, 65 insertions(+)
>
> diff --git a/qt-ui/diveplanner.cpp b/qt-ui/diveplanner.cpp
> index 631d605..a03b84d 100644
> --- a/qt-ui/diveplanner.cpp
> +++ b/qt-ui/diveplanner.cpp
> @@ -253,6 +253,12 @@ DivePlannerWidget::DivePlannerWidget(QWidget *parent, Qt::WindowFlags f) : QWidg
> ui.tableWidget->setModel(DivePlannerPointsModel::instance());
> DivePlannerPointsModel::instance()->setRecalc(true);
> ui.tableWidget->view()->setItemDelegateForColumn(DivePlannerPointsModel::GAS, new AirTypesDelegate(this));
> + // This makes shure the spinbox gets a setMinimum(0) on it so we can't have negative time or depth.
> + ui.tableWidget->view()->setItemDelegateForColumn(DivePlannerPointsModel::DEPTH, new SpinBoxDelegate(this));
> + ui.tableWidget->view()->setItemDelegateForColumn(DivePlannerPointsModel::RUNTIME, new SpinBoxDelegate(this));
> + ui.tableWidget->view()->setItemDelegateForColumn(DivePlannerPointsModel::DURATION, new SpinBoxDelegate(this));
> + // Nope, thats a QDoubleSpinBox.
> + //ui.tableWidget->view()->setItemDelegateForColumn(DivePlannerPointsModel::CCSETPOINT, new SpinBoxDelegate(this));
> ui.cylinderTableWidget->setTitle(tr("Available Gases"));
> ui.cylinderTableWidget->setModel(CylindersModel::instance());
> QTableView *view = ui.cylinderTableWidget->view();
> diff --git a/qt-ui/modeldelegates.cpp b/qt-ui/modeldelegates.cpp
> index dc6af56..4b58452 100644
> --- a/qt-ui/modeldelegates.cpp
> +++ b/qt-ui/modeldelegates.cpp
> @@ -364,3 +364,46 @@ void ProfilePrintDelegate::paint(QPainter *painter, const QStyleOptionViewItem &
> }
> QStyledItemDelegate::paint(painter, option, index);
> }
> +
> +/*
> +void SpinBoxDelegate::revertModelData(QWidget *widget, QAbstractItemDelegate::EndEditHint hint)
> +{
> +}
> +*/
> +
> +SpinBoxDelegate::SpinBoxDelegate(QObject *parent) : QStyledItemDelegate(parent)
> +{
> +}
> +
> +QWidget *SpinBoxDelegate::createEditor(QWidget *parent,
> + const QStyleOptionViewItem &/* option */,
> + const QModelIndex &/* index */) const
> +{
> + QSpinBox *editor = new QSpinBox(parent);
> + editor->setMinimum(0);
> + //editor->setMaximum(100);
> +
> + return editor;
> +}
> +
> +void SpinBoxDelegate::setEditorData(QWidget *editor, const QModelIndex &index) const
> +{
> + int value = index.model()->data(index, Qt::EditRole).toInt();
> +
> + QSpinBox *spinBox = static_cast<QSpinBox*>(editor);
> + spinBox->setValue(value);
> +}
> +
> +void SpinBoxDelegate::setModelData(QWidget *editor, QAbstractItemModel *model, const QModelIndex &index) const
> +{
> + QSpinBox *spinBox = static_cast<QSpinBox*>(editor);
> + spinBox->interpretText();
> + int value = spinBox->value();
> +
> + model->setData(index, value, Qt::EditRole);
> +}
> +
> +void SpinBoxDelegate::updateEditorGeometry(QWidget *editor, const QStyleOptionViewItem &option, const QModelIndex &/* index */) const
> +{
> + editor->setGeometry(option.rect);
> +}
> diff --git a/qt-ui/modeldelegates.h b/qt-ui/modeldelegates.h
> index e2b705e..b4959b2 100644
> --- a/qt-ui/modeldelegates.h
> +++ b/qt-ui/modeldelegates.h
> @@ -88,4 +88,20 @@ public:
> void paint(QPainter *painter, const QStyleOptionViewItem &option, const QModelIndex &index) const;
> };
>
> +class SpinBoxDelegate : public QStyledItemDelegate {
> + Q_OBJECT
> +public:
> + explicit SpinBoxDelegate(QObject *parent = 0);
> +
> + QWidget *createEditor(QWidget *parent, const QStyleOptionViewItem &option, const QModelIndex &index) const;
> + void setEditorData(QWidget *editor, const QModelIndex &index) const;
> + void setModelData(QWidget *editor, QAbstractItemModel *model, const QModelIndex &index) const;
> + void updateEditorGeometry(QWidget *editor, const QStyleOptionViewItem &option, const QModelIndex &index) const;
> + /*
> +public
> +slots:
> + void revertModelData(QWidget *widget, QAbstractItemDelegate::EndEditHint hint);
> + */
> +};
> +
> #endif // MODELDELEGATES_H
> --
> 1.9.1
>
> _______________________________________________
> subsurface mailing list
> subsurface at hohndel.org
> http://lists.hohndel.org/cgi-bin/mailman/listinfo/subsurface
More information about the subsurface
mailing list