From f355fe070293a3f80b33ee0bc0154b2fe767fc4d Mon Sep 17 00:00:00 2001 From: Andrei Karas Date: Mon, 31 Dec 2012 19:26:21 +0300 Subject: Sort onscreen keyboard actions list. --- src/gui/widgets/setuptouchitem.cpp | 57 +++++++++++++++++++++++++++++++++++++- src/gui/widgets/setuptouchitem.h | 41 ++++++--------------------- 2 files changed, 64 insertions(+), 34 deletions(-) diff --git a/src/gui/widgets/setuptouchitem.cpp b/src/gui/widgets/setuptouchitem.cpp index 59f33b6a5..06faf7b19 100644 --- a/src/gui/widgets/setuptouchitem.cpp +++ b/src/gui/widgets/setuptouchitem.cpp @@ -27,6 +27,62 @@ #include "debug.h" +class SortTouchActionFunctor final +{ + public: + bool operator() (const SetupActionData *const data1, + const SetupActionData *const data2) const + { + if (!data1 || !data2) + return false; + return data1->name < data2->name; + } +} touchActionSorter; + +TouchActionsModel::TouchActionsModel() +{ + std::vector data; + + for (int f = 0, sz = touchActionDataSize; f < sz; f ++) + { + int k = 0; + while (!touchActionData[f][k].name.empty()) + { + data.push_back(&touchActionData[f][k]); + k ++; + } + } + + std::sort(data.begin(), data.end(), touchActionSorter); + int cnt = 0; + for (std::vector::iterator it = data.begin(), + it_end = data.end(); it != it_end; ++ it) + { + const SetupActionData *data1 = *it; + mNames.push_back(data1->name); + mActionId.push_back(data1->actionId); + mActionToSelection[data1->actionId] = cnt; + cnt ++; + } +} + +int TouchActionsModel::getActionFromSelection(int sel) +{ + if (sel < 0 || sel > mActionId.size()) + return -1; + return mActionId[sel]; +} + +int TouchActionsModel::getSelectionFromAction(int action) +{ + std::map::const_iterator it + = mActionToSelection.find(action); + if (it == mActionToSelection.end()) + return 0; + return (*it).second; +} + + SetupActionDropDown::SetupActionDropDown(std::string text, std::string description, std::string keyName, @@ -89,7 +145,6 @@ void SetupActionDropDown::createControls() atoi(mValue.c_str()))); mWidget = mDropDown; -// mTextField->setWidth(50); fixFirstItemSize(mLabel); mHorizont->add(mLabel); mHorizont->add(mDropDown); diff --git a/src/gui/widgets/setuptouchitem.h b/src/gui/widgets/setuptouchitem.h index 2f5cf7805..77eff2ae6 100644 --- a/src/gui/widgets/setuptouchitem.h +++ b/src/gui/widgets/setuptouchitem.h @@ -26,46 +26,21 @@ #include "gui/widgets/namesmodel.h" #include "gui/widgets/setupitem.h" +#include + class TouchActionsModel final : public NamesModel { public: - TouchActionsModel() : - NamesModel() - { - int cnt = 0; - for (int f = 0, sz = touchActionDataSize; f < sz; f ++) - { - int k = 0; - while (!touchActionData[f][k].name.empty()) - { - const SetupActionData &data = touchActionData[f][k]; - mNames.push_back(data.name); - mActionId.push_back(data.actionId); - mActionToSelection[data.actionId] = cnt; - k ++; - cnt ++; - } - } - } + TouchActionsModel(); + + A_DELETE_COPY(TouchActionsModel) virtual ~TouchActionsModel() { } - int getActionFromSelection(int sel) - { - if (sel < 0 || sel > mActionId.size()) - return -1; - return mActionId[sel]; - } - - int getSelectionFromAction(int action) - { - std::map::const_iterator it - = mActionToSelection.find(action); - if (it == mActionToSelection.end()) - return 0; - return (*it).second; - } + int getActionFromSelection(int sel); + + int getSelectionFromAction(int action); private: std::vector mActionId; -- cgit v1.2.3-60-g2f50