summaryrefslogtreecommitdiff
path: root/src/gui/widgets/tabbedarea.cpp
diff options
context:
space:
mode:
authorAndrei Karas <akaras@inbox.ru>2012-04-17 11:31:47 +0300
committerAndrei Karas <akaras@inbox.ru>2012-04-17 11:31:47 +0300
commit693879649420c0997bfb29bea7f5752f6d9ac526 (patch)
tree01d6c56532d561385edbfe2ad0235df6c5a58c5f /src/gui/widgets/tabbedarea.cpp
parent8df35828d69f3debd89557a74c26359a8b249f87 (diff)
downloadplus-693879649420c0997bfb29bea7f5752f6d9ac526.tar.gz
plus-693879649420c0997bfb29bea7f5752f6d9ac526.tar.bz2
plus-693879649420c0997bfb29bea7f5752f6d9ac526.tar.xz
plus-693879649420c0997bfb29bea7f5752f6d9ac526.zip
Move keyboard handling from guichan to own classes.
Diffstat (limited to 'src/gui/widgets/tabbedarea.cpp')
-rw-r--r--src/gui/widgets/tabbedarea.cpp31
1 files changed, 31 insertions, 0 deletions
diff --git a/src/gui/widgets/tabbedarea.cpp b/src/gui/widgets/tabbedarea.cpp
index fc6526a13..bb8ea063b 100644
--- a/src/gui/widgets/tabbedarea.cpp
+++ b/src/gui/widgets/tabbedarea.cpp
@@ -477,6 +477,37 @@ void TabbedArea::removeAll()
}
}
+void TabbedArea::keyPressed(gcn::KeyEvent& keyEvent)
+{
+ if (keyEvent.isConsumed() || !isFocused())
+ return;
+
+ if (keyEvent.getKey().getValue() == gcn::Key::LEFT)
+ {
+ int index = getSelectedTabIndex();
+ index--;
+
+ if (index < 0)
+ return;
+ else
+ setSelectedTab(mTabs[index].first);
+
+ keyEvent.consume();
+ }
+ else if (keyEvent.getKey().getValue() == gcn::Key::RIGHT)
+ {
+ int index = getSelectedTabIndex();
+ index++;
+
+ if (index >= static_cast<int>(mTabs.size()))
+ return;
+ else
+ setSelectedTab(mTabs[index].first);
+
+ keyEvent.consume();
+ }
+}
+
/*
void TabbedArea::moveLeft(gcn::Tab *tab)
{