Qt/MemoryViewWidget: Remove the behavior that clicking anywhere in the table centers the table on that row.

This commit is contained in:
Admiral H. Curtiss 2022-04-26 02:43:01 +02:00
parent 88dd9e57f3
commit 7f94e62dd5
No known key found for this signature in database
GPG Key ID: F051B4C4044F33FB
1 changed files with 9 additions and 5 deletions

View File

@ -51,6 +51,7 @@ public:
setVerticalScrollBarPolicy(Qt::ScrollBarAlwaysOff); setVerticalScrollBarPolicy(Qt::ScrollBarAlwaysOff);
setShowGrid(false); setShowGrid(false);
setContextMenuPolicy(Qt::CustomContextMenu); setContextMenuPolicy(Qt::CustomContextMenu);
setSelectionMode(SingleSelection);
connect(this, &MemoryViewTable::customContextMenuRequested, m_view, connect(this, &MemoryViewTable::customContextMenuRequested, m_view,
&MemoryViewWidget::OnContextMenu); &MemoryViewWidget::OnContextMenu);
@ -105,12 +106,16 @@ public:
if (!item) if (!item)
return; return;
const u32 address = item->data(USER_ROLE_CELL_ADDRESS).toUInt();
if (item->data(USER_ROLE_IS_ROW_BREAKPOINT_CELL).toBool()) if (item->data(USER_ROLE_IS_ROW_BREAKPOINT_CELL).toBool())
{
const u32 address = item->data(USER_ROLE_CELL_ADDRESS).toUInt();
m_view->ToggleBreakpoint(address, true); m_view->ToggleBreakpoint(address, true);
m_view->Update();
}
else else
m_view->SetAddress(address); {
m_view->Update(); QTableWidget::mousePressEvent(event);
}
} }
private: private:
@ -284,7 +289,7 @@ void MemoryViewWidget::Update()
for (int c = 2; c < m_table->columnCount(); c++) for (int c = 2; c < m_table->columnCount(); c++)
{ {
auto* item = new QTableWidgetItem(QStringLiteral("-")); auto* item = new QTableWidgetItem(QStringLiteral("-"));
item->setFlags(Qt::ItemIsEnabled); item->setFlags(Qt::ItemIsEnabled | Qt::ItemIsSelectable);
item->setData(USER_ROLE_IS_ROW_BREAKPOINT_CELL, false); item->setData(USER_ROLE_IS_ROW_BREAKPOINT_CELL, false);
item->setData(USER_ROLE_CELL_ADDRESS, row_address); item->setData(USER_ROLE_CELL_ADDRESS, row_address);
item->setData(USER_ROLE_HAS_VALUE, false); item->setData(USER_ROLE_HAS_VALUE, false);
@ -378,7 +383,6 @@ void MemoryViewWidget::UpdateColumns(Type type, int first_column)
} }
else else
{ {
cell_item->setFlags({});
cell_item->setText(QStringLiteral("-")); cell_item->setText(QStringLiteral("-"));
cell_item->setData(USER_ROLE_IS_ROW_BREAKPOINT_CELL, false); cell_item->setData(USER_ROLE_IS_ROW_BREAKPOINT_CELL, false);
cell_item->setData(USER_ROLE_CELL_ADDRESS, cell_address); cell_item->setData(USER_ROLE_CELL_ADDRESS, cell_address);