QTabWidget的常用属性设置。
table->horizontalScrollBar()->setVisible(false);
table->verticalScrollBar()->setVisible(false);
table->setSelectionBehavior(QAbstractItemView::SelectRows);
table->setEditTriggers(QAbstractItemView::NoEditTriggers);
table->setColumnCount(3);
table->setShowGrid(false);
table->setColumnWidth(0, 20);
table->setColumnWidth(1, 128);
table->setColumnWidth(2, 20);
table->horizontalHeader()->setHidden(true);
table->verticalHeader()->setHidden(true);
QStringList header; header<<"子系统路口"<<"上移";
table->setHorizontalHeaderLabels(header);
table->horizontalHeader()->setSectionResizeMode(QHeaderView::Stretch);
table->horizontalHeader()->setSectionResizeMode(1, QHeaderView::ResizeToContents);
table->setContextMenuPolicy(Qt::CustomContextMenu);
connect(table, SIGNAL(customContextMenuRequested ( const QPoint&)), this , SLOT(rightClickedOperationPRJ(const QPoint&))); //右键
1)方式1:直接在创建QTableWidgetItem的时候创建,如
tableWdiget->setItem(0,1,new QTableWidgetItem(QIcon(":/image/cpu")," "));
2)方式2:通过在item中创建一个label,通过label的setPixMap函数来显示图片:
QLabel *label = new QLabel("");
label->setPixmap(QPixmap(":/image/grid").scaled(30,30));
ui->matrixViewTable->setCellWidget(0,i,label);
3)方式3:通过继承 QStyledItemDelegate类使用委托来实现item中显示图片:
class QPixmapItemdele : public QStyledItemDelegate
{
public:
QPixmapItemdele(QObject* parent = 0):QStyledItemDelegate(parent){ }
//在委托类的paint中画图
virtual void paint(QPainter *painter, const QStyleOptionViewItem &option, const QModelIndex &index) const
{
if(index.data(Qt::DisplayRole).canConvert<QPixmap>())
{
QPixmap pix = index.data(Qt::DisplayRole).value<QPixmap>();
painter->drawPixmap(option.rect,pix);
}
QStyledItemDelegate::paint(painter,option,index);
}
};
然后为tablewidget设置委托,后面就可以设置具体的某项的图片:
ui->matrixViewTable->setItemDelegate(new QPixmapItemdele());
//以下是设置第一行的所有列的图片
for(int i=0; i<ui->matrixViewTable->columnCount(); i++)
{
QTableWidgetItem *item = new QTableWidgetItem();
ui->matrixViewTable->setItem(0,i,item);
item->setData(Qt::DisplayRole,QVariant::fromValue<QPixmap>(QPixmap(":/image/grid").scaled(30,30)));
}
以上三种方法:
方法一直接在item上创建Icon,则表中每个Item表示为左边icon,右边为icon对应的text,即使text为空,也会留出很大的空间出来,导致左边的icon很小,
可以用以下语句来设置左边图标大小:
ui->matrixViewTable->setIconSize(QSize(30,30));
但是右边还是有text留出来的空间,如果想让icon充满整个item,则此方法没法达成。
方法二通过item中创建label来setPixMap的方式可以让icon充满整个item,但是显示出来的icon用鼠标点击不会有选择动作发生,或者也许可以处理点击事件(未试过,不知是否能行)。
方法三继承委托能够让图片充满整个item,同时选择图片时,会出现选择框,不至于像法二一样点击了没有任何反应。
table->item(0, 0)->setTextAlignment(Qt::AlignCenter);
table->item(0, 1)->setTextAlignment(Qt::AlignCenter);
table->item(0, 0)->setForeground(QBrush(QColor(255, 0, 0)));
table->item(0, 1)->setForeground(QBrush(QColor(255, 0, 0)));
table->item(0, 0)->setFont( QFont( "Times", 10, QFont::Black ) );
table->item(0, 1)->setFont( QFont( "Times", 10, QFont::Black ) );
table->sort(3, Qt::DescendingOrder);
ui->tableView->resizeRowsToContents();//所有行高度自适应
ui->tableView->resizeColumnsToContents();//所有行宽度自适应