24.QTableView函数使用,右击菜单实现

常用函数

QTableView view(this);
QStandardItemModel model(this);

/*设置表头水平标题*/
model.setHorizontalHeaderItem(0,new QStandardItem("Name"));
model.setHorizontalHeaderItem(1,new QStandardItem("Sex"));
model.setHorizontalHeaderItem(2,new QStandardItem("Age"));
model.horizontalHeaderItem(0)->setFont(QFont("Helvetica",20,50));   //设置标题字体

/*设置表头垂直标题*/
model.setVerticalHeaderItem(0,new QStandardItem("No.1"));
model.setVerticalHeaderItem(1,new QStandardItem("No.2"));
model.setVerticalHeaderItem(2,new QStandardItem("No.3"));

/*设置列表条目数据*/
QPixmap  pix(":user.png");
pix = pix.scaled(24,24,Qt::KeepAspectRatio);
QStandardItem *itemA=new QStandardItem();
itemA->setData(pix,Qt::DecorationRole);                        //设置条目图标
itemA->setData("A",Qt::DisplayRole);
itemA->setData("A:tooltip",Qt::ToolTipRole);
itemA->setData(QFont("宋体",12,QFont::Bold,true),Qt::FontRole); //设置条目字体
itemA->setData(Qt::AlignCenter,Qt::TextAlignmentRole);         //设置条目中心对齐
//可以实现按数值排序,否则的话"2">"123"itemA->setData(Qt::DisplayRole, 2); 
 QLinearGradient linearGradient(0,0,100,20);
 linearGradient.setColorAt(0.2, Qt::white);
 linearGradient.setColorAt(0.6, Qt::green);
 linearGradient.setColorAt(1.0, Qt::black);
 itemA->setData(QBrush(linearGradient),Qt::BackgroundRole);    //设置条目背景色(为渐变色)

   model.setItem(0,0,itemA);
   model.setItem(0,1,new QStandardItem("B"));
   model.setItem(1,0,new QStandardItem("C"));  
   model.item(0,1)->setTextAlignment(Qt::AlignCenter);  //设置条目居中对齐


/*将数据模型的第一列进行下降排序(从大到小,不会进行整行排序)*/
model.sort(0,Qt::DescendingOrder);
/*根据视图里的第一列数据,进行整行大小排序*/ 
 view.sortByColumn(0); 
/*设置视图能够自动使能排序*/
view.setSortingEnabled(true); 
/*设置视图是否支持自动滑动*/ 
view.setAutoScroll(bool enable);    
/*设置选中一行后,标题的字体不会加粗*/
view->horizontalHeader()->setHighlightSections(false); 
/*设置列宽不可变动,在5.X后改为了setSectionResizeMode()*/
view.horizontalHeader()->setResizeMode(QHeaderView::Fixed);

/*设置行宽不可变动*/
view.verticalHeader()->setResizeMode(QHeaderView::Fixed); 
/*设置用户选择模式, NoSelection表示不能选择表格*/ view.setSelectionMode(QAbstractItemView::NoSelection);  
/*隐藏垂直标题*/ 
view.verticalHeader()->hide();  

view.setSelectionMode(QAbstractItemView::SingleSelection);                //设置选择模式,表示只能选中单个  
view.setSelectionBehavior(QAbstractItemView::SelectRows);                      //设置选择行为,表示只能选择一行(也可以设置为列,或者单个Item项目) 

/*设置表格不可编辑*/
view.setEditTriggers(QAbstractItemView::NoEditTriggers);
/*设置表头的显示与隐藏*/
view.horizontalHeader()->setVisible(false);
view.verticalHeader()->setVisible(false);

/*禁止显示网格线*/
view.setShowGrid(false);

/*禁止显示滚动条*/
view.setHorizontalScrollBarPolicy(Qt::ScrollBarAlwaysOff);

/*设置行列的高宽*/
view.setColumnWidth(0,50);       //设置column0(第1列)的宽度为50,必须要设置好model后,再来设置宽度  
view.setRowHeight(0,30);          //设置row0(第1行)的高度为30,必须setModel()后,再来设置高度
view.resizeRowsToContents();    //更据当前内容自动调整行距
view.resizeColumnsToContents(); //更据当前内容自动调整列距 /*禁止焦点(取消QTableView选中后的虚线框)*/  view.setFocusPolicy(Qt::NoFocus); /*获取鼠标当前位于视图的哪个index位置*/qDebug()<<view.currentIndex().row();  //获取行号,如果为-1,表示无效qDebug()<<view.currentIndex().column();//获取列号,如果为-1,表示无效  
void QTableView::setSpan(int row, int column, int rowSpanCount, int columnSpanCount);
//合并单元格
//第一个参数:要改变的单元格行数
//第二个参数:要改变的单元格列数
//第三个参数:需要合并的行数
//第四个参数:需要合并的列数
//比如: setSpan(0,0,2,3);   表示从table(0,0)开始到2,3结束,合并共2行和3列  
void setVerticalScrollMode(QAbstractItemView::ScrollMode mode);//设置滑动模式.可以设置按行滑动,还是按像素点来滑动

 

合并单元格提醒

数据更新后,还要继续使用setSpan再次合并(主要是要对全表格进行重新的单元格合并,已经合并过的地方行列又要重新进行新的合并,因为数据已经更新),这时不能直接使用setSpan,而是要先把QTableView的row还原为原来没有合并行列的情形,再次使用setSpan

