Changed Qt debugger ASM viewer to render text a single character at a time to have better control of horizontal char advance. Mac OS seems to not always draw characters with the same spacing if not done this way.

This commit is contained in:
Matthew Budd 2020-11-13 11:27:55 -05:00
parent 58a1d76e2c
commit 836127afd0
2 changed files with 19 additions and 3 deletions

View File

@ -3441,6 +3441,21 @@ void QAsmView::contextMenuEvent(QContextMenuEvent *event)
} }
} }
//---------------------------------------------------------------------------- //----------------------------------------------------------------------------
void QAsmView::drawText( QPainter *painter, int x, int y, const char *txt )
{
int i=0;
char c[2];
c[0] = 0; c[1] = 0;
while ( txt[i] != 0 )
{
c[0] = txt[i];
painter->drawText( x, y, tr(c) );
i++; x += pxCharWidth;
}
}
//----------------------------------------------------------------------------
void QAsmView::paintEvent(QPaintEvent *event) void QAsmView::paintEvent(QPaintEvent *event)
{ {
int x,y,l, row, nrow, selAddr; int x,y,l, row, nrow, selAddr;
@ -3519,7 +3534,7 @@ void QAsmView::paintEvent(QPaintEvent *event)
{ {
painter.setPen( this->palette().color(QPalette::WindowText)); painter.setPen( this->palette().color(QPalette::WindowText));
} }
painter.drawText( x, y, tr(asmEntry[l]->text.c_str()) ); drawText( &painter, x, y, asmEntry[l]->text.c_str() );
if ( (selAddrLine == l) ) if ( (selAddrLine == l) )
{ // Highlight ASM line for selected address. { // Highlight ASM line for selected address.
@ -3535,7 +3550,7 @@ void QAsmView::paintEvent(QPaintEvent *event)
painter.setPen( white ); painter.setPen( white );
painter.drawText( ax, y, tr(selAddrText) ); drawText( &painter, ax, y, selAddrText );
painter.setPen( this->palette().color(QPalette::WindowText)); painter.setPen( this->palette().color(QPalette::WindowText));
} }
@ -3588,7 +3603,7 @@ void QAsmView::paintEvent(QPaintEvent *event)
painter.fillRect( ax, y - pxLineSpacing + pxLineLead, hlgtXd * pxCharWidth, pxLineSpacing, hlgtBG ); painter.fillRect( ax, y - pxLineSpacing + pxLineLead, hlgtXd * pxCharWidth, pxLineSpacing, hlgtBG );
painter.drawText( ax, y, tr(s.c_str()) ); drawText( &painter, ax, y, s.c_str() );
} }
y += pxLineSpacing; y += pxLineSpacing;
} }

View File

@ -128,6 +128,7 @@ class QAsmView : public QWidget
bool textIsHighlighted(void); bool textIsHighlighted(void);
void setHighlightEndCoord( int x, int y ); void setHighlightEndCoord( int x, int y );
void loadClipboard( const char *txt ); void loadClipboard( const char *txt );
void drawText( QPainter *painter, int x, int y, const char *txt );
private: private:
ConsoleDebugger *parent; ConsoleDebugger *parent;