QTableView与QSqlTableModel显示mysql数据库中的数据,如何在QTableView的项中添加chekbox按钮与下拉列表啊?真心求指导。

lidaotong 2012-12-25 10:15:04
各位大侠好,利用QTableView与QSqlTableModel显示mysql数据库中的数据,如何在QTableView的项中添加chekbox按钮与下拉列表啊?

我想在QTableView的视图中,添加checkbox按钮,如何实现啊,可以点击选中与取消,点击与取消的状态要反应到数据库中。
例如图片所示:QTableView视图根据数据库的行列生成,【检测内容】列中的checkbox按钮如何实现啊?选中与不选中状态可以在数据库中用0或非零表示(只是这么个意思),如果数据库中对应【检测内容】列中的项非0,则checkbox选中,为0则不选中。


如上图所示,在【检测内容】列为checkbox按钮,【预期规格】与【预期速率】列为下拉列表combox,默认下拉列表不使能,当选中checkbox后,下拉列表才能够使能,从中选择内容。大侠们如何实现啊?

总结一下,我想知道,QTableView中如何嵌入checkbox与combox下拉列表,checkbox与combox下拉列表选择内容能够与数据库进行关联。研究了一段时间,百思不得其解。求做个的大侠们指导,拜谢了。
对QTableView、QSqlTableModel还不是很熟悉,求指导,再次拜谢。
...全文
1141 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
lidaotong 2013-01-11
  • 打赏
  • 举报
回复
引用 6 楼 wallace716 的回复:
如果你的表格列是固定的就比较好实现。 你可以继承一个QSqlTableModel类,比如mySqlTableModel:public QSqlTableModel. 在mySqlTableModel中重新实现“Qt::ItemFlags flags(const QModelIndex &index) const;”函数。 这样来选择“下拉列表”的使能。 ……
你好,根据你的代码实现,只有点击单元格的时候才会出现下拉列表,能不能默认直接就显示下拉列表的样子。因为如果不点击 单元格的话看不出存在下拉列表。我的意思是,默认单元格就显示为一个下拉列表。这个能实现吗,大侠。
wallace716 2012-12-31
  • 打赏
  • 举报
回复
如果你的表格列是固定的就比较好实现。 你可以继承一个QSqlTableModel类,比如mySqlTableModel:public QSqlTableModel. 在mySqlTableModel中重新实现“Qt::ItemFlags flags(const QModelIndex &index) const;”函数。 这样来选择“下拉列表”的使能。 下拉列表可以用代理类来实现。我这贴一个我自己做的下拉列表的代理类,仅供拍砖。
#ifndef DELEGATE_COMBO_BOX_H
#define DELEGATE_COMBO_BOX_H

#include <QtGui>

class delegate_combo_box : public QStyledItemDelegate
{
    Q_OBJECT
public:

    delegate_combo_box(QObject *parent = 0);
    delegate_combo_box(QStringList menuList);

    void paint(QPainter *painter,
               const QStyleOptionViewItem &option, const QModelIndex &index) const;

     QSize sizeHint ( const QStyleOptionViewItem & option, const QModelIndex & index ) const;

    // Create an editor you specified.
    QWidget *createEditor(QWidget *parent, const QStyleOptionViewItem &,
                          const QModelIndex &index) const;

    //Get data of model to editor.
    void setEditorData(QWidget *editor, const QModelIndex &index) const;

    //Push data to model when edited.
    void setModelData(QWidget *editor, QAbstractItemModel *model,
                      const QModelIndex &index) const;

private:
    QStringList itemList;

};

#endif // DELEGATE_COMBO_BOX_H
#include "delegate_combo_box.h"

delegate_combo_box::delegate_combo_box(QObject *parent) :
    QStyledItemDelegate(parent)
{
}

delegate_combo_box::delegate_combo_box(QStringList menuList,QObject *parent) :
    QStyledItemDelegate(parent)
{
    itemList << menuList;
}

//re impelement
void delegate_combo_box::paint(QPainter *painter,
                               const QStyleOptionViewItem &option, const QModelIndex &index) const
{
    Q_ASSERT(index.isValid());

    QStyleOptionViewItemV4 opt = option;
    //initStyleOption(&opt, index);
    opt.text = itemList.value(index.data(Qt::DisplayRole).toInt());
    QApplication::style()->drawControl(QStyle::CE_ItemViewItem, &opt, painter);

}

QSize delegate_combo_box::sizeHint(const QStyleOptionViewItem &option, const QModelIndex &index) const
{
    int menuIndex = index.data(Qt::DisplayRole).toInt();
    QString text = itemList.value(menuIndex);
    QFontMetrics metrics =  option.fontMetrics;
    return QSize(metrics.width(text)+8,metrics.height());
}

QWidget *delegate_combo_box::createEditor(QWidget *parent,
                                          const QStyleOptionViewItem &,
                                          const QModelIndex &/*index*/ ) const
{
    QComboBox *comboBoxEditor = new QComboBox(parent);
    comboBoxEditor->addItems(itemList);
    return comboBoxEditor;
}

void delegate_combo_box::setEditorData(QWidget *editor,
                                       const QModelIndex & index) const
{
    QComboBox *edit = qobject_cast<QComboBox*>(editor);
    if(edit)
    {
        edit->setCurrentIndex(index.data(Qt::EditRole).toInt());
    }
}


void delegate_combo_box::setModelData(QWidget *editor,
                                      QAbstractItemModel *model, const QModelIndex &index) const
{
    QComboBox *edit = qobject_cast<QComboBox*>(editor);
    if(edit)
    {
        model->setData(index,edit->currentIndex());
    }
}
MarsZ 2012-12-26
  • 打赏
  • 举报
