我有一个与QSqlTableModel连接的QTableView
在第一列中,只有这种格式的日期:2010-01-02
我希望此列以此格式显示日期(但不更改实际数据):02.01.2010
我知道我必须为这个列创建一个QItemDelegate,但我不知道如何读取现有数据并用不同的东西覆盖它。你知道如何管理它吗?
答案 0 :(得分:15)
最简单的解决方案是创建一个QStyledItemDelegate
子类并重新实现displayText(...)
即
class DateFormatDelegate : public QStyledItemDelegate
{
public:
DateFormatDelegate (QString dateFormat, QObject *parent = 0) :
QStyledItemDelegate(parent),
m_dateFormat(dateFormat)
{
}
virtual QString displayText(const QVariant & value, const QLocale & locale ) const
{
Q_UNUSED(locale);
return value.toDate().toString(m_dateFormat);
}
private:
QString m_dateFormat;
};
然后在你看来 -
setItemDelegateForColumn(/*date column*/, new DateFormatDelegate("MM.dd.yyyy", this));
答案 1 :(得分:4)
项目委托不一定会更改数据,只是呈现数据。此外,如果您使用的是Qt 4.4或更新版本,请查看QStyledItemDelegate - 它的主题感知并且看起来更好。
this article中有一个项目代表的例子(这似乎是官方文档的镜像,现在已经失败或消失了。)
由于您真正想要的是自定义文本,您是否考虑使用代理模型而只返回日期列的DisplayRole的自定义QString?