设置
QTableWidget *tb = ui->tableWidget;
tb->setSelectionBehavior(QAbstractItemView::SelectRows);
tb->setSelectionMode(QAbstractItemView::SingleSelection);
操作
QTableWidget *tb = ui->tableWidget;
int curRow=tb->currentRow(); //当前行号
tb->removeRow(curRow); //删除当前行及其items
设置
QTableWidget *tb = ui->tableWidget;
tb->setSelectionBehavior(QAbstractItemView::SelectRows);
tb->setSelectionMode(QAbstractItemView::ExtendedSelection);
操作
QTableWidget *tb = ui->tableWidget;
QItemSelectionModel *m_selection = tb->selectionModel();
QModelIndexList indexList = m_selection->selectedIndexes();
QList<int> list;
int prev =-1,curr=-1;
if(indexList.length()>1){
//预处理第一行
prev = indexList.at(0).row();
list.append(prev);
for(int i=1;i<indexList.length();i++){
//qDebug() <<"row: "<< indexList.at(i).row() <<"column: "<
curr = indexList.at(i).row();
if(prev ==curr){
continue;
}else{
prev = curr;
list.append(prev);
}
}
}else if(indexList.length()==1){
list.append(indexList.at(0).row());
}else{
return;
}
//从大到小排序,必须从最后一行 往前删除 不然会打乱顺序
std::sort(list.rbegin(),list.rend());
//根据填充到的数据 删除选中列
for(int j = 0; j <list.size(); j++)
{
int cc = list.at(j);
tb->removeRow(cc); //删除当前行及其items
}
无需设置setSelectionBehavior(QAbstractItemView::SelectRows)
,但是可以选择的那一列最好设置为不可编辑。按下Ctrl键,选择多行。
设置1
tableView->setSelectionMode(QAbstractItemView::ExtendedSelection);//选择模式
m_selection = new QItemSelectionModel(m_model,this); //创建选择模型
tableView->setSelectionModel(m_selection); //设置选择模型
设置2
QStandardItem *item1 = new QStandardItem("aa1");
item1->setEditable(false);
QStandardItem *item2 = new QStandardItem("aa2");
item2->setEditable(false);
QList<QStandardItem *> list = {item1,item2};
model->appendRow(list);
操作
QModelIndexList indexList = m_selection->selectedIndexes();
QList<int> list;
int sameColumn=-1;
for(int i=0;i<indexList.length();i++){
if(i==0){sameColumn=indexList.at(i).column();}
//qDebug() <<"row: "<< indexList.at(i).row() <<"column: "<
if(sameColumn!=indexList.at(i).column()){
//上面currentColumnChanged信号其实已经让用户只能选择同一列,这里双重保险
qDebug()<<"你的选择有不同列,请务必选择同一列的不同行来进行多行删除操作";
return;
}
list.append(indexList.at(i).row());
}
//从大到小排序,必须从最后一行 往前删除 不然会打乱顺序
std::sort(list.rbegin(),list.rend());
//根据填充到的数据 删除选中列
for(int j = 0; j <list.size(); j++)
{
int cc = list.at(j);
m_model->removeRow(cc);
}
QTableWidgetSelectionRange是Qt框架中用于表示QTableWidget中选定的一块单元格区域的类。以下是如何使用QTableWidgetSelectionRange的一些常见操作:
QList<QTableWidgetSelectionRange> ranges = tableWidget->selectedRanges();
if (!ranges.isEmpty()) {
int startRow = ranges.first().topRow();
int startColumn = ranges.first().leftColumn();
int rowCount = ranges.first().rowCount();
int columnCount = ranges.first().columnCount();
}
foreach (const QTableWidgetSelectionRange &range, ranges) {
int startRow = range.topRow();
int startColumn = range.leftColumn();
int rowCount = range.rowCount();
int columnCount = range.columnCount();
// 进行处理...
}
QTableWidgetSelectionRange range(1, 1, 3, 3); // 定义一个起始行为1,起始列为1,行数和列数为3的区域
if (tableWidget->selectedRanges().contains(range)) {
// 区域被选定
}
tableWidget->clearSelection();
QTableWidgetSelectionRange类提供了一种方便的方式来处理QTableWidget中的选择区域。使用它可以获取和操作选定的单元格区域,进行相关的处理和操作。
QTableWidget通过setSelectionMode()
和SelectionBehavior
来设置选择模式
enum QAbstractItemView::SelectionBehavior
Constant | Value | Description |
---|---|---|
QAbstractItemView::SelectItems | 0 | Selecting single items. |
QAbstractItemView::SelectRows | 1 | Selecting only rows. |
QAbstractItemView::SelectColumns | 2 | Selecting only columns. |
enum QAbstractItemView::SelectionMode
此枚举指示视图如何响应用户选择:
Constant | Value | Description |
---|---|---|
QAbstractItemView::SingleSelection | 1 | When the user selects an item, any already-selected item becomes unselected. It is possible for the user to deselect the selected item by pressing the Ctrl key when clicking the selected item. |
QAbstractItemView::ContiguousSelection | 4 | When the user selects an item in the usual way, the selection is cleared and the new item selected. However, if the user presses the Shift key while clicking on an item, all items between the current item and the clicked item are selected or unselected, depending on the state of the clicked item. |
QAbstractItemView::ExtendedSelection | 3 | When the user selects an item in the usual way, the selection is cleared and the new item selected. However, if the user presses the Ctrl key when clicking on an item, the clicked item gets toggled and all other items are left untouched. If the user presses the Shift key while clicking on an item, all items between the current item and the clicked item are selected or unselected, depending on the state of the clicked item. Multiple items can be selected by dragging the mouse over them. |
QAbstractItemView::MultiSelection | 2 | When the user selects an item in the usual way, the selection status of that item is toggled and the other items are left alone. Multiple items can be toggled by dragging the mouse over them. |
QAbstractItemView::NoSelection | 0 | Items cannot be selected. |