回复
引用 3 楼 lidaotong 的回复:
引用 2 楼 marsz1990 的回复:引用 楼主 lidaotong 的回复:各位大侠好,利用QTableView与QSqlTableModel显示mysql数据库中的数据,如何在QTableView的项中添加chekbox按钮与下拉列表啊? 我想在QTableView的视图中,添加checkbox按钮,如何实现啊,可以点击选中与取消,点击与取消的状态要反应到数……
Qt自带的例子有,这个我之前也折腾了个把星期,论坛提问基本无效,只能自己看例子参悟了,亲,注意参悟这个词语。。。 友情提示,请直接拷贝例子修改代码……
jdwx 2012-12-26
  • 打赏
  • 举报
回复
参照下面的例子:
lidaotong 2012-12-26
  • 打赏
  • 举报
回复
引用 2 楼 marsz1990 的回复:
引用 楼主 lidaotong 的回复:各位大侠好,利用QTableView与QSqlTableModel显示mysql数据库中的数据,如何在QTableView的项中添加chekbox按钮与下拉列表啊? 我想在QTableView的视图中,添加checkbox按钮,如何实现啊,可以点击选中与取消,点击与取消的状态要反应到数据库中。 例如图片所示:QTableVi……
能详述一下吗?
MarsZ 2012-12-26
  • 打赏
  • 举报
回复
引用 楼主 lidaotong 的回复:
各位大侠好,利用QTableView与QSqlTableModel显示mysql数据库中的数据,如何在QTableView的项中添加chekbox按钮与下拉列表啊? 我想在QTableView的视图中,添加checkbox按钮,如何实现啊,可以点击选中与取消,点击与取消的状态要反应到数据库中。 例如图片所示:QTableView视图根据数据库的行列生成,【检测内容……
哥,用代理吧……
lidaotong 2012-12-25
  • 打赏
  • 举报
回复
帖子内容写的比较啰嗦,想说明白自己的意图,求指导
课程亮点       本课程是PySide6零基础入门与目实战视频教程,经过精心设计,分为十个章节,制作了141页ppt, 接近70个代码示例,主要讲解PySide6开发环境安装、基础控件与界面布局、目实战,PySide6程序打包,安装包制作,安装卸载、更新,发布等知识。涵盖从基础概念到高级应用的全方位知识,旨在为你提供一条清晰、系统的学习之路。无论你是编程新手,还是希望深化对PySide6的了解,本课程都能满足你的需。       教学环境:Win11 64bit、Python3.11、PyCharm、Anacoda。课程大纲第一章:基础篇 PySide6开发环境安装        从Anaconda环境配置开始,带你快速入门Win11/win10下PySide6、PyQt5开发环境的安装与配置,分别介绍PyCharm与VSCode如何配置PySide6,  以及Python AnaConda的基本用法,创建虚拟环境,安装python模块。第二章 控件与布局篇 PySide6常用控件与界面布局使用介绍        深入PySide6的常用控件与界面布局技巧,通过丰富的实例,掌握PySide6的窗口、布局、控件等核心内容。主要介绍QLabel、QPushButton、QLineEdit、QCheckBox、QComboBox、QTextEdit、QTextBrowser、QListView与QListWidget、QStackedWidget、QTabWidget、QTableView等控件以及水平垂直布局,弹簧控件,栅格布局,表单布局。第三章 信号槽与事件机制       解锁PySide6的信号槽机制和事件处理技能,让你的应用更加灵活。详细介绍Qt自定义信号槽,跨窗口传递信号;Qt鼠标事件,键盘事件,组合事件,事件过滤。第四章 QMainWindow应用篇       详细介绍QMainWindow的使用,包括菜单栏、工具栏、状态栏和停靠窗口等。第五章 样式表qss与自定义控件        教你如何使用样式表美化应用界面,并创建独特的自定义控件。掌握这些技能后,学员将能够设计出既美观又功能丰富的用户界面。第六章 图表与曲线        引入pyqtgraph,展示如何在PySide6应用绘制图表和动态曲线。第七章 数据编程        带你进入数据编程世界,使用sqlite3与PySide6结合,进行数据存储和管理。第八章 目实战:高仿有道词典        通过一个高仿有道词典的目,将所学知识融会贯通,实战演练。课程将会接入翻译接口,开发一个属于自己的翻译软件。第九章 打包与部署       教你如何将PySide6目打包成exe,并使用Inno Setup制作安装包,介绍软件更新、卸载策略,让你的应用轻松上线。第十章 课程总结        回顾整个课程的学习内容,巩固知识点,为进一步的学习和应用打下坚实的基础。教学特色       实战案例:每个章节都配备实战案例,让学习者在实践深化理解。       代码资料全覆盖:提供全套课程代码资料下载,便于学习者随时查阅和复习。       高效学习路径:课程内容结构清晰,由浅入深,适合不同层次的学习者。       本课程提供全部代码与在线答疑。谁应该学习这个课程       对图形界面开发感兴趣的编程新手。       希望提升个人技能,进入或者深耕在GUI开发领域的开发者。       需要快速掌握PySide6进行目开发的软件工程师。结语        通过本课程的学习,你不仅能掌握PySide6的核心技能,还能通过实战目提升解决实际问题的能力,最终让你能独立完成专业的GUI应用开发。随着技术的深入,你将发现PySide6不仅仅是一个工具库,它开启的是一扇通往高效、美观应用开发的大门。        开始PySide6的学习之旅,让你的编程之路更加精彩!

16,203

社区成员

发帖
与我相关
我的任务
社区描述
Qt 是一个跨平台应用程序框架。通过使用 Qt,您可以一次性开发应用程序和用户界面,然后将其部署到多个桌面和嵌入式操作系统,而无需重复编写源代码。
社区管理员
  • Qt
  • 亭台六七座
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