كيف تتفاعل مع إجراءات مربع الاختيار؟ (qtableview مع QStandArdItemModel)

StackOverflow https://stackoverflow.com/questions/2785434

سؤال

أنا أستخدم QTableView و QStandArdItemModel لإظهار بعض البيانات.

لكل صف ، يوجد عمود يحتوي على خانة اختيار ، يتم إدراج خانة الاختيار هذه بواسطة SetItem ، الرمز كما يلي:

int rowNum;
QStandardItemModel *tableModel;
QStandardItem* __tmpItem = new QStandardItem();

__tmpItem->setCheckable(true);
__tmpItem->setCheckState(Qt::Unchecked);

tableModel->setItem(rowNum,0,__tmpItem);

الآن أريد التفاعل مع خانة الاختيار. إذا قامت خانة الاختيار بتغيير حالتها بواسطة المستخدم (من التحقق إلى عدم تحديد أو العكس) ، فأنا أريد أن أفعل شيئًا على صف البيانات المقابل.

أعلم أنه يمكنني استخدام Signal-Slot للالتقاء بتغيير خانة الاختيار ، ولكن نظرًا لوجود الكثير من صفات البيانات ، لا أريد توصيل كل صف واحد تلو الآخر.

هل هناك على أي حال للتفاعل مع إجراء الفحص بشكل أكثر فعالية؟ شكرًا :)

هل كانت مفيدة؟

المحلول

تعامل مع حدث النقر ، هناك ستحصل على ModelIndex ، والحصول على البيانات وتعديل نفس الشيء

إذا كنت ستقوم بإدراج أكثر من نص أو أيقونة ، فأنت بحاجة إلى تعيين المندوب لمشاهدة القائمة الخاصة بك

نصائح أخرى

لا أتعامل مع QTableView+QStandArdItemModel ، ولكن قد يكون مثالًا أدناه سيساعدك:

1). ملف table.h:

#ifndef TABLE__H
#define TABLE__H

#include <QtGui>

class ItemDelegate : public QItemDelegate
{
public:
    ItemDelegate(QObject *parent = 0)
        : QItemDelegate(parent)
    {
    }
    virtual void drawCheck(QPainter *painter, const QStyleOptionViewItem &option,
        const QRect &, Qt::CheckState state) const
    {
        const int textMargin = QApplication::style()->pixelMetric(QStyle::PM_FocusFrameHMargin) + 1;

        QRect checkRect = QStyle::alignedRect(option.direction, Qt::AlignCenter,
            check(option, option.rect, Qt::Checked).size(),
            QRect(option.rect.x() + textMargin, option.rect.y(),
            option.rect.width() - (textMargin * 2), option.rect.height()));
        QItemDelegate::drawCheck(painter, option, checkRect, state);
    }
    virtual bool editorEvent(QEvent *event, QAbstractItemModel *model, const QStyleOptionViewItem &option,
        const QModelIndex &index)
    {
        Q_ASSERT(event);
        Q_ASSERT(model);

        // make sure that the item is checkable
        Qt::ItemFlags flags = model->flags(index);
        if (!(flags & Qt::ItemIsUserCheckable) || !(flags & Qt::ItemIsEnabled))
            return false;
        // make sure that we have a check state
        QVariant value = index.data(Qt::CheckStateRole);
        if (!value.isValid())
            return false;
        // make sure that we have the right event type
        if (event->type() == QEvent::MouseButtonRelease) {
            const int textMargin = QApplication::style()->pixelMetric(QStyle::PM_FocusFrameHMargin) + 1;
            QRect checkRect = QStyle::alignedRect(option.direction, Qt::AlignCenter,
                check(option, option.rect, Qt::Checked).size(),
                QRect(option.rect.x() + textMargin, option.rect.y(),
                option.rect.width() - (2 * textMargin), option.rect.height()));
            if (!checkRect.contains(static_cast<QMouseEvent*>(event)->pos()))
                return false;
        } else if (event->type() == QEvent::KeyPress) {
            if (static_cast<QKeyEvent*>(event)->key() != Qt::Key_Space
                && static_cast<QKeyEvent*>(event)->key() != Qt::Key_Select)
                return false;
        } else {
            return false;
        }
        Qt::CheckState state = (static_cast<Qt::CheckState>(value.toInt()) == Qt::Checked
            ? Qt::Unchecked : Qt::Checked);

        QMessageBox::information(0,
            QString((state == Qt::Checked) ? "Qt::Checked" : "Qt::Unchecked"),
            QString("[%1/%2]").arg(index.row()).arg(index.column()));

        return model->setData(index, state, Qt::CheckStateRole);
    }
    virtual void drawFocus(QPainter *painter, const QStyleOptionViewItem &option, const QRect &rect) const
    {
        QItemDelegate::drawFocus(painter, option, option.rect);
    }
};


static int ROWS = 3;
static int COLS = 1;
class Table : public QTableWidget
{
    Q_OBJECT
public:
    Table(QWidget *parent = 0)
        : QTableWidget(ROWS, COLS, parent)
    {
        setItemDelegate(new ItemDelegate(this));
        QTableWidgetItem *item = 0;
        for (int i=0; i<rowCount(); ++i) {
            for (int j=0; j<columnCount(); ++j) {
                setItem(i, j, item = new QTableWidgetItem);
                item->setFlags(Qt::ItemIsEnabled|Qt::ItemIsUserCheckable);
                item->setCheckState((i+j) % 2 == 0 ? Qt::Checked : Qt::Unchecked);
            }
        }
    }
};

#endif

2). ملف main.cpp:

#include <QApplication>

#include "table.h"

int main(int argc, char **argv)
{
    QApplication a(argc, argv);
    Table w;
    w.show();
    return a.exec();
}

حظا طيبا وفقك الله.

ملاحظة: هنا هو الأصل نص.

فيما يلي فكرة أخرى مشابهة للمثال الذي اقترحه MOSG باستخدام QSTYLEITEMDELEGATE في حين أن. http://developer.qt.nokia.com/faq/answer/how_can_i_align_the_checkboxes_in_a_view

مرخصة بموجب: CC-BY-SA مع الإسناد
لا تنتمي إلى StackOverflow
scroll top