mirror of
				https://github.com/subsurface/subsurface.git
				synced 2025-02-19 22:16:15 +00:00 
			
		
		
		
	Also hold a pointer to the struct picture on the model.
Changes to hold a pointer to the struct picture on the model, so we can use it to determine the correct positioning of the image on the profile. Signed-off-by: Tomaz Canabrava <tomaz.canabrava@intel.com> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
This commit is contained in:
		
							parent
							
								
									43cf9fdb7a
								
							
						
					
					
						commit
						b1847f9ebb
					
				
					 2 changed files with 23 additions and 8 deletions
				
			
		|  | @ -43,15 +43,17 @@ void DivePictureModel::updateDivePictures(int divenr) | ||||||
| 		return; | 		return; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | 	stringPixmapCache.clear(); | ||||||
| 	QStringList pictures; | 	QStringList pictures; | ||||||
| 	FOR_EACH_PICTURE( d ) { | 	FOR_EACH_PICTURE( d ) { | ||||||
|  | 		stringPixmapCache[QString(picture->filename)].picture = picture; | ||||||
| 		pictures.push_back(QString(picture->filename)); | 		pictures.push_back(QString(picture->filename)); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	stringPixmapCache.clear(); | 
 | ||||||
| 	SPixmapList retList = QtConcurrent::blockingMapped<SPixmapList>( pictures, scaleImages); | 	SPixmapList retList = QtConcurrent::blockingMapped<SPixmapList>( pictures, scaleImages); | ||||||
| 	Q_FOREACH(const SPixmap & pixmap, retList) | 	Q_FOREACH(const SPixmap & pixmap, retList) | ||||||
| 		stringPixmapCache[pixmap.first] = pixmap.second; | 		stringPixmapCache[pixmap.first].image = pixmap.second; | ||||||
| 
 | 
 | ||||||
| 	beginInsertRows(QModelIndex(), 0, numberOfPictures-1); | 	beginInsertRows(QModelIndex(), 0, numberOfPictures-1); | ||||||
| 	endInsertRows(); | 	endInsertRows(); | ||||||
|  | @ -59,7 +61,7 @@ void DivePictureModel::updateDivePictures(int divenr) | ||||||
| 
 | 
 | ||||||
| int DivePictureModel::columnCount(const QModelIndex &parent) const | int DivePictureModel::columnCount(const QModelIndex &parent) const | ||||||
| { | { | ||||||
| 	return 1; | 	return 2; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| QVariant DivePictureModel::data(const QModelIndex &index, int role) const | QVariant DivePictureModel::data(const QModelIndex &index, int role) const | ||||||
|  | @ -69,10 +71,17 @@ QVariant DivePictureModel::data(const QModelIndex &index, int role) const | ||||||
| 		return ret; | 		return ret; | ||||||
| 
 | 
 | ||||||
| 	QString key = stringPixmapCache.keys().at(index.row()); | 	QString key = stringPixmapCache.keys().at(index.row()); | ||||||
| 	switch(role){ | 	if(index.column() == 0){ | ||||||
| 		case Qt::ToolTipRole : ret = key; break; | 		switch(role){ | ||||||
| 		case Qt::DecorationRole : ret = stringPixmapCache[key]; break; | 			case Qt::ToolTipRole : ret = key; break; | ||||||
| 		case Qt::DisplayRole : ret = QFileInfo(key).fileName(); | 			case Qt::DecorationRole : ret = stringPixmapCache[key].image; break; | ||||||
|  | 			case Qt::DisplayRole : ret = QFileInfo(key).fileName(); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	else if (index.column() == 1){ | ||||||
|  | 		switch(role){ | ||||||
|  | 			case Qt::UserRole : ret = QVariant::fromValue( (void*) stringPixmapCache[key].picture); | ||||||
|  | 		} | ||||||
| 	} | 	} | ||||||
| 	return ret; | 	return ret; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -6,6 +6,12 @@ | ||||||
| #include <QListView> | #include <QListView> | ||||||
| #include <QThread> | #include <QThread> | ||||||
| 
 | 
 | ||||||
|  | struct picture; | ||||||
|  | struct PhotoHelper{ | ||||||
|  | 	QImage image; | ||||||
|  | 	struct picture *picture; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
| class DivePictureModel : public QAbstractTableModel { | class DivePictureModel : public QAbstractTableModel { | ||||||
| Q_OBJECT | Q_OBJECT | ||||||
| public: | public: | ||||||
|  | @ -20,7 +26,7 @@ private: | ||||||
| 	// Currently, load the images on the fly
 | 	// Currently, load the images on the fly
 | ||||||
| 	// Later, use a thread to load the images
 | 	// Later, use a thread to load the images
 | ||||||
| 	// Later, save the thumbnails so we don't need to reopen every time.
 | 	// Later, save the thumbnails so we don't need to reopen every time.
 | ||||||
| 	QHash<QString, QImage> stringPixmapCache; | 	QHash<QString, PhotoHelper> stringPixmapCache; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| class DivePictureDelegate : QStyledItemDelegate { | class DivePictureDelegate : QStyledItemDelegate { | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue