Store database icons as QImage instead of QIcon.

This has the advantage that they can be used without a running X server.
Add methods to retrieve QPixmaps that are converted from the stored QImages
and cached by QPixmapCache.
This commit is contained in:
Felix Geyer
2012-01-01 21:52:54 +01:00
parent fdf600e09a
commit 00aafa69f5
15 changed files with 137 additions and 60 deletions

View File

@@ -20,7 +20,6 @@
#include <QtCore/QDateTime>
#include <QtCore/QHash>
#include <QtGui/QIcon>
#include "core/Uuid.h"
#include "keys/CompositeKey.h"

View File

@@ -19,20 +19,40 @@
#include "core/DataPath.h"
DatabaseIcons* DatabaseIcons::m_instance(0);
QIcon DatabaseIcons::icon(int index)
QImage DatabaseIcons::icon(int index)
{
if (index < 0 || index >= iconCount()) {
qWarning("DatabaseIcons::icon: invalid icon index %d", index);
return QIcon();
return QImage();
}
if (!m_instance) {
m_instance = new DatabaseIcons();
if (!m_iconCache[index].isNull()) {
return m_iconCache[index];
}
else {
QString iconPath = QString("icons/database/").append(m_indexToName.at(index));
QImage icon(DataPath::getPath(iconPath));
m_iconCache[index] = icon;
return icon;
}
}
QPixmap DatabaseIcons::iconPixmap(int index)
{
if (index < 0 || index >= iconCount()) {
qWarning("DatabaseIcons::iconPixmap: invalid icon index %d", index);
return QPixmap();
}
return m_instance->getIconInternal(index);
QPixmap pixmap;
if (!QPixmapCache::find(m_pixmapCacheKeys[index], &pixmap)) {
pixmap = QPixmap::fromImage(icon(index));
m_pixmapCacheKeys[index] = QPixmapCache::insert(pixmap);
}
return pixmap;
}
int DatabaseIcons::iconCount()
@@ -42,6 +62,7 @@ int DatabaseIcons::iconCount()
DatabaseIcons::DatabaseIcons()
{
m_indexToName.reserve(iconCount());
m_indexToName.append("C00_Password.png");
m_indexToName.append("C01_Package_Network.png");
m_indexToName.append("C02_MessageBox_Warning.png");
@@ -113,18 +134,20 @@ DatabaseIcons::DatabaseIcons()
m_indexToName.append("C68_BlackBerry.png");
Q_ASSERT(m_indexToName.size() == iconCount());
m_iconCache.reserve(iconCount());
m_iconCache.resize(iconCount());
m_pixmapCacheKeys.reserve(iconCount());
m_pixmapCacheKeys.resize(iconCount());
}
QIcon DatabaseIcons::getIconInternal(int index)
DatabaseIcons* databaseIcons()
{
if (m_iconCache.contains(index)) {
return m_iconCache.value(index);
}
else {
QString iconPath = QString("icons/database/").append(m_indexToName.at(index));
QIcon icon(DataPath::getPath(iconPath));
static DatabaseIcons* instance(0);
m_iconCache.insert(index, icon);
return icon;
if (!instance) {
instance = new DatabaseIcons();
}
return instance;
}

View File

@@ -18,25 +18,28 @@
#ifndef KEEPASSX_DATABASEICONS_H
#define KEEPASSX_DATABASEICONS_H
#include <QtCore/QHash>
#include <QtGui/QIcon>
#include <QtCore/QVector>
#include <QtGui/QImage>
#include <QtGui/QPixmap>
#include <QtGui/QPixmapCache>
class DatabaseIcons
{
public:
static QIcon icon(int index);
static int iconCount();
private:
static DatabaseIcons* m_instance;
QImage icon(int index);
QPixmap iconPixmap(int index);
int iconCount();
private:
DatabaseIcons();
QIcon getIconInternal(int index);
bool m_initalized;
QList<QString> m_indexToName;
QHash<int,QIcon> m_iconCache;
QVector<QString> m_indexToName;
QVector<QImage> m_iconCache;
QVector<QPixmapCache::Key> m_pixmapCacheKeys;
friend DatabaseIcons* databaseIcons();
};
DatabaseIcons* databaseIcons();
#endif // KEEPASSX_DATABASEICONS_H

View File

@@ -52,10 +52,10 @@ Uuid Entry::uuid() const
return m_uuid;
}
QIcon Entry::icon() const
QImage Entry::icon() const
{
if (m_customIcon.isNull()) {
return DatabaseIcons::icon(m_iconNumber);
return databaseIcons()->icon(m_iconNumber);
}
else {
// TODO check if m_db is 0
@@ -63,6 +63,23 @@ QIcon Entry::icon() const
}
}
QPixmap Entry::iconPixmap() const
{
if (m_customIcon.isNull()) {
return databaseIcons()->iconPixmap(m_iconNumber);
}
else {
QPixmap pixmap;
if (!QPixmapCache::find(m_pixmapCacheKey, &pixmap)) {
// TODO check if m_db is 0
pixmap = QPixmap::fromImage(m_db->metadata()->customIcon(m_customIcon));
*const_cast<QPixmapCache::Key*>(&m_pixmapCacheKey) = QPixmapCache::insert(pixmap);
}
return pixmap;
}
}
int Entry::iconNumber() const
{
return m_iconNumber;
@@ -176,6 +193,8 @@ void Entry::setIcon(int iconNumber)
m_iconNumber = iconNumber;
m_customIcon = Uuid();
m_pixmapCacheKey = QPixmapCache::Key();
}
void Entry::setIcon(const Uuid& uuid)
@@ -184,6 +203,8 @@ void Entry::setIcon(const Uuid& uuid)
m_iconNumber = 0;
m_customIcon = uuid;
m_pixmapCacheKey = QPixmapCache::Key();
}
void Entry::setForegroundColor(const QColor& color)