对于QStandardItemsetData()成员 函数的第二个参数role 是模型数据角色 

当role值不同时,则显示在视图上的方式也会不同

对于role角色,常用的值有:

  • Qt::DisplayRole      0         以文本方式显示数据(QString)
  • Qt::DecorationRole       1     将数据作为图标来装饰(QIcon,QPixmap)
  • Qt::EditRole      2                可编辑的数据信息显示(QString)
  • Qt::ToolTipRole      3         作为工具提示显示(QString)
  • Qt::StatusTipRole   4         作为状态栏中显示的数据(QString)
  • Qt::WhatsThisRole 5            作为帮助信息栏中显示的数据(QString)
  • Qt::FontRole        6              设置字体(QFont)
  • Qt::TextAlignmentRole   7     设置模型数据的文本对齐(Qt::AlignmentFlag)
  • Qt::BackgroundRole      8     设置模型数据的背景色(QBrush)
  • Qt::ForegroundRole      9     设置模型数据的前景色,比如字体(QBrush)

实现右击菜单

当用户在QTableView视图里右击鼠标时,便会触发一个QEvent::ContextMenu类型的事件,所以通过事件过滤器来实现右击菜单效果

步骤:

  • 定义菜单对象(QMenu)
  • 通过QMenu的addAction()函数,添加子项,并连接到槽函数
  • 定义事件过滤器,判断是否是QTableView的QEvent::ContextMenu事件
  • 判断成功,则调用menu.exec(cursor().pos()),在当前鼠标位置打开菜单

效果:

代码如下

Widget.h:

#ifndef WIDGET_H
#define WIDGET_H
#include <QtGui>

class Widget : public QWidget
{
    Q_OBJECT

    QTableView  view;
    QStandardItemModel model;
    QMenu   menu;

public:
    explicit Widget(QWidget *parent = 0);
    bool eventFilter(QObject* obj, QEvent *evt);

public slots:
    void onDelete(void);
};

#endif // WIDGET_H

Widget.cpp:

#include "widget.h"

Widget::Widget(QWidget *parent) :
    QWidget(parent),
    view(this),
    model(this),
    menu(this)
{
    model.setItem(0,0, new QStandardItem("A"));
    model.setItem(0,1, new QStandardItem("B"));
    model.setItem(1,0, new QStandardItem("C"));
    model.setItem(1,1, new QStandardItem("D"));
    model.setItem(2,0, new QStandardItem("E"));
    model.setItem(2,1, new QStandardItem("F"));
    model.setItem(3,0, new QStandardItem("G"));
    model.setItem(3,1, new QStandardItem("H"));

    /*设置视图只能选中一行,取消焦点,禁止编辑*/
    view.setFocusPolicy(Qt::NoFocus);
    view.setEditTriggers(QAbstractItemView::NoEditTriggers);
    view.setSelectionMode(QAbstractItemView::SingleSelection);
    view.setSelectionBehavior(QAbstractItemView::SelectRows);
    view.setModel(&model);

    view.installEventFilter(this);         

    menu.addAction("删除",this,SLOT(onDelete()));     //设置菜单项,并连接槽函数
}

void Widget::onDelete(void)
{
    model.removeRow(view.currentIndex().row());   //更据当前鼠标所在的索引的行位置,删除一行
}

bool Widget::eventFilter(QObject* obj, QEvent *evt)
{
    if(obj == &view  &&  evt->type() == QEvent::ContextMenu)
    {
        if(view.currentIndex().isValid()==true)
        {
              menu.exec(cursor().pos());           //在当前鼠标位置上运行菜单menu对象
        }
    }
    return QWidget::eventFilter(obj,evt);
}

main函数:

int main(int argc, char *argv[])
{
    QApplication a(argc, argv);
    Widget w;
    w.show();
    return a.exec();
}
对于QTableView,可以通过使用QMenu和QAction来实现右键菜单。以下是一个简单的示例代码: ```python from PyQt5.QtWidgets import QApplication, QMainWindow, QTableView, QMenu, QAction, QMessageBox from PyQt5.QtCore import Qt class MainWindow(QMainWindow): def __init__(self): super().__init__() self.setWindowTitle("QTableView右键菜单示例") # 创建QTableView self.table_view = QTableView(self) self.setCentralWidget(self.table_view) # 创建右键菜单 self.context_menu = QMenu(self.table_view) self.delete_action = QAction("删除", self) self.context_menu.addAction(self.delete_action) # 绑定右键菜单信号 self.table_view.setContextMenuPolicy(Qt.CustomContextMenu) self.table_view.customContextMenuRequested.connect(self.show_context_menu) # 绑定删除动作的槽函数 self.delete_action.triggered.connect(self.delete_row) def show_context_menu(self, pos): # 显示右键菜单 global_pos = self.table_view.mapToGlobal(pos) self.context_menu.exec_(global_pos) def delete_row(self): # 获取当前选中的行 selected_row = self.table_view.currentIndex().row() if selected_row >= 0: # 在这里编写删除行的代码 QMessageBox.information(self, "提示", "删除行:" + str(selected_row)) if __name__ == "__main__": app = QApplication([]) window = MainWindow() window.show() app.exec_() ``` 这个例子创建了一个带有QTableView的主窗口,并在QTableView实现了一个右键菜单。右键菜单有一个"删除"动作,当用户选择该动作时,会弹出一个消息框显示删除的行号。 你可以根据实际需求修改和扩展这个示例代码,来满足你的具体需求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

诺谦

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值