summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Giuseppe Bilotta <giuseppe.bilotta@gmail.com>2014-10-15 15:30:50 +0200
committerGravatar Dirk Hohndel <dirk@hohndel.org>2014-10-18 15:16:07 -0700
commit5a2db2db4b31b37da5661db893d60619587e5a68 (patch)
treeae71523879f50fd033de01a72e23a3a60b707a8d
parentf18bcd66072c115456d98a8aeb87500b2ca8e642 (diff)
downloadsubsurface-5a2db2db4b31b37da5661db893d60619587e5a68.tar.gz
Define auxiliary functions for metrics
Collect font, font metrics and icon size functions in a separate module. Signed-off-by: Giuseppe Bilotta <giuseppe.bilotta@gmail.com> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
-rw-r--r--qt-ui/metrics.cpp32
-rw-r--r--qt-ui/metrics.h21
-rw-r--r--qt-ui/models.cpp7
-rw-r--r--qt-ui/models.h4
-rw-r--r--subsurface.pro2
5 files changed, 57 insertions, 9 deletions
diff --git a/qt-ui/metrics.cpp b/qt-ui/metrics.cpp
new file mode 100644
index 000000000..49e27849f
--- /dev/null
+++ b/qt-ui/metrics.cpp
@@ -0,0 +1,32 @@
+/*
+ * metrics.cpp
+ *
+ * methods to find/compute essential UI metrics
+ * (font properties, icon sizes, etc)
+ *
+ */
+
+#include "metrics.h"
+
+QFont defaultModelFont()
+{
+ QFont font;
+// font.setPointSizeF(font.pointSizeF() * 0.8);
+ return font;
+}
+
+QFontMetrics defaultModelFontMetrics()
+{
+ return QFontMetrics(defaultModelFont());
+}
+
+// return the default icon size, computed as the multiple of 16 closest to
+// the given height
+int defaultIconSize(int height)
+{
+ int ret = (height + 8)/16;
+ ret *= 16;
+ if (ret < 16)
+ ret = 16;
+ return ret;
+}
diff --git a/qt-ui/metrics.h b/qt-ui/metrics.h
new file mode 100644
index 000000000..ba45ab916
--- /dev/null
+++ b/qt-ui/metrics.h
@@ -0,0 +1,21 @@
+/*
+ * metrics.h
+ *
+ * header file for common function to find/compute essential UI metrics
+ * (font properties, icon sizes, etc)
+ *
+ */
+#ifndef METRICS_H
+#define METRICS_H
+
+#include <QFont>
+#include <QFontMetrics>
+
+QFont defaultModelFont();
+QFontMetrics defaultModelFontMetrics();
+
+// return the default icon size, computed as the multiple of 16 closest to
+// the given height (that defaults to the default font height)
+int defaultIconSize(int height = defaultModelFontMetrics().height());
+
+#endif // METRICS_H
diff --git a/qt-ui/models.cpp b/qt-ui/models.cpp
index 30dc6f64d..0e57b3b52 100644
--- a/qt-ui/models.cpp
+++ b/qt-ui/models.cpp
@@ -25,13 +25,6 @@
#include <QMessageBox>
#include <QStringListModel>
-QFont defaultModelFont()
-{
- QFont font;
-// font.setPointSizeF(font.pointSizeF() * 0.8);
- return font;
-}
-
CleanerTableModel::CleanerTableModel(QObject *parent) : QAbstractTableModel(parent)
{
}
diff --git a/qt-ui/models.h b/qt-ui/models.h
index bf13063c8..2345d0de2 100644
--- a/qt-ui/models.h
+++ b/qt-ui/models.h
@@ -13,12 +13,12 @@
#include <QStringListModel>
#include <QSortFilterProxyModel>
+#include "metrics.h"
+
#include "../dive.h"
#include "../divelist.h"
#include "../divecomputer.h"
-QFont defaultModelFont();
-
// Encapsulates Boilerplate.
class CleanerTableModel : public QAbstractTableModel {
Q_OBJECT
diff --git a/subsurface.pro b/subsurface.pro
index d4b71c303..724e0215d 100644
--- a/subsurface.pro
+++ b/subsurface.pro
@@ -57,6 +57,7 @@ HEADERS = \
qt-ui/mainwindow.h \
qt-ui/modeldelegates.h \
qt-ui/models.h \
+ qt-ui/metrics.h \
qt-ui/preferences.h \
qt-ui/printdialog.h \
qt-ui/printlayout.h \
@@ -143,6 +144,7 @@ SOURCES = \
qt-ui/mainwindow.cpp \
qt-ui/modeldelegates.cpp \
qt-ui/models.cpp \
+ qt-ui/metrics.cpp \
qt-ui/preferences.cpp \
qt-ui/printdialog.cpp \
qt-ui/printlayout.cpp \