鄙人尝试着用QTreeView实现了一下缩略图的功能。用QTreeView 实现图片文件缩略图功能与QTreeWidget有些不同,不是在view里面动手脚,而是在FileSystemModel中通过 QFileIconProvider改变文件的图标。
这时需要通过重写QFileIconProvider 类中的 函数:
QIcon QFileIconProvider::icon(const QFileInfo & info) const
该函数在初始化QFileSystmModel对象时由内部自动调用,不需要我们关心具体细节,我们只需要知道该函数传入值是文件信息,传出值是相应文件的图标QIcon对象。为了实现缩略图的显示,我们需要做的就是判断文件是否是图片格式,是的话用url生成QIcon对象并返回。函数代码如下:
QIcon DBFileIconProvider::icon(const QFileInfo & info) const
{
QString str = info.filePath();
//! 当文件为非目录时加入图标
if(!QFileInfo(info.filePath()).isDir())
{
//! 判断文件是否是图片格式
if( info.suffix().compare("jpg",Qt::CaseInsensitive)==0 ||
info.suffix().compare("bmp",Qt::CaseInsensitive)==0 ||
info.suffix().compare("png",Qt::CaseInsensitive)==0 ||
info.suffix().compare("jpeg",Qt::CaseInsensitive)==0 )
{
//! 通过url创建QIcon
QIcon myIcon(info.filePath());
return myIcon;
}
}
//! 返回默认
return QFileIconProvider::icon(info);
}
DBFileIconProvider是我自己继承QFileIconProvider的一个类。有了这个类后,在model和view绑定在一块的时候只需要这样:
//!初始化QFileSystemModel
m_fileSystemModel = new QFileSystemModel();
QStringList filters;
m_fileSystemModel->setNameFilters(filters << "*.png" << "*.jpg" << "*.jpeg" <<"*.bmp"<<"*.plist");
m_fileSystemModel->setNameFilterDisables(false); //!< 设置过滤器
//! 创建自己的FileIconProvider,并赋给fileSystemModel
QFileIconProvider * pIconProvider = new DBFileIconProvider();
m_fileSystemModel->setIconProvider(pIconProvider);
效果图:
之后实现 ctrl+ 鼠标滚轮改变图片大小只需重写wheelEvent函数,在其中调用setIconSize()函数即可。