GUI: resolved issue #216 (additional option to copy a resized table)
This commit is contained in:
parent
da607528b1
commit
fd8f2d2239
|
@ -316,7 +316,7 @@ void StdTable::copyLineSlot()
|
||||||
Bridge::CopyToClipboard(finalText);
|
Bridge::CopyToClipboard(finalText);
|
||||||
}
|
}
|
||||||
|
|
||||||
void StdTable::copyTableSlot()
|
void StdTable::copyTable(std::function<int (int)> getMaxColumnLength)
|
||||||
{
|
{
|
||||||
int colCount = getColumnCount();
|
int colCount = getColumnCount();
|
||||||
int rowCount = getRowCount();
|
int rowCount = getRowCount();
|
||||||
|
@ -333,12 +333,14 @@ void StdTable::copyTableSlot()
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
int charwidth = getCharWidth();
|
std::vector<int> colWidths;
|
||||||
|
for(int i = 0; i < colCount; i++)
|
||||||
|
colWidths.push_back(getMaxColumnLength(i));
|
||||||
for(int i = 0; i < colCount; i++)
|
for(int i = 0; i < colCount; i++)
|
||||||
{
|
{
|
||||||
if(i)
|
if(i)
|
||||||
finalText += " ";
|
finalText += " ";
|
||||||
int colWidth = getColumnWidth(i) / charwidth;
|
int colWidth = colWidths[i];
|
||||||
if(colWidth)
|
if(colWidth)
|
||||||
finalText += getColTitle(i).leftJustified(colWidth, QChar(' '), true);
|
finalText += getColTitle(i).leftJustified(colWidth, QChar(' '), true);
|
||||||
else
|
else
|
||||||
|
@ -353,7 +355,7 @@ void StdTable::copyTableSlot()
|
||||||
if(j)
|
if(j)
|
||||||
finalRowText += " ";
|
finalRowText += " ";
|
||||||
QString cellContent = getCellContent(i, j);
|
QString cellContent = getCellContent(i, j);
|
||||||
int colWidth = getColumnWidth(j) / charwidth;
|
int colWidth = colWidths[j];
|
||||||
if(colWidth && j != colCount - 1)
|
if(colWidth && j != colCount - 1)
|
||||||
finalRowText += cellContent.leftJustified(colWidth, QChar(' '), true);
|
finalRowText += cellContent.leftJustified(colWidth, QChar(' '), true);
|
||||||
else
|
else
|
||||||
|
@ -365,6 +367,26 @@ void StdTable::copyTableSlot()
|
||||||
Bridge::CopyToClipboard(finalText);
|
Bridge::CopyToClipboard(finalText);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void StdTable::copyTableSlot()
|
||||||
|
{
|
||||||
|
copyTable([this](int col)
|
||||||
|
{
|
||||||
|
return getColumnWidth(col) / getCharWidth();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
void StdTable::copyTableResizeSlot()
|
||||||
|
{
|
||||||
|
copyTable([this](int col)
|
||||||
|
{
|
||||||
|
int max = 0;
|
||||||
|
int rowCount = getRowCount();
|
||||||
|
for(int i = 0; i < rowCount; i++)
|
||||||
|
max = std::max(getCellContent(i, col).length(), max);
|
||||||
|
return max;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
void StdTable::copyEntrySlot()
|
void StdTable::copyEntrySlot()
|
||||||
{
|
{
|
||||||
QAction* action = qobject_cast<QAction*>(sender());
|
QAction* action = qobject_cast<QAction*>(sender());
|
||||||
|
@ -381,13 +403,17 @@ void StdTable::setupCopyMenu(QMenu* copyMenu)
|
||||||
if(!getColumnCount())
|
if(!getColumnCount())
|
||||||
return;
|
return;
|
||||||
//Copy->Whole Line
|
//Copy->Whole Line
|
||||||
QAction* mCopyLine = new QAction(tr("Whole &Line"), this);
|
QAction* mCopyLine = new QAction(tr("&Line"), copyMenu);
|
||||||
connect(mCopyLine, SIGNAL(triggered()), this, SLOT(copyLineSlot()));
|
connect(mCopyLine, SIGNAL(triggered()), this, SLOT(copyLineSlot()));
|
||||||
copyMenu->addAction(mCopyLine);
|
copyMenu->addAction(mCopyLine);
|
||||||
//Copy->Whole Table
|
//Copy->Cropped Table
|
||||||
QAction* mCopyTable = new QAction(tr("Whole &Table"), this);
|
QAction* mCopyTable = new QAction(tr("Cropped &Table"), copyMenu);
|
||||||
connect(mCopyTable, SIGNAL(triggered()), this, SLOT(copyTableSlot()));
|
connect(mCopyTable, SIGNAL(triggered()), this, SLOT(copyTableSlot()));
|
||||||
copyMenu->addAction(mCopyTable);
|
copyMenu->addAction(mCopyTable);
|
||||||
|
//Copy->Full Table
|
||||||
|
QAction* mCopyTableResize = new QAction(tr("&Full Table"), copyMenu);
|
||||||
|
connect(mCopyTableResize, SIGNAL(triggered()), this, SLOT(copyTableResizeSlot()));
|
||||||
|
copyMenu->addAction(mCopyTableResize);
|
||||||
//Copy->Separator
|
//Copy->Separator
|
||||||
copyMenu->addSeparator();
|
copyMenu->addSeparator();
|
||||||
//Copy->ColName
|
//Copy->ColName
|
||||||
|
@ -398,7 +424,7 @@ void StdTable::setupCopyMenu(QMenu* copyMenu)
|
||||||
QString title = mCopyTitles.at(i);
|
QString title = mCopyTitles.at(i);
|
||||||
if(!title.length()) //skip empty copy titles
|
if(!title.length()) //skip empty copy titles
|
||||||
continue;
|
continue;
|
||||||
QAction* mCopyAction = new QAction(title, this);
|
QAction* mCopyAction = new QAction(title, copyMenu);
|
||||||
mCopyAction->setObjectName(QString::number(i));
|
mCopyAction->setObjectName(QString::number(i));
|
||||||
connect(mCopyAction, SIGNAL(triggered()), this, SLOT(copyEntrySlot()));
|
connect(mCopyAction, SIGNAL(triggered()), this, SLOT(copyEntrySlot()));
|
||||||
copyMenu->addAction(mCopyAction);
|
copyMenu->addAction(mCopyAction);
|
||||||
|
|
|
@ -49,11 +49,14 @@ signals:
|
||||||
public slots:
|
public slots:
|
||||||
void copyLineSlot();
|
void copyLineSlot();
|
||||||
void copyTableSlot();
|
void copyTableSlot();
|
||||||
|
void copyTableResizeSlot();
|
||||||
void copyEntrySlot();
|
void copyEntrySlot();
|
||||||
void contextMenuRequestedSlot(const QPoint & pos);
|
void contextMenuRequestedSlot(const QPoint & pos);
|
||||||
void headerButtonPressedSlot(int col);
|
void headerButtonPressedSlot(int col);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
void copyTable(std::function<int(int)> getMaxColSize);
|
||||||
|
|
||||||
class ColumnCompare
|
class ColumnCompare
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
|
|
@ -270,7 +270,7 @@ void CPUInfoBox::addFollowMenuItem(QMenu* menu, QString name, dsint value)
|
||||||
foreach(QAction * action, menu->actions()) //check for duplicate action
|
foreach(QAction * action, menu->actions()) //check for duplicate action
|
||||||
if(action->text() == name)
|
if(action->text() == name)
|
||||||
return;
|
return;
|
||||||
QAction* newAction = new QAction(name, this);
|
QAction* newAction = new QAction(name, menu);
|
||||||
newAction->setFont(QFont("Courier New", 8));
|
newAction->setFont(QFont("Courier New", 8));
|
||||||
menu->addAction(newAction);
|
menu->addAction(newAction);
|
||||||
newAction->setObjectName(QString("DUMP|") + QString("%1").arg(value, sizeof(dsint) * 2, 16, QChar('0')).toUpper());
|
newAction->setObjectName(QString("DUMP|") + QString("%1").arg(value, sizeof(dsint) * 2, 16, QChar('0')).toUpper());
|
||||||
|
|
Loading…
Reference in New Issue