View File

@@ -23,7 +23,9 @@
#include <QtCore/QSet>
#include <QtCore/QUrl>
#include <QtGui/QColor>
#include <QtGui/QIcon>
#include <QtGui/QImage>
#include <QtGui/QPixmap>
#include <QtGui/QPixmapCache>
#include "core/TimeInfo.h"
#include "core/Uuid.h"
@@ -45,7 +47,8 @@ public:
Entry();
~Entry();
Uuid uuid() const;
QIcon icon() const;
QImage icon() const;
QPixmap iconPixmap() const;
int iconNumber() const;
Uuid iconUuid() const;
QColor foregroundColor() const;
@@ -125,6 +128,7 @@ private:
QList<Entry*> m_history;
QPointer<Group> m_group;
const Database* m_db;
QPixmapCache::Key m_pixmapCacheKey;
const static QStringList m_defaultAttibutes;
};

View File

@@ -55,16 +55,34 @@ QString Group::notes() const
return m_notes;
}
QIcon Group::icon() const
QImage Group::icon() const
{
if (m_customIcon.isNull()) {
return DatabaseIcons::icon(m_iconNumber);
return databaseIcons()->icon(m_iconNumber);
}
else {
// TODO check if m_db is 0
return m_db->metadata()->customIcon(m_customIcon);
}
}
QPixmap Group::iconPixmap() const
{
if (m_customIcon.isNull()) {
return databaseIcons()->iconPixmap(m_iconNumber);
}
else {
QPixmap pixmap;
if (!QPixmapCache::find(m_pixmapCacheKey, &pixmap)) {
// TODO check if m_db is 0
pixmap = QPixmap::fromImage(m_db->metadata()->customIcon(m_customIcon));
*const_cast<QPixmapCache::Key*>(&m_pixmapCacheKey) = QPixmapCache::insert(pixmap);
}
return pixmap;
}
}
int Group::iconNumber() const
{
return m_iconNumber;
@@ -129,6 +147,8 @@ void Group::setIcon(int iconNumber)
m_iconNumber = iconNumber;
m_customIcon = Uuid();
m_pixmapCacheKey = QPixmapCache::Key();
Q_EMIT dataChanged(this);
}
@@ -139,6 +159,8 @@ void Group::setIcon(const Uuid& uuid)
m_iconNumber = 0;
m_customIcon = uuid;
m_pixmapCacheKey = QPixmapCache::Key();
Q_EMIT dataChanged(this);
}

View File

@@ -19,7 +19,9 @@
#define KEEPASSX_GROUP_H
#include <QtCore/QPointer>
#include <QtGui/QIcon>
#include <QtGui/QImage>
#include <QtGui/QPixmap>
#include <QtGui/QPixmapCache>
#include "core/Database.h"
#include "core/Entry.h"
@@ -38,7 +40,8 @@ public:
Uuid uuid() const;
QString name() const;
QString notes() const;
QIcon icon() const;
QImage icon() const;
QPixmap iconPixmap() const;
int iconNumber() const;
Uuid iconUuid() const;
TimeInfo timeInfo() const;
@@ -109,6 +112,7 @@ private:
QList<Entry*> m_entries;
QPointer<Group> m_parent;
QPixmapCache::Key m_pixmapCacheKey;
friend void Database::setRootGroup(Group* group);
friend Entry::~Entry();

View File

@@ -120,12 +120,12 @@ bool Metadata::autoEnableVisualHiding() const
return m_autoEnableVisualHiding;
}
QIcon Metadata::customIcon(const Uuid& uuid) const
QImage Metadata::customIcon(const Uuid& uuid) const
{
return m_customIcons.value(uuid);
}
QHash<Uuid, QIcon> Metadata::customIcons() const
QHash<Uuid, QImage> Metadata::customIcons() const
{
return m_customIcons;
}
@@ -257,7 +257,7 @@ void Metadata::setAutoEnableVisualHiding(bool value)
m_autoEnableVisualHiding = value;
}
void Metadata::addCustomIcon(const Uuid& uuid, const QIcon& icon)
void Metadata::addCustomIcon(const Uuid& uuid, const QImage& icon)
{
Q_ASSERT(!uuid.isNull());
Q_ASSERT(!m_customIcons.contains(uuid));

View File

@@ -20,7 +20,7 @@
#include <QtCore/QDateTime>
#include <QtCore/QHash>
#include <QtGui/QIcon>
#include <QtGui/QImage>
#include "core/Uuid.h"
@@ -48,8 +48,8 @@ public:
bool protectUrl() const;
bool protectNotes() const;
bool autoEnableVisualHiding() const;
QIcon customIcon(const Uuid& uuid) const;
QHash<Uuid, QIcon> customIcons() const;
QImage customIcon(const Uuid& uuid) const;
QHash<Uuid, QImage> customIcons() const;
bool recycleBinEnabled() const;
const Group* recycleBin() const;
QDateTime recycleBinChanged() const;
@@ -76,7 +76,7 @@ public:
void setProtectUrl(bool value);
void setProtectNotes(bool value);
void setAutoEnableVisualHiding(bool value);
void addCustomIcon(const Uuid& uuid, const QIcon& icon);
void addCustomIcon(const Uuid& uuid, const QImage& icon);
void removeCustomIcon(const Uuid& uuid);
void setRecycleBinEnabled(bool value);
void setRecycleBin(Group* group);
@@ -113,7 +113,7 @@ private:
bool m_protectNotes;
bool m_autoEnableVisualHiding;
QHash<Uuid, QIcon> m_customIcons;
QHash<Uuid, QImage> m_customIcons;
bool m_recycleBinEnabled;
Group* m_recycleBin;