address review comments
This commit is contained in:
		| @@ -168,12 +168,12 @@ void Config::ReadControlValues() { | |||||||
|         qt_config->beginReadArray(QStringLiteral("touch_from_button_maps")); |         qt_config->beginReadArray(QStringLiteral("touch_from_button_maps")); | ||||||
|  |  | ||||||
|     if (num_touch_from_button_maps > 0) { |     if (num_touch_from_button_maps > 0) { | ||||||
|         const auto& append_touch_from_button_map = [this] { |         const auto append_touch_from_button_map = [this] { | ||||||
|             Settings::TouchFromButtonMap map; |             Settings::TouchFromButtonMap map; | ||||||
|             map.name = ReadSetting(QStringLiteral("name"), QStringLiteral("default")) |             map.name = ReadSetting(QStringLiteral("name"), QStringLiteral("default")) | ||||||
|                            .toString() |                            .toString() | ||||||
|                            .toStdString(); |                            .toStdString(); | ||||||
|             const std::size_t num_touch_maps = qt_config->beginReadArray(QStringLiteral("entries")); |             const int num_touch_maps = qt_config->beginReadArray(QStringLiteral("entries")); | ||||||
|             map.buttons.reserve(num_touch_maps); |             map.buttons.reserve(num_touch_maps); | ||||||
|             for (int i = 0; i < num_touch_maps; i++) { |             for (int i = 0; i < num_touch_maps; i++) { | ||||||
|                 qt_config->setArrayIndex(i); |                 qt_config->setArrayIndex(i); | ||||||
|   | |||||||
| @@ -124,12 +124,12 @@ void ConfigureTouchFromButton::UpdateUiDisplay() { | |||||||
|         binding_list_model->appendRow({button, xcoord, ycoord}); |         binding_list_model->appendRow({button, xcoord, ycoord}); | ||||||
|  |  | ||||||
|         int dot = ui->bottom_screen->AddDot(package.Get("x", 0), package.Get("y", 0)); |         int dot = ui->bottom_screen->AddDot(package.Get("x", 0), package.Get("y", 0)); | ||||||
|         button->setData(dot, data_role_dot); |         button->setData(dot, DataRoleDot); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| void ConfigureTouchFromButton::ConnectEvents() { | void ConfigureTouchFromButton::ConnectEvents() { | ||||||
|     connect(ui->mapping, qOverload<int>(&QComboBox::activated), this, [this](int index) { |     connect(ui->mapping, qOverload<int>(&QComboBox::currentIndexChanged), this, [this](int index) { | ||||||
|         SaveCurrentMapping(); |         SaveCurrentMapping(); | ||||||
|         selected_index = index; |         selected_index = index; | ||||||
|         UpdateUiDisplay(); |         UpdateUiDisplay(); | ||||||
| @@ -199,16 +199,9 @@ void ConfigureTouchFromButton::NewMapping() { | |||||||
|     if (name.isEmpty()) { |     if (name.isEmpty()) { | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     if (selected_index > 0) { |  | ||||||
|         SaveCurrentMapping(); |  | ||||||
|     } |  | ||||||
|     touch_maps.emplace_back(Settings::TouchFromButtonMap{name.toStdString(), {}}); |     touch_maps.emplace_back(Settings::TouchFromButtonMap{name.toStdString(), {}}); | ||||||
|     selected_index = static_cast<int>(touch_maps.size()) - 1; |  | ||||||
|  |  | ||||||
|     ui->mapping->addItem(name); |     ui->mapping->addItem(name); | ||||||
|     ui->mapping->setCurrentIndex(selected_index); |     ui->mapping->setCurrentIndex(ui->mapping->count() - 1); | ||||||
|     UpdateUiDisplay(); |  | ||||||
| } | } | ||||||
|  |  | ||||||
| void ConfigureTouchFromButton::DeleteMapping() { | void ConfigureTouchFromButton::DeleteMapping() { | ||||||
| @@ -217,10 +210,11 @@ void ConfigureTouchFromButton::DeleteMapping() { | |||||||
|     if (answer != QMessageBox::Yes) { |     if (answer != QMessageBox::Yes) { | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|  |     const bool blocked = ui->mapping->blockSignals(true); | ||||||
|     ui->mapping->removeItem(selected_index); |     ui->mapping->removeItem(selected_index); | ||||||
|     ui->mapping->setCurrentIndex(0); |     ui->mapping->blockSignals(blocked); | ||||||
|     touch_maps.erase(touch_maps.begin() + selected_index); |     touch_maps.erase(touch_maps.begin() + selected_index); | ||||||
|     selected_index = touch_maps.size() ? 0 : -1; |     selected_index = ui->mapping->currentIndex(); | ||||||
|     UpdateUiDisplay(); |     UpdateUiDisplay(); | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -239,16 +233,16 @@ void ConfigureTouchFromButton::GetButtonInput(const int row_index, const bool is | |||||||
|     input_setter = [this, row_index, is_new](const Common::ParamPackage& params, |     input_setter = [this, row_index, is_new](const Common::ParamPackage& params, | ||||||
|                                              const bool cancel) { |                                              const bool cancel) { | ||||||
|         auto cell = binding_list_model->item(row_index, 0); |         auto cell = binding_list_model->item(row_index, 0); | ||||||
|         if (!cancel) { |         if (cancel) { | ||||||
|             cell->setText(ButtonToText(params)); |  | ||||||
|             cell->setData(QString::fromStdString(params.Serialize())); |  | ||||||
|         } else { |  | ||||||
|             if (is_new) { |             if (is_new) { | ||||||
|                 binding_list_model->removeRow(row_index); |                 binding_list_model->removeRow(row_index); | ||||||
|             } else { |             } else { | ||||||
|                 cell->setText( |                 cell->setText( | ||||||
|                     ButtonToText(Common::ParamPackage{cell->data().toString().toStdString()})); |                     ButtonToText(Common::ParamPackage{cell->data().toString().toStdString()})); | ||||||
|             } |             } | ||||||
|  |         } else { | ||||||
|  |             cell->setText(ButtonToText(params)); | ||||||
|  |             cell->setData(QString::fromStdString(params.Serialize())); | ||||||
|         } |         } | ||||||
|     }; |     }; | ||||||
|  |  | ||||||
| @@ -271,8 +265,8 @@ void ConfigureTouchFromButton::NewBinding(const QPoint& pos) { | |||||||
|     QStandardItem* xcoord = new QStandardItem(QString::number(pos.x())); |     QStandardItem* xcoord = new QStandardItem(QString::number(pos.x())); | ||||||
|     QStandardItem* ycoord = new QStandardItem(QString::number(pos.y())); |     QStandardItem* ycoord = new QStandardItem(QString::number(pos.y())); | ||||||
|  |  | ||||||
|     int dot_id = ui->bottom_screen->AddDot(pos.x(), pos.y()); |     const int dot_id = ui->bottom_screen->AddDot(pos.x(), pos.y()); | ||||||
|     button->setData(dot_id, data_role_dot); |     button->setData(dot_id, DataRoleDot); | ||||||
|  |  | ||||||
|     binding_list_model->appendRow({button, xcoord, ycoord}); |     binding_list_model->appendRow({button, xcoord, ycoord}); | ||||||
|     ui->binding_list->setFocus(); |     ui->binding_list->setFocus(); | ||||||
| @@ -291,7 +285,7 @@ void ConfigureTouchFromButton::DeleteBinding() { | |||||||
|     const int row_index = ui->binding_list->currentIndex().row(); |     const int row_index = ui->binding_list->currentIndex().row(); | ||||||
|     if (row_index >= 0) { |     if (row_index >= 0) { | ||||||
|         ui->bottom_screen->RemoveDot( |         ui->bottom_screen->RemoveDot( | ||||||
|             binding_list_model->index(row_index, 0).data(data_role_dot).toInt()); |             binding_list_model->index(row_index, 0).data(DataRoleDot).toInt()); | ||||||
|         binding_list_model->removeRow(row_index); |         binding_list_model->removeRow(row_index); | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -300,13 +294,13 @@ void ConfigureTouchFromButton::OnBindingSelection(const QItemSelection& selected | |||||||
|                                                   const QItemSelection& deselected) { |                                                   const QItemSelection& deselected) { | ||||||
|     ui->button_delete_bind->setEnabled(!selected.isEmpty()); |     ui->button_delete_bind->setEnabled(!selected.isEmpty()); | ||||||
|     if (!selected.isEmpty()) { |     if (!selected.isEmpty()) { | ||||||
|         const auto dot_data = selected.indexes().first().data(data_role_dot); |         const auto dot_data = selected.indexes().first().data(DataRoleDot); | ||||||
|         if (dot_data.isValid()) { |         if (dot_data.isValid()) { | ||||||
|             ui->bottom_screen->HighlightDot(dot_data.toInt()); |             ui->bottom_screen->HighlightDot(dot_data.toInt()); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     if (!deselected.isEmpty()) { |     if (!deselected.isEmpty()) { | ||||||
|         const auto dot_data = deselected.indexes().first().data(data_role_dot); |         const auto dot_data = deselected.indexes().first().data(DataRoleDot); | ||||||
|         if (dot_data.isValid()) { |         if (dot_data.isValid()) { | ||||||
|             ui->bottom_screen->HighlightDot(dot_data.toInt(), false); |             ui->bottom_screen->HighlightDot(dot_data.toInt(), false); | ||||||
|         } |         } | ||||||
| @@ -324,7 +318,7 @@ void ConfigureTouchFromButton::OnBindingChanged(QStandardItem* item) { | |||||||
|         (item->column() == 1 ? Core::kScreenBottomWidth : Core::kScreenBottomHeight) - 1))); |         (item->column() == 1 ? Core::kScreenBottomWidth : Core::kScreenBottomHeight) - 1))); | ||||||
|     binding_list_model->blockSignals(blocked); |     binding_list_model->blockSignals(blocked); | ||||||
|  |  | ||||||
|     const auto dot_data = binding_list_model->index(item->row(), 0).data(data_role_dot); |     const auto dot_data = binding_list_model->index(item->row(), 0).data(DataRoleDot); | ||||||
|     if (dot_data.isValid()) { |     if (dot_data.isValid()) { | ||||||
|         ui->bottom_screen->MoveDot(dot_data.toInt(), |         ui->bottom_screen->MoveDot(dot_data.toInt(), | ||||||
|                                    binding_list_model->item(item->row(), 1)->text().toInt(), |                                    binding_list_model->item(item->row(), 1)->text().toInt(), | ||||||
| @@ -338,7 +332,7 @@ void ConfigureTouchFromButton::OnBindingDeleted(const QModelIndex& parent, int f | |||||||
|         if (!ix.isValid()) { |         if (!ix.isValid()) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         const auto dot_data = ix.data(data_role_dot); |         const auto dot_data = ix.data(DataRoleDot); | ||||||
|         if (dot_data.isValid()) { |         if (dot_data.isValid()) { | ||||||
|             ui->bottom_screen->RemoveDot(dot_data.toInt()); |             ui->bottom_screen->RemoveDot(dot_data.toInt()); | ||||||
|         } |         } | ||||||
| @@ -347,7 +341,7 @@ void ConfigureTouchFromButton::OnBindingDeleted(const QModelIndex& parent, int f | |||||||
|  |  | ||||||
| void ConfigureTouchFromButton::SetActiveBinding(const int dot_id) { | void ConfigureTouchFromButton::SetActiveBinding(const int dot_id) { | ||||||
|     for (int i = 0; i < binding_list_model->rowCount(); ++i) { |     for (int i = 0; i < binding_list_model->rowCount(); ++i) { | ||||||
|         if (binding_list_model->index(i, 0).data(data_role_dot) == dot_id) { |         if (binding_list_model->index(i, 0).data(DataRoleDot) == dot_id) { | ||||||
|             ui->binding_list->setCurrentIndex(binding_list_model->index(i, 0)); |             ui->binding_list->setCurrentIndex(binding_list_model->index(i, 0)); | ||||||
|             ui->binding_list->setFocus(); |             ui->binding_list->setFocus(); | ||||||
|             return; |             return; | ||||||
| @@ -357,7 +351,7 @@ void ConfigureTouchFromButton::SetActiveBinding(const int dot_id) { | |||||||
|  |  | ||||||
| void ConfigureTouchFromButton::SetCoordinates(const int dot_id, const QPoint& pos) { | void ConfigureTouchFromButton::SetCoordinates(const int dot_id, const QPoint& pos) { | ||||||
|     for (int i = 0; i < binding_list_model->rowCount(); ++i) { |     for (int i = 0; i < binding_list_model->rowCount(); ++i) { | ||||||
|         if (binding_list_model->item(i, 0)->data(data_role_dot) == dot_id) { |         if (binding_list_model->item(i, 0)->data(DataRoleDot) == dot_id) { | ||||||
|             binding_list_model->item(i, 1)->setText(QString::number(pos.x())); |             binding_list_model->item(i, 1)->setText(QString::number(pos.x())); | ||||||
|             binding_list_model->item(i, 2)->setText(QString::number(pos.y())); |             binding_list_model->item(i, 2)->setText(QString::number(pos.y())); | ||||||
|             return; |             return; | ||||||
| @@ -432,9 +426,9 @@ int TouchScreenPreview::AddDot(const int device_x, const int device_y) { | |||||||
|     dot->setFont(dot_font); |     dot->setFont(dot_font); | ||||||
|     dot->setText(QChar(0xD7)); // U+00D7 Multiplication Sign |     dot->setText(QChar(0xD7)); // U+00D7 Multiplication Sign | ||||||
|     dot->setAlignment(Qt::AlignmentFlag::AlignCenter); |     dot->setAlignment(Qt::AlignmentFlag::AlignCenter); | ||||||
|     dot->setProperty(prop_id, ++max_dot_id); |     dot->setProperty(PropId, ++max_dot_id); | ||||||
|     dot->setProperty(prop_x, device_x); |     dot->setProperty(PropX, device_x); | ||||||
|     dot->setProperty(prop_y, device_y); |     dot->setProperty(PropY, device_y); | ||||||
|     dot->setCursor(Qt::CursorShape::PointingHandCursor); |     dot->setCursor(Qt::CursorShape::PointingHandCursor); | ||||||
|     dot->setMouseTracking(true); |     dot->setMouseTracking(true); | ||||||
|     dot->installEventFilter(this); |     dot->installEventFilter(this); | ||||||
| @@ -445,7 +439,7 @@ int TouchScreenPreview::AddDot(const int device_x, const int device_y) { | |||||||
| } | } | ||||||
|  |  | ||||||
| void TouchScreenPreview::RemoveDot(const int id) { | void TouchScreenPreview::RemoveDot(const int id) { | ||||||
|     for (auto dot_it = dots.begin(); dot_it < dots.end(); ++dot_it) { |     for (auto dot_it = dots.begin(); dot_it != dots.end(); ++dot_it) { | ||||||
|         if (dot_it->first == id) { |         if (dot_it->first == id) { | ||||||
|             dot_it->second->deleteLater(); |             dot_it->second->deleteLater(); | ||||||
|             dots.erase(dot_it); |             dots.erase(dot_it); | ||||||
| @@ -466,6 +460,9 @@ void TouchScreenPreview::HighlightDot(const int id, const bool active) const { | |||||||
|                 dot.second->setForegroundRole(active ? QPalette::ColorRole::LinkVisited |                 dot.second->setForegroundRole(active ? QPalette::ColorRole::LinkVisited | ||||||
|                                                      : QPalette::ColorRole::NoRole); |                                                      : QPalette::ColorRole::NoRole); | ||||||
|             } |             } | ||||||
|  |             if (active) { | ||||||
|  |                 dot.second->raise(); | ||||||
|  |             } | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| @@ -474,8 +471,8 @@ void TouchScreenPreview::HighlightDot(const int id, const bool active) const { | |||||||
| void TouchScreenPreview::MoveDot(const int id, const int device_x, const int device_y) const { | void TouchScreenPreview::MoveDot(const int id, const int device_x, const int device_y) const { | ||||||
|     for (const auto& dot : dots) { |     for (const auto& dot : dots) { | ||||||
|         if (dot.first == id) { |         if (dot.first == id) { | ||||||
|             dot.second->setProperty(prop_x, device_x); |             dot.second->setProperty(PropX, device_x); | ||||||
|             dot.second->setProperty(prop_y, device_y); |             dot.second->setProperty(PropY, device_y); | ||||||
|             PositionDot(dot.second, device_x, device_y); |             PositionDot(dot.second, device_x, device_y); | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
| @@ -508,9 +505,9 @@ void TouchScreenPreview::mouseMoveEvent(QMouseEvent* event) { | |||||||
|     if (!coord_label) { |     if (!coord_label) { | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|     const auto point = MapToDeviceCoords(event->x(), event->y()); |     const auto pos = MapToDeviceCoords(event->x(), event->y()); | ||||||
|     if (point.has_value()) { |     if (pos) { | ||||||
|         coord_label->setText(QStringLiteral("X: %1, Y: %2").arg(point->x()).arg(point->y())); |         coord_label->setText(QStringLiteral("X: %1, Y: %2").arg(pos->x()).arg(pos->y())); | ||||||
|     } else { |     } else { | ||||||
|         coord_label->clear(); |         coord_label->clear(); | ||||||
|     } |     } | ||||||
| @@ -525,7 +522,7 @@ void TouchScreenPreview::leaveEvent(QEvent* event) { | |||||||
| void TouchScreenPreview::mousePressEvent(QMouseEvent* event) { | void TouchScreenPreview::mousePressEvent(QMouseEvent* event) { | ||||||
|     if (event->button() == Qt::MouseButton::LeftButton) { |     if (event->button() == Qt::MouseButton::LeftButton) { | ||||||
|         const auto pos = MapToDeviceCoords(event->x(), event->y()); |         const auto pos = MapToDeviceCoords(event->x(), event->y()); | ||||||
|         if (pos.has_value()) { |         if (pos) { | ||||||
|             emit DotAdded(*pos); |             emit DotAdded(*pos); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| @@ -538,7 +535,7 @@ bool TouchScreenPreview::eventFilter(QObject* obj, QEvent* event) { | |||||||
|         if (mouse_event->button() != Qt::MouseButton::LeftButton) { |         if (mouse_event->button() != Qt::MouseButton::LeftButton) { | ||||||
|             break; |             break; | ||||||
|         } |         } | ||||||
|         emit DotSelected(obj->property(prop_id).toInt()); |         emit DotSelected(obj->property(PropId).toInt()); | ||||||
|  |  | ||||||
|         drag_state.dot = qobject_cast<QLabel*>(obj); |         drag_state.dot = qobject_cast<QLabel*>(obj); | ||||||
|         drag_state.start_pos = mouse_event->globalPos(); |         drag_state.start_pos = mouse_event->globalPos(); | ||||||
| @@ -559,15 +556,15 @@ bool TouchScreenPreview::eventFilter(QObject* obj, QEvent* event) { | |||||||
|         } |         } | ||||||
|         auto current_pos = mapFromGlobal(mouse_event->globalPos()); |         auto current_pos = mapFromGlobal(mouse_event->globalPos()); | ||||||
|         current_pos.setX(std::clamp(current_pos.x(), contentsMargins().left(), |         current_pos.setX(std::clamp(current_pos.x(), contentsMargins().left(), | ||||||
|                                     contentsMargins().left() + contentsRect().width())); |                                     contentsMargins().left() + contentsRect().width() - 1)); | ||||||
|         current_pos.setY(std::clamp(current_pos.y(), contentsMargins().top(), |         current_pos.setY(std::clamp(current_pos.y(), contentsMargins().top(), | ||||||
|                                     contentsMargins().top() + contentsRect().height())); |                                     contentsMargins().top() + contentsRect().height() - 1)); | ||||||
|         const auto device_coord = MapToDeviceCoords(current_pos.x(), current_pos.y()); |         const auto device_coord = MapToDeviceCoords(current_pos.x(), current_pos.y()); | ||||||
|         if (device_coord.has_value()) { |         if (device_coord) { | ||||||
|             drag_state.dot->setProperty(prop_x, device_coord->x()); |             drag_state.dot->setProperty(PropX, device_coord->x()); | ||||||
|             drag_state.dot->setProperty(prop_y, device_coord->y()); |             drag_state.dot->setProperty(PropY, device_coord->y()); | ||||||
|             PositionDot(drag_state.dot, device_coord->x(), device_coord->y()); |             PositionDot(drag_state.dot, device_coord->x(), device_coord->y()); | ||||||
|             emit DotMoved(drag_state.dot->property(prop_id).toInt(), *device_coord); |             emit DotMoved(drag_state.dot->property(PropId).toInt(), *device_coord); | ||||||
|             if (coord_label) { |             if (coord_label) { | ||||||
|                 coord_label->setText( |                 coord_label->setText( | ||||||
|                     QStringLiteral("X: %1, Y: %2").arg(device_coord->x()).arg(device_coord->y())); |                     QStringLiteral("X: %1, Y: %2").arg(device_coord->x()).arg(device_coord->y())); | ||||||
| @@ -589,9 +586,9 @@ bool TouchScreenPreview::eventFilter(QObject* obj, QEvent* event) { | |||||||
| std::optional<QPoint> TouchScreenPreview::MapToDeviceCoords(const int screen_x, | std::optional<QPoint> TouchScreenPreview::MapToDeviceCoords(const int screen_x, | ||||||
|                                                             const int screen_y) const { |                                                             const int screen_y) const { | ||||||
|     const float t_x = 0.5f + static_cast<float>(screen_x - contentsMargins().left()) * |     const float t_x = 0.5f + static_cast<float>(screen_x - contentsMargins().left()) * | ||||||
|                                  (Core::kScreenBottomWidth - 1) / contentsRect().width(); |                                  (Core::kScreenBottomWidth - 1) / (contentsRect().width() - 1); | ||||||
|     const float t_y = 0.5f + static_cast<float>(screen_y - contentsMargins().top()) * |     const float t_y = 0.5f + static_cast<float>(screen_y - contentsMargins().top()) * | ||||||
|                                  (Core::kScreenBottomHeight - 1) / contentsRect().height(); |                                  (Core::kScreenBottomHeight - 1) / (contentsRect().height() - 1); | ||||||
|     if (t_x >= 0.5f && t_x < Core::kScreenBottomWidth && t_y >= 0.5f && |     if (t_x >= 0.5f && t_x < Core::kScreenBottomWidth && t_y >= 0.5f && | ||||||
|         t_y < Core::kScreenBottomHeight) { |         t_y < Core::kScreenBottomHeight) { | ||||||
|  |  | ||||||
| @@ -603,11 +600,11 @@ std::optional<QPoint> TouchScreenPreview::MapToDeviceCoords(const int screen_x, | |||||||
| void TouchScreenPreview::PositionDot(QLabel* const dot, const int device_x, | void TouchScreenPreview::PositionDot(QLabel* const dot, const int device_x, | ||||||
|                                      const int device_y) const { |                                      const int device_y) const { | ||||||
|     dot->move(static_cast<int>( |     dot->move(static_cast<int>( | ||||||
|                   static_cast<float>(device_x >= 0 ? device_x : dot->property(prop_x).toInt()) * |                   static_cast<float>(device_x >= 0 ? device_x : dot->property(PropX).toInt()) * | ||||||
|                       (contentsRect().width() - 1) / (Core::kScreenBottomWidth - 1) + |                       (contentsRect().width() - 1) / (Core::kScreenBottomWidth - 1) + | ||||||
|                   contentsMargins().left() - static_cast<float>(dot->width()) / 2 + 0.5f), |                   contentsMargins().left() - static_cast<float>(dot->width()) / 2 + 0.5f), | ||||||
|               static_cast<int>( |               static_cast<int>( | ||||||
|                   static_cast<float>(device_y >= 0 ? device_y : dot->property(prop_y).toInt()) * |                   static_cast<float>(device_y >= 0 ? device_y : dot->property(PropY).toInt()) * | ||||||
|                       (contentsRect().height() - 1) / (Core::kScreenBottomHeight - 1) + |                       (contentsRect().height() - 1) / (Core::kScreenBottomHeight - 1) + | ||||||
|                   contentsMargins().top() - static_cast<float>(dot->height()) / 2 + 0.5f)); |                   contentsMargins().top() - static_cast<float>(dot->height()) / 2 + 0.5f)); | ||||||
| } | } | ||||||
|   | |||||||
| @@ -37,7 +37,7 @@ class ConfigureTouchFromButton : public QDialog { | |||||||
| public: | public: | ||||||
|     explicit ConfigureTouchFromButton(QWidget* parent, |     explicit ConfigureTouchFromButton(QWidget* parent, | ||||||
|                                       const std::vector<Settings::TouchFromButtonMap>& touch_maps, |                                       const std::vector<Settings::TouchFromButtonMap>& touch_maps, | ||||||
|                                       const int default_index = 0); |                                       int default_index = 0); | ||||||
|     ~ConfigureTouchFromButton() override; |     ~ConfigureTouchFromButton() override; | ||||||
|  |  | ||||||
|     int GetSelectedIndex() const; |     int GetSelectedIndex() const; | ||||||
| @@ -46,8 +46,8 @@ public: | |||||||
| public slots: | public slots: | ||||||
|     void ApplyConfiguration(); |     void ApplyConfiguration(); | ||||||
|     void NewBinding(const QPoint& pos); |     void NewBinding(const QPoint& pos); | ||||||
|     void SetActiveBinding(const int dot_id); |     void SetActiveBinding(int dot_id); | ||||||
|     void SetCoordinates(const int dot_id, const QPoint& pos); |     void SetCoordinates(int dot_id, const QPoint& pos); | ||||||
|  |  | ||||||
| protected: | protected: | ||||||
|     virtual void showEvent(QShowEvent* ev) override; |     virtual void showEvent(QShowEvent* ev) override; | ||||||
| @@ -67,8 +67,8 @@ private: | |||||||
|     void SetConfiguration(); |     void SetConfiguration(); | ||||||
|     void UpdateUiDisplay(); |     void UpdateUiDisplay(); | ||||||
|     void ConnectEvents(); |     void ConnectEvents(); | ||||||
|     void GetButtonInput(const int row_index, const bool is_new); |     void GetButtonInput(int row_index, bool is_new); | ||||||
|     void SetPollingResult(const Common::ParamPackage& params, const bool cancel); |     void SetPollingResult(const Common::ParamPackage& params, bool cancel); | ||||||
|     void SaveCurrentMapping(); |     void SaveCurrentMapping(); | ||||||
|  |  | ||||||
|     std::unique_ptr<Ui::ConfigureTouchFromButton> ui; |     std::unique_ptr<Ui::ConfigureTouchFromButton> ui; | ||||||
| @@ -79,7 +79,7 @@ private: | |||||||
|     std::unique_ptr<QTimer> timeout_timer; |     std::unique_ptr<QTimer> timeout_timer; | ||||||
|     std::unique_ptr<QTimer> poll_timer; |     std::unique_ptr<QTimer> poll_timer; | ||||||
|     std::vector<std::unique_ptr<InputCommon::Polling::DevicePoller>> device_pollers; |     std::vector<std::unique_ptr<InputCommon::Polling::DevicePoller>> device_pollers; | ||||||
|     std::optional<std::function<void(const Common::ParamPackage&, const bool)>> input_setter; |     std::optional<std::function<void(const Common::ParamPackage&, bool)>> input_setter; | ||||||
|  |  | ||||||
|     static constexpr int data_role_dot = Qt::ItemDataRole::UserRole + 2; |     static constexpr int DataRoleDot = Qt::ItemDataRole::UserRole + 2; | ||||||
| }; | }; | ||||||
|   | |||||||
| @@ -113,7 +113,7 @@ Drag points to change position, or double-click table cells to edit values.</str | |||||||
|      <item> |      <item> | ||||||
|       <widget class="QPushButton" name="button_delete_bind"> |       <widget class="QPushButton" name="button_delete_bind"> | ||||||
|        <property name="text"> |        <property name="text"> | ||||||
|         <string>Delete point</string> |         <string>Delete Point</string> | ||||||
|        </property> |        </property> | ||||||
|       </widget> |       </widget> | ||||||
|      </item> |      </item> | ||||||
|   | |||||||
| @@ -18,19 +18,19 @@ class TouchScreenPreview : public QFrame { | |||||||
|     Q_PROPERTY(QColor dotHighlightColor MEMBER dot_highlight_color) |     Q_PROPERTY(QColor dotHighlightColor MEMBER dot_highlight_color) | ||||||
|  |  | ||||||
| public: | public: | ||||||
|     TouchScreenPreview(QWidget* parent); |     explicit TouchScreenPreview(QWidget* parent); | ||||||
|     ~TouchScreenPreview() override; |     ~TouchScreenPreview() override; | ||||||
|  |  | ||||||
|     void SetCoordLabel(QLabel* const); |     void SetCoordLabel(QLabel*); | ||||||
|     int AddDot(const int device_x, const int device_y); |     int AddDot(int device_x, int device_y); | ||||||
|     void RemoveDot(const int id); |     void RemoveDot(int id); | ||||||
|     void HighlightDot(const int id, const bool active = true) const; |     void HighlightDot(int id, bool active = true) const; | ||||||
|     void MoveDot(const int id, const int device_x, const int device_y) const; |     void MoveDot(int id, int device_x, int device_y) const; | ||||||
|  |  | ||||||
| signals: | signals: | ||||||
|     void DotAdded(const QPoint& pos); |     void DotAdded(const QPoint& pos); | ||||||
|     void DotSelected(const int dot_id); |     void DotSelected(int dot_id); | ||||||
|     void DotMoved(const int dot_id, const QPoint& pos); |     void DotMoved(int dot_id, const QPoint& pos); | ||||||
|  |  | ||||||
| protected: | protected: | ||||||
|     virtual void resizeEvent(QResizeEvent*) override; |     virtual void resizeEvent(QResizeEvent*) override; | ||||||
| @@ -40,8 +40,8 @@ protected: | |||||||
|     virtual bool eventFilter(QObject*, QEvent*) override; |     virtual bool eventFilter(QObject*, QEvent*) override; | ||||||
|  |  | ||||||
| private: | private: | ||||||
|     std::optional<QPoint> MapToDeviceCoords(const int screen_x, const int screen_y) const; |     std::optional<QPoint> MapToDeviceCoords(int screen_x, int screen_y) const; | ||||||
|     void PositionDot(QLabel* const dot, const int device_x = -1, const int device_y = -1) const; |     void PositionDot(QLabel* dot, int device_x = -1, int device_y = -1) const; | ||||||
|  |  | ||||||
|     bool ignore_resize = false; |     bool ignore_resize = false; | ||||||
|     QPointer<QLabel> coord_label; |     QPointer<QLabel> coord_label; | ||||||
| @@ -49,9 +49,9 @@ private: | |||||||
|     std::vector<std::pair<int, QLabel*>> dots; |     std::vector<std::pair<int, QLabel*>> dots; | ||||||
|     int max_dot_id = 0; |     int max_dot_id = 0; | ||||||
|     QColor dot_highlight_color; |     QColor dot_highlight_color; | ||||||
|     static constexpr char prop_id[] = "dot_id"; |     static constexpr char PropId[] = "dot_id"; | ||||||
|     static constexpr char prop_x[] = "device_x"; |     static constexpr char PropX[] = "device_x"; | ||||||
|     static constexpr char prop_y[] = "device_y"; |     static constexpr char PropY[] = "device_y"; | ||||||
|  |  | ||||||
|     struct { |     struct { | ||||||
|         bool active = false; |         bool active = false; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user