Merge pull request #6826 from spycrab/qt_netplay2

Qt/NetPlayDialog: Improve player list
This commit is contained in:
Léo Lam 2018-05-13 01:17:51 +02:00 committed by GitHub
commit ad5a69be79
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 79 additions and 29 deletions

View File

@ -1271,6 +1271,16 @@ void NetPlayClient::ComputeMD5(const std::string& file_identifier)
m_MD5_thread.detach(); m_MD5_thread.detach();
} }
const PadMappingArray& NetPlayClient::GetPadMapping() const
{
return m_pad_map;
}
const PadMappingArray& NetPlayClient::GetWiimoteMapping() const
{
return m_wiimote_map;
}
// stuff hacked into dolphin // stuff hacked into dolphin
// called from ---CPU--- thread // called from ---CPU--- thread

View File

@ -98,6 +98,9 @@ public:
static void SendTimeBase(); static void SendTimeBase();
bool DoAllPlayersHaveGame(); bool DoAllPlayersHaveGame();
const PadMappingArray& GetPadMapping() const;
const PadMappingArray& GetWiimoteMapping() const;
protected: protected:
void ClearBuffers(); void ClearBuffers();

View File

@ -12,15 +12,16 @@
#include <QGridLayout> #include <QGridLayout>
#include <QGroupBox> #include <QGroupBox>
#include <QHBoxLayout> #include <QHBoxLayout>
#include <QHeaderView>
#include <QLabel> #include <QLabel>
#include <QLineEdit> #include <QLineEdit>
#include <QListWidget>
#include <QMenu> #include <QMenu>
#include <QMessageBox> #include <QMessageBox>
#include <QProgressDialog> #include <QProgressDialog>
#include <QPushButton> #include <QPushButton>
#include <QSpinBox> #include <QSpinBox>
#include <QSplitter> #include <QSplitter>
#include <QTableWidget>
#include <QTextBrowser> #include <QTextBrowser>
#include <QToolButton> #include <QToolButton>
@ -163,10 +164,18 @@ void NetPlayDialog::CreatePlayersLayout()
m_room_box = new QComboBox; m_room_box = new QComboBox;
m_hostcode_label = new QLabel; m_hostcode_label = new QLabel;
m_hostcode_action_button = new QPushButton(tr("Copy")); m_hostcode_action_button = new QPushButton(tr("Copy"));
m_players_list = new QListWidget; m_players_list = new QTableWidget;
m_kick_button = new QPushButton(tr("Kick Player")); m_kick_button = new QPushButton(tr("Kick Player"));
m_assign_ports_button = new QPushButton(tr("Assign Controller Ports")); m_assign_ports_button = new QPushButton(tr("Assign Controller Ports"));
m_players_list->setColumnCount(5);
m_players_list->verticalHeader()->hide();
m_players_list->setSelectionBehavior(QAbstractItemView::SelectRows);
m_players_list->horizontalHeader()->setStretchLastSection(true);
for (int i = 0; i < 4; i++)
m_players_list->horizontalHeader()->setSectionResizeMode(i, QHeaderView::ResizeToContents);
auto* layout = new QGridLayout; auto* layout = new QGridLayout;
layout->addWidget(m_room_box, 0, 0); layout->addWidget(m_room_box, 0, 0);
@ -190,7 +199,7 @@ void NetPlayDialog::ConnectWidgets()
else else
QApplication::clipboard()->setText(m_hostcode_label->text()); QApplication::clipboard()->setText(m_hostcode_label->text());
}); });
connect(m_players_list, &QListWidget::itemSelectionChanged, [this] { connect(m_players_list, &QTableWidget::itemSelectionChanged, [this] {
int row = m_players_list->currentRow(); int row = m_players_list->currentRow();
m_kick_button->setEnabled(row > 0 && m_kick_button->setEnabled(row > 0 &&
!m_players_list->currentItem()->data(Qt::UserRole).isNull()); !m_players_list->currentItem()->data(Qt::UserRole).isNull());
@ -338,38 +347,66 @@ void NetPlayDialog::show(std::string nickname, bool use_traversal)
void NetPlayDialog::UpdateGUI() void NetPlayDialog::UpdateGUI()
{ {
// Update player list auto* client = Settings::Instance().GetNetPlayClient();
std::vector<int> player_ids;
std::string tmp;
Settings::Instance().GetNetPlayClient()->GetPlayerList(tmp, player_ids); // Update Player List
const auto players = client->GetPlayers();
const auto player_count = static_cast<int>(players.size());
std::istringstream ss(tmp); int selection_pid = m_players_list->currentItem() ?
m_players_list->currentItem()->data(Qt::UserRole).toInt() :
int row = m_players_list->currentRow(); -1;
unsigned int i = 0;
m_players_list->clear(); m_players_list->clear();
m_players_list->setHorizontalHeaderLabels(
{tr("Player"), tr("Game Status"), tr("Ping"), tr("Mapping"), tr("Revision")});
m_players_list->setRowCount(player_count);
while (std::getline(ss, tmp)) const auto get_mapping_string = [](const Player* player, const PadMappingArray& array) {
std::string str;
for (size_t i = 0; i < array.size(); i++)
{ {
auto text = QString::fromStdString(tmp); if (player->pid == array[i])
if (!text.isEmpty()) str += std::to_string(i + 1);
{ else
QListWidgetItem* item = new QListWidgetItem(text); str += '-';
if (player_ids.size() > i && !text.startsWith(QStringLiteral("Ping:")) &&
!text.startsWith(QStringLiteral("Status:")))
{
item->setData(Qt::UserRole, player_ids[i]);
i++;
}
m_players_list->addItem(item);
}
} }
if (row != -1) return '|' + str + '|';
m_players_list->setCurrentRow(row, QItemSelectionModel::SelectCurrent); };
static const std::map<PlayerGameStatus, QString> player_status{
{PlayerGameStatus::Ok, tr("OK")}, {PlayerGameStatus::NotFound, tr("Not Found")}};
for (int i = 0; i < player_count; i++)
{
const auto* p = players[i];
auto* name_item = new QTableWidgetItem(QString::fromStdString(p->name));
auto* status_item = new QTableWidgetItem(player_status.count(p->game_status) ?
player_status.at(p->game_status) :
QStringLiteral("?"));
auto* ping_item = new QTableWidgetItem(QStringLiteral("%1 ms").arg(p->ping));
auto* mapping_item = new QTableWidgetItem(
QString::fromStdString(get_mapping_string(p, client->GetPadMapping()) +
get_mapping_string(p, client->GetWiimoteMapping())));
auto* revision_item = new QTableWidgetItem(QString::fromStdString(p->revision));
for (auto* item : {name_item, status_item, ping_item, mapping_item, revision_item})
{
item->setFlags(Qt::ItemIsEnabled | Qt::ItemIsSelectable);
item->setData(Qt::UserRole, static_cast<int>(p->pid));
}
m_players_list->setItem(i, 0, name_item);
m_players_list->setItem(i, 1, status_item);
m_players_list->setItem(i, 2, ping_item);
m_players_list->setItem(i, 3, mapping_item);
m_players_list->setItem(i, 4, revision_item);
if (p->pid == selection_pid)
m_players_list->selectRow(i);
}
// Update Room ID / IP label // Update Room ID / IP label
if (m_use_traversal && m_room_box->currentIndex() == 0) if (m_use_traversal && m_room_box->currentIndex() == 0)

View File

@ -19,10 +19,10 @@ class QGridLayout;
class QGroupBox; class QGroupBox;
class QLabel; class QLabel;
class QLineEdit; class QLineEdit;
class QListWidget;
class QPushButton; class QPushButton;
class QSpinBox; class QSpinBox;
class QSplitter; class QSplitter;
class QTableWidget;
class QTextEdit; class QTextEdit;
class QToolButton; class QToolButton;
@ -85,7 +85,7 @@ private:
QComboBox* m_room_box; QComboBox* m_room_box;
QLabel* m_hostcode_label; QLabel* m_hostcode_label;
QPushButton* m_hostcode_action_button; QPushButton* m_hostcode_action_button;
QListWidget* m_players_list; QTableWidget* m_players_list;
QPushButton* m_kick_button; QPushButton* m_kick_button;
QPushButton* m_assign_ports_button; QPushButton* m_assign_ports_button;