return QPoint(x, y);
}
-void DolphinView::zoomIn()
+void DolphinView::setZoomLevel(int level)
{
- m_controller->triggerZoomIn();
- m_iconManager->updatePreviews();
+ if (level < zoomLevelMinimum()) {
+ level = zoomLevelMinimum();
+ } else if (level > zoomLevelMaximum()) {
+ level = zoomLevelMaximum();
+ }
+
+ if (level != zoomLevel()) {
+ m_controller->setZoomLevel(level);
+ m_iconManager->updatePreviews();
+ emit zoomLevelChanged(level);
+ }
}
-void DolphinView::zoomOut()
+int DolphinView::zoomLevel() const
{
- m_controller->triggerZoomOut();
- m_iconManager->updatePreviews();
+ return m_controller->zoomLevel();
}
-bool DolphinView::isZoomInPossible() const
+int DolphinView::zoomLevelMinimum() const
{
- return m_controller->isZoomInPossible();
+ return m_controller->zoomLevelMinimum();
}
-bool DolphinView::isZoomOutPossible() const
+int DolphinView::zoomLevelMaximum() const
{
- return m_controller->isZoomOutPossible();
+ return m_controller->zoomLevelMaximum();
}
void DolphinView::setSorting(Sorting sorting)
void DolphinView::renameSelectedItems()
{
const KFileItemList items = selectedItems();
- if (items.count() > 1) {
+ const int itemCount = items.count();
+ if (itemCount < 1) {
+ return;
+ }
+
+ if (itemCount > 1) {
// More than one item has been selected for renaming. Open
// a rename dialog and rename all items afterwards.
RenameDialog dialog(this, items);
}
}
} else if (DolphinSettings::instance().generalSettings()->renameInline()) {
- Q_ASSERT(items.count() == 1);
-
+ Q_ASSERT(itemCount == 1);
+
if (isColumnViewActive()) {
m_columnView->editItem(items.first());
} else {
itemView()->edit(proxyIndex);
}
} else {
- Q_ASSERT(items.count() == 1);
-
+ Q_ASSERT(itemCount == 1);
+
RenameDialog dialog(this, items);
if (dialog.exec() == QDialog::Rejected) {
return;
{
if (event->modifiers() & Qt::ControlModifier) {
const int delta = event->delta();
- if ((delta > 0) && isZoomInPossible()) {
- zoomIn();
- } else if ((delta < 0) && isZoomOutPossible()) {
- zoomOut();
+ const int level = zoomLevel();
+ if (delta > 0) {
+ setZoomLevel(level + 1);
+ } else if (delta < 0) {
+ setZoomLevel(level - 1);
}
event->accept();
}