address review comments
This commit is contained in:
parent
e792c3d90c
commit
26a6f64418
|
@ -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