<kcfgfile name="dolphinrc"/>
<include>kiconloader.h</include>
<include>kglobalsettings.h</include>
+ <include>QListView</include>
<group name="IconsMode">
- <entry name="Arrangement" type="String">
+ <entry name="Arrangement" type="Int">
<label>Arrangement</label>
- <default>LeftToRight</default>
+ <default code="true">QListView::TopToBottom</default>
</entry>
<entry name="FontFamily" type="String">
<label>Font family</label>
</entry>
<entry name="GridHeight" type="Int">
<label>Grid height</label>
- <default code="true">K3Icon::SizeMedium</default>
+ <default code="true">96</default>
</entry>
<entry name="GridWidth" type="Int">
<label>Grid width</label>
- <default>0</default>
+ <default>128</default>
</entry>
<entry name="GridSpacing" type="Int">
<label>Grid spacing</label>
#include "dolphindetailsview.h"
#include "dolphincontroller.h"
+#include "dolphinsettings.h"
#include "dolphinsortfilterproxymodel.h"
#include "viewproperties.h"
+#include "dolphin_detailsmodesettings.h"
+
#include <assert.h>
#include <kdirmodel.h>
#include <QHeaderView>
connect(this, SIGNAL(clicked(const QModelIndex&)),
controller, SLOT(triggerItem(const QModelIndex&)));
+
+ // apply the details mode settings to the widget
+ const DetailsModeSettings* settings = DolphinSettings::instance().detailsModeSettings();
+ assert(settings != 0);
+
+ m_viewOptions = QTreeView::viewOptions();
+ m_viewOptions.font = QFont(settings->fontFamily(), settings->fontSize());
+ const int iconSize = settings->iconSize();
+ m_viewOptions.decorationSize = QSize(iconSize, iconSize);
}
DolphinDetailsView::~DolphinDetailsView()
}
QStyleOptionViewItem DolphinDetailsView::viewOptions() const
{
- return QTreeView::viewOptions();
-
- // TODO: the view options should been read from the settings;
- // the following code is just for testing...
- //QStyleOptionViewItem options = QTreeView::viewOptions();
- //options.decorationAlignment = Qt::AlignRight;
- //options.decorationPosition = QStyleOptionViewItem::Right;
- //options.decorationSize = QSize(100, 100);
- //options.showDecorationSelected = true;
- //options.state = QStyle::State_MouseOver;
- //return options;
+ return m_viewOptions;
}
void DolphinDetailsView::contextMenuEvent(QContextMenuEvent* event)
#define DOLPHINDETAILSVIEW_H
#include <dolphinview.h>
+#include <QStyleOptionViewItem>
#include <QTreeView>
class DolphinController;
private:
DolphinController* m_controller;
+ QStyleOptionViewItem m_viewOptions;
};
#endif
#include "dolphiniconsview.h"
#include "dolphincontroller.h"
+#include "dolphinsettings.h"
+
+#include "dolphin_iconsmodesettings.h"
#include <assert.h>
#include <kdirmodel.h>
m_controller(controller)
{
assert(controller != 0);
-
setResizeMode(QListView::Adjust);
- // TODO: read out settings
- setViewMode(QListView::IconMode);
- setGridSize(QSize(128, 96));
-
connect(this, SIGNAL(clicked(const QModelIndex&)),
controller, SLOT(triggerItem(const QModelIndex&)));
+
+ // apply the icons mode settings to the widget
+ const IconsModeSettings* settings = DolphinSettings::instance().iconsModeSettings();
+ assert(settings != 0);
+
+ if (settings->arrangement() == QListView::TopToBottom) {
+ setViewMode(QListView::IconMode);
+ }
+ else {
+ setViewMode(QListView::ListMode);
+ }
+
+ setGridSize(QSize(settings->gridWidth(), settings->gridHeight()));
+ setSpacing(settings->gridSpacing());
+
+ m_viewOptions = QListView::viewOptions();
+ m_viewOptions.font = QFont(settings->fontFamily(), settings->fontSize());
+ const int iconSize = settings->iconSize();
+ m_viewOptions.decorationSize = QSize(iconSize, iconSize);
}
DolphinIconsView::~DolphinIconsView()
QStyleOptionViewItem DolphinIconsView::viewOptions() const
{
- return QListView::viewOptions();
-
- // TODO: the view options should been read from the settings;
- // the following code is just for testing...
- //QStyleOptionViewItem options = QListView::viewOptions();
- //options.decorationAlignment = Qt::AlignRight;
- //options.decorationPosition = QStyleOptionViewItem::Right;
- //options.decorationSize = QSize(100, 100);
- //options.showDecorationSelected = true;
- //options.state = QStyle::State_MouseOver;
- //return options;
+ return m_viewOptions;
}
void DolphinIconsView::contextMenuEvent(QContextMenuEvent* event)
#define DOLPHINICONSVIEW_H
#include <QListView>
+#include <QStyleOptionViewItem>
class DolphinController;
class DolphinView;
private:
DolphinController* m_controller;
+ QStyleOptionViewItem m_viewOptions;
};
#endif
#include <klocale.h>
#include <kvbox.h>
+#include <QListView>
+
#define GRID_SPACING_BASE 8
-#define GRID_SPACING_INC 12
+#define GRID_SPACING_INC 24
IconsViewSettingsPage::IconsViewSettingsPage(DolphinMainWindow* mainWindow,
QWidget* parent) :
gridGroup->setSizePolicy(sizePolicy);
gridGroup->setMargin(margin);
- const bool leftToRightArrangement = (settings->arrangement() == "LeftToRight");
+ const bool leftToRightArrangement = (settings->arrangement() == QListView::LeftToRight);
new QLabel(i18n("Arrangement:"), gridGroup);
m_arrangementBox = new QComboBox(gridGroup);
m_arrangementBox->addItem(i18n("Left to right"));
const int fontSize = m_fontSizeBox->value();
- QString arrangement = (m_arrangementBox->currentIndex() == 0) ?
- "LeftToRight" :
- "TopToBottom";
+ const int arrangement = (m_arrangementBox->currentIndex() == 0) ?
+ QListView::LeftToRight :
+ QListView::TopToBottom;
+
settings->setArrangement(arrangement);
- //DolphinSettings::instance().calculateGridSize(m_textWidthBox->currentIndex());
+
+ // TODO: this is just a very rough testing code to calculate the grid
+ // width and height
+ int gridWidth = defaultSize;
+ int gridHeight = defaultSize;
+ if (arrangement == QListView::TopToBottom) {
+ gridWidth += 96;
+ gridHeight += 64;
+ }
+ else {
+ gridWidth += 256;
+ }
+
+ settings->setGridWidth(gridWidth);
+ settings->setGridHeight(gridHeight);
settings->setFontFamily(m_fontFamilyBox->currentFont().family());
settings->setFontSize(fontSize);