Changed Qt name table viewer layout to more like mesen.

This commit is contained in:
mjbudd77 2021-01-28 22:33:28 -05:00
parent b5008d89bc
commit aff634b0ed
2 changed files with 320 additions and 308 deletions

View File

@ -37,6 +37,7 @@
#include "../../debug.h" #include "../../debug.h"
#include "../../palette.h" #include "../../palette.h"
#include "Qt/ConsoleUtilities.h"
#include "Qt/NameTableViewer.h" #include "Qt/NameTableViewer.h"
#include "Qt/main.h" #include "Qt/main.h"
#include "Qt/dface.h" #include "Qt/dface.h"
@ -55,9 +56,12 @@ static int xpos = 0, ypos = 0;
static int attview = 0; static int attview = 0;
static int hidepal = 0; static int hidepal = 0;
static bool drawScrollLines = true; static bool drawScrollLines = true;
static bool drawGridLines = true; static bool drawTileGridLines = true;
static bool drawAttrGridLines = false;
static bool redrawtables = true; static bool redrawtables = true;
//extern int FCEUPPU_GetAttr(int ntnum, int xt, int yt);
// checkerboard tile for attribute view // checkerboard tile for attribute view
static const uint8_t ATTRIBUTE_VIEW_TILE[16] = { 0x0F, 0x0F, 0x0F, 0x0F, 0x0F, 0x0F, 0x0F, 0x0F, 0x00, 0x00, 0x00, 0x00, 0xFF, 0xFF, 0xFF, 0xFF }; static const uint8_t ATTRIBUTE_VIEW_TILE[16] = { 0x0F, 0x0F, 0x0F, 0x0F, 0x0F, 0x0F, 0x0F, 0x0F, 0x00, 0x00, 0x00, 0x00, 0xFF, 0xFF, 0xFF, 0xFF };
@ -88,7 +92,7 @@ enum NT_MirrorType
static NT_MirrorType ntmirroring = NT_NONE, oldntmirroring = NT_NONE; static NT_MirrorType ntmirroring = NT_NONE, oldntmirroring = NT_NONE;
static void initNameTableViewer(void); static void initNameTableViewer(void);
static void ChangeMirroring(void); //static void ChangeMirroring(void);
//---------------------------------------------------- //----------------------------------------------------
int openNameTableViewWindow( QWidget *parent ) int openNameTableViewWindow( QWidget *parent )
{ {
@ -108,16 +112,24 @@ int openNameTableViewWindow( QWidget *parent )
ppuNameTableViewerDialog_t::ppuNameTableViewerDialog_t(QWidget *parent) ppuNameTableViewerDialog_t::ppuNameTableViewerDialog_t(QWidget *parent)
: QDialog( parent, Qt::Window ) : QDialog( parent, Qt::Window )
{ {
QVBoxLayout *mainLayout, *vbox; QHBoxLayout *mainLayout;
QHBoxLayout *hbox; QVBoxLayout *vbox1, *vbox2;
QHBoxLayout *hbox, *hbox1;
QGridLayout *grid; QGridLayout *grid;
QGroupBox *frame; QGroupBox *frame;
QMenuBar *menuBar; QMenuBar *menuBar;
QMenu *viewMenu, *subMenu; QMenu *viewMenu, *subMenu;
QAction *act, *zoomAct[4]; QAction *act, *zoomAct[4];
QActionGroup *group; QActionGroup *group;
QLabel *lbl;
QFont font;
char stmp[64]; char stmp[64];
int useNativeMenuBar; int useNativeMenuBar;
fceuDecIntValidtor *validator;
font.setFamily("Courier New");
font.setStyle( QFont::StyleNormal );
font.setStyleHint( QFont::Monospace );
nameTableViewWindow = this; nameTableViewWindow = this;
@ -148,13 +160,13 @@ ppuNameTableViewerDialog_t::ppuNameTableViewerDialog_t(QWidget *parent)
viewMenu->addAction(act); viewMenu->addAction(act);
// View -> Show Grid Lines // View -> Show Grid Lines
act = new QAction(tr("Show Grid Lines"), this); act = new QAction(tr("Show Tile Grid"), this);
//act->setShortcut(QKeySequence::Open); //act->setShortcut(QKeySequence::Open);
act->setCheckable(true); act->setCheckable(true);
act->setChecked(drawGridLines); act->setChecked(drawTileGridLines);
act->setStatusTip(tr("Show Grid Lines")); act->setStatusTip(tr("Show Tile Grid"));
connect(act, SIGNAL(triggered(bool)), this, SLOT(menuGridLinesChanged(bool)) ); connect(act, SIGNAL(triggered(bool)), this, SLOT(menuGridLinesChanged(bool)) );
showGridLineAct = act; showTileGridAct = act;
viewMenu->addAction(act); viewMenu->addAction(act);
@ -219,18 +231,17 @@ ppuNameTableViewerDialog_t::ppuNameTableViewerDialog_t(QWidget *parent)
setWindowTitle( tr("Name Table Viewer") ); setWindowTitle( tr("Name Table Viewer") );
mainLayout = new QVBoxLayout(); mainLayout = new QHBoxLayout();
mainLayout->setMenuBar( menuBar ); mainLayout->setMenuBar( menuBar );
setLayout( mainLayout ); setLayout( mainLayout );
//vbox = new QVBoxLayout(); vbox1 = new QVBoxLayout();
//frame = new QGroupBox( tr("Name Tables") ); vbox2 = new QVBoxLayout();
frame = new QGroupBox( tr("Tile Info") );
ntView = new ppuNameTableView_t(this); ntView = new ppuNameTableView_t(this);
grid = new QGridLayout(); grid = new QGridLayout();
ctlPanelFrame = new QFrame();
//nameTableFrame = new QFrame();
scrollArea = new QScrollArea(); scrollArea = new QScrollArea();
scrollArea->setWidgetResizable(false); scrollArea->setWidgetResizable(false);
@ -239,115 +250,146 @@ ppuNameTableViewerDialog_t::ppuNameTableViewerDialog_t(QWidget *parent)
scrollArea->setVerticalScrollBarPolicy( Qt::ScrollBarAsNeeded ); scrollArea->setVerticalScrollBarPolicy( Qt::ScrollBarAsNeeded );
scrollArea->setMinimumSize( QSize( 512, 480 ) ); scrollArea->setMinimumSize( QSize( 512, 480 ) );
//vbox->addWidget( ntView );
//nameTableFrame->setLayout( vbox );
scrollArea->setWidget( ntView );
mainLayout->addWidget( scrollArea, 100 );
mainLayout->addWidget( ctlPanelFrame, 1 );
ctlPanelFrame->setLayout( grid );
ntView->setScrollPointer( scrollArea ); ntView->setScrollPointer( scrollArea );
scrollArea->setWidget( ntView );
mainLayout->addLayout( vbox1, 100 );
mainLayout->addLayout( vbox2, 1 );
vbox1->addWidget( scrollArea, 100 );
vbox2->addWidget( frame );
frame->setLayout( grid );
lbl = new QLabel( tr("PPU Addr:") );
lbl->setFont( font );
grid->addWidget( lbl, 0, 0, Qt::AlignLeft );
lbl = new QLabel( tr("Name Table:") );
lbl->setFont( font );
grid->addWidget( lbl, 1, 0, Qt::AlignLeft );
lbl = new QLabel( tr("Location:") );
lbl->setFont( font );
grid->addWidget( lbl, 2, 0, Qt::AlignLeft );
lbl = new QLabel( tr("Tile Index:") );
lbl->setFont( font );
grid->addWidget( lbl, 3, 0, Qt::AlignLeft );
lbl = new QLabel( tr("Tile Addr:") );
lbl->setFont( font );
grid->addWidget( lbl, 4, 0, Qt::AlignLeft );
lbl = new QLabel( tr("Attribute Data:") );
lbl->setFont( font );
grid->addWidget( lbl, 5, 0, Qt::AlignLeft );
lbl = new QLabel( tr("Attribute Addr:") );
lbl->setFont( font );
grid->addWidget( lbl, 6, 0, Qt::AlignLeft );
lbl = new QLabel( tr("Palette Addr:") );
lbl->setFont( font );
grid->addWidget( lbl, 7, 0, Qt::AlignLeft );
ppuAddrLbl = new QLineEdit();
ppuAddrLbl->setReadOnly(true);
grid->addWidget( ppuAddrLbl, 0, 1, Qt::AlignLeft );
nameTableLbl = new QLineEdit();
nameTableLbl->setReadOnly(true);
grid->addWidget( nameTableLbl, 1, 1, Qt::AlignLeft );
tileLocLbl = new QLineEdit();
tileLocLbl->setReadOnly(true);
grid->addWidget( tileLocLbl, 2, 1, Qt::AlignLeft );
tileIdxLbl = new QLineEdit();
tileIdxLbl->setReadOnly(true);
grid->addWidget( tileIdxLbl, 3, 1, Qt::AlignLeft );
tileAddrLbl = new QLineEdit();
tileAddrLbl->setReadOnly(true);
grid->addWidget( tileAddrLbl, 4, 1, Qt::AlignLeft );
attrDataLbl = new QLineEdit();
attrDataLbl->setReadOnly(true);
grid->addWidget( attrDataLbl, 5, 1, Qt::AlignLeft );
attrAddrLbl = new QLineEdit();
attrAddrLbl->setReadOnly(true);
grid->addWidget( attrAddrLbl, 6, 1, Qt::AlignLeft );
palAddrLbl = new QLineEdit();
palAddrLbl->setReadOnly(true);
grid->addWidget( palAddrLbl, 7, 1, Qt::AlignLeft );
showScrollLineCbox = new QCheckBox( tr("Show Scroll Lines") ); showScrollLineCbox = new QCheckBox( tr("Show Scroll Lines") );
showGridLineCbox = new QCheckBox( tr("Show Grid Lines") ); showTileGridCbox = new QCheckBox( tr("Show Tile Grid") );
showAttrGridCbox = new QCheckBox( tr("Show Attr Grid") );
showAttrbCbox = new QCheckBox( tr("Show Attributes") ); showAttrbCbox = new QCheckBox( tr("Show Attributes") );
ignorePaletteCbox = new QCheckBox( tr("Ignore Palette") ); ignorePaletteCbox = new QCheckBox( tr("Ignore Palette") );
showScrollLineCbox->setChecked( drawScrollLines ); showScrollLineCbox->setChecked( drawScrollLines );
showGridLineCbox->setChecked( drawGridLines ); showTileGridCbox->setChecked( drawTileGridLines );
showAttrGridCbox->setChecked( drawAttrGridLines );
showAttrbCbox->setChecked( attview ); showAttrbCbox->setChecked( attview );
ignorePaletteCbox->setChecked( hidepal ); ignorePaletteCbox->setChecked( hidepal );
grid->addWidget( showScrollLineCbox, 0, 0, Qt::AlignLeft ); vbox2->addWidget( showScrollLineCbox );
grid->addWidget( showGridLineCbox , 1, 0, Qt::AlignLeft ); vbox2->addWidget( showTileGridCbox );
grid->addWidget( showAttrbCbox , 2, 0, Qt::AlignLeft ); vbox2->addWidget( showAttrGridCbox );
grid->addWidget( ignorePaletteCbox , 2, 1, Qt::AlignLeft ); vbox2->addWidget( showAttrbCbox );
vbox2->addWidget( ignorePaletteCbox );
connect( showScrollLineCbox, SIGNAL(stateChanged(int)), this, SLOT(showScrollLinesChanged(int))); connect( showScrollLineCbox, SIGNAL(stateChanged(int)), this, SLOT(showScrollLinesChanged(int)));
connect( showGridLineCbox , SIGNAL(stateChanged(int)), this, SLOT(showGridLinesChanged(int))); connect( showTileGridCbox , SIGNAL(stateChanged(int)), this, SLOT(showTileGridChanged(int)));
connect( showAttrGridCbox , SIGNAL(stateChanged(int)), this, SLOT(showAttrGridChanged(int)));
connect( showAttrbCbox , SIGNAL(stateChanged(int)), this, SLOT(showAttrbChanged(int))); connect( showAttrbCbox , SIGNAL(stateChanged(int)), this, SLOT(showAttrbChanged(int)));
connect( ignorePaletteCbox , SIGNAL(stateChanged(int)), this, SLOT(ignorePaletteChanged(int))); connect( ignorePaletteCbox , SIGNAL(stateChanged(int)), this, SLOT(ignorePaletteChanged(int)));
//
// hbox = new QHBoxLayout();
// refreshSlider = new QSlider( Qt::Horizontal );
// hbox->addWidget( new QLabel( tr("Refresh: More") ) );
// hbox->addWidget( refreshSlider );
// hbox->addWidget( new QLabel( tr("Less") ) );
// grid->addLayout( hbox, 0, 1, Qt::AlignRight );
//
// refreshSlider->setMinimum( 0);
// refreshSlider->setMaximum(25);
// refreshSlider->setValue(NTViewRefresh);
//
// connect( refreshSlider, SIGNAL(valueChanged(int)), this, SLOT(refreshSliderChanged(int)));
//
hbox1 = new QHBoxLayout();
hbox = new QHBoxLayout();
vbox1->addLayout( hbox1, 1);
lbl = new QLabel( tr("Mirroring Type:") );
mirrorLbl = new QLabel( tr("Vertical") );
hbox->addWidget( lbl , 1, Qt::AlignRight );
hbox->addWidget( mirrorLbl, 1, Qt::AlignLeft );
hbox1->addLayout( hbox, 1 );
hbox = new QHBoxLayout(); hbox = new QHBoxLayout();
refreshSlider = new QSlider( Qt::Horizontal );
hbox->addWidget( new QLabel( tr("Refresh: More") ) );
hbox->addWidget( refreshSlider );
hbox->addWidget( new QLabel( tr("Less") ) );
grid->addLayout( hbox, 0, 1, Qt::AlignRight );
refreshSlider->setMinimum( 0);
refreshSlider->setMaximum(25);
refreshSlider->setValue(NTViewRefresh);
connect( refreshSlider, SIGNAL(valueChanged(int)), this, SLOT(refreshSliderChanged(int)));
hbox = new QHBoxLayout();
scanLineEdit = new QLineEdit(); scanLineEdit = new QLineEdit();
hbox->addWidget( new QLabel( tr("Display on Scanline:") ) ); hbox->addWidget( new QLabel( tr("Display on Scanline:") ), 1, Qt::AlignRight );
hbox->addWidget( scanLineEdit ); hbox->addWidget( scanLineEdit, 1, Qt::AlignLeft );
grid->addLayout( hbox, 1, 1, Qt::AlignRight );
hbox1->addLayout( hbox, 1 );
validator = new fceuDecIntValidtor( 0, 255, this );
scanLineEdit->setMaxLength( 3 ); scanLineEdit->setMaxLength( 3 );
scanLineEdit->setInputMask( ">900;" ); scanLineEdit->setValidator( validator );
sprintf( stmp, "%i", NTViewScanline ); sprintf( stmp, "%i", NTViewScanline );
scanLineEdit->setText( tr(stmp) ); scanLineEdit->setText( tr(stmp) );
connect( scanLineEdit, SIGNAL(textEdited(const QString &)), this, SLOT(scanLineChanged(const QString &))); connect( scanLineEdit, SIGNAL(textEdited(const QString &)), this, SLOT(scanLineChanged(const QString &)));
hbox = new QHBoxLayout();
frame = new QGroupBox( tr("Current Mirroring") );
grid = new QGridLayout();
mirrorGroup = frame;
mainLayout->addLayout( hbox, 1 );
hbox->addWidget( frame );
frame->setLayout( grid );
horzMirrorBtn = new QRadioButton( tr("Horizontal") );
vertMirrorBtn = new QRadioButton( tr("Vertical") );
fourScreenBtn = new QRadioButton( tr("Four Screen") );
singleScreenBtn[0] = new QRadioButton( tr("Single Screen 0") );
singleScreenBtn[1] = new QRadioButton( tr("Single Screen 1") );
singleScreenBtn[2] = new QRadioButton( tr("Single Screen 2") );
singleScreenBtn[3] = new QRadioButton( tr("Single Screen 3") );
grid->addWidget( horzMirrorBtn, 0, 0, Qt::AlignLeft );
grid->addWidget( vertMirrorBtn, 1, 0, Qt::AlignLeft );
grid->addWidget( fourScreenBtn, 2, 0, Qt::AlignLeft );
grid->addWidget( singleScreenBtn[0], 0, 1, Qt::AlignLeft );
grid->addWidget( singleScreenBtn[1], 1, 1, Qt::AlignLeft );
grid->addWidget( singleScreenBtn[2], 2, 1, Qt::AlignLeft );
grid->addWidget( singleScreenBtn[3], 3, 1, Qt::AlignLeft );
connect( horzMirrorBtn , SIGNAL(clicked(void)), this, SLOT(horzMirrorClicked(void)));
connect( vertMirrorBtn , SIGNAL(clicked(void)), this, SLOT(vertMirrorClicked(void)));
connect( fourScreenBtn , SIGNAL(clicked(void)), this, SLOT(fourScreenClicked(void)));
connect( singleScreenBtn[0], SIGNAL(clicked(void)), this, SLOT(singleScreen0Clicked(void)));
connect( singleScreenBtn[1], SIGNAL(clicked(void)), this, SLOT(singleScreen1Clicked(void)));
connect( singleScreenBtn[2], SIGNAL(clicked(void)), this, SLOT(singleScreen2Clicked(void)));
connect( singleScreenBtn[3], SIGNAL(clicked(void)), this, SLOT(singleScreen3Clicked(void)));
updateMirrorButtons();
vbox = new QVBoxLayout();
frame = new QGroupBox( tr("Properties") );
hbox->addWidget( frame );
frame->setLayout( vbox );
dataDisplayGroup = frame;
tileID = new QLabel( tr("Tile ID:") );
tileXY = new QLabel( tr("X/Y :") );
ppuAddrLbl = new QLabel( tr("PPU Address:") );
attrbLbl = new QLabel( tr("Attribute:") );
vbox->addWidget( tileID );
vbox->addWidget( tileXY );
vbox->addWidget( ppuAddrLbl );
vbox->addWidget( attrbLbl );
FCEUD_UpdateNTView( -1, true); FCEUD_UpdateNTView( -1, true);
updateTimer = new QTimer( this ); updateTimer = new QTimer( this );
@ -356,6 +398,7 @@ ppuNameTableViewerDialog_t::ppuNameTableViewerDialog_t(QWidget *parent)
updateTimer->start( 33 ); // 30hz updateTimer->start( 33 ); // 30hz
updateMirrorText();
updateVisibility(); updateVisibility();
} }
//---------------------------------------------------- //----------------------------------------------------
@ -384,13 +427,12 @@ void ppuNameTableViewerDialog_t::closeWindow(void)
//---------------------------------------------------- //----------------------------------------------------
void ppuNameTableViewerDialog_t::periodicUpdate(void) void ppuNameTableViewerDialog_t::periodicUpdate(void)
{ {
updateMirrorButtons(); updateMirrorText();
if ( redrawtables ) if ( redrawtables )
{ {
//this->update();
//this->scrollArea->update();
this->scrollArea->viewport()->update(); this->scrollArea->viewport()->update();
redrawtables = false; redrawtables = false;
} }
} }
@ -418,110 +460,84 @@ void ppuNameTableViewerDialog_t::changeZoom4x(void)
void ppuNameTableViewerDialog_t::updateVisibility(void) void ppuNameTableViewerDialog_t::updateVisibility(void)
{ {
if ( compactView ) //if ( compactView )
{ //{
ctlPanelFrame->hide(); // ctlPanelFrame->hide();
mirrorGroup->hide(); // mirrorGroup->hide();
dataDisplayGroup->hide(); // dataDisplayGroup->hide();
} //}
else //else
{ //{
ctlPanelFrame->show(); // ctlPanelFrame->show();
mirrorGroup->show(); // mirrorGroup->show();
dataDisplayGroup->show(); // dataDisplayGroup->show();
} //}
} }
//---------------------------------------------------- //----------------------------------------------------
void ppuNameTableViewerDialog_t::setPropertyLabels( int TileID, int TileX, int TileY, int NameTable, int PPUAddress, int AttAddress, int Attrib ) void ppuNameTableViewerDialog_t::setPropertyLabels( int TileID, int TileX, int TileY, int NameTable, int PPUAddress, int AttAddress, int Attrib, int palAddr )
{ {
char stmp[64]; char stmp[32];
sprintf( stmp, "Tile ID: %02X", TileID); sprintf( stmp, "%02X", TileID);
tileIdxLbl->setText( tr(stmp) );
tileID->setText( tr(stmp) ); sprintf( stmp, "%04X", TileID << 4);
tileAddrLbl->setText( tr(stmp) );
sprintf( stmp, "X/Y : %0d/%0d", TileX, TileY); sprintf( stmp, "%0d, %0d", TileX, TileY);
tileLocLbl->setText( tr(stmp) );
tileXY->setText( tr(stmp) );
sprintf(stmp,"PPU Address: %04X",PPUAddress);
sprintf(stmp,"%04X",PPUAddress);
ppuAddrLbl->setText( tr(stmp) ); ppuAddrLbl->setText( tr(stmp) );
sprintf(stmp,"Attribute: %1X (%04X)",Attrib,AttAddress); sprintf(stmp,"%1X",NameTable);
nameTableLbl->setText( tr(stmp) );
sprintf(stmp,"%02X",Attrib);
attrDataLbl->setText( tr(stmp) );
sprintf(stmp,"%04X",AttAddress);
attrAddrLbl->setText( tr(stmp) );
sprintf(stmp,"%04X", palAddr );
palAddrLbl->setText( tr(stmp) );
attrbLbl->setText( tr(stmp) );
} }
//---------------------------------------------------- //----------------------------------------------------
void ppuNameTableViewerDialog_t::updateMirrorButtons(void) void ppuNameTableViewerDialog_t::updateMirrorText(void)
{ {
const char *txt = "";
switch ( ntmirroring ) switch ( ntmirroring )
{ {
default: default:
case NT_NONE: case NT_NONE:
txt = "None";
break; break;
case NT_HORIZONTAL: case NT_HORIZONTAL:
horzMirrorBtn->setChecked(true); txt = "Horizontal";
break; break;
case NT_VERTICAL: case NT_VERTICAL:
vertMirrorBtn->setChecked(true); txt = "Vertical";
break; break;
case NT_FOUR_SCREEN: case NT_FOUR_SCREEN:
fourScreenBtn->setChecked(true); txt = "Four Screen";
break; break;
case NT_SINGLE_SCREEN_TABLE_0: case NT_SINGLE_SCREEN_TABLE_0:
txt = "Single Screen 0";
break;
case NT_SINGLE_SCREEN_TABLE_1: case NT_SINGLE_SCREEN_TABLE_1:
txt = "Single Screen 1";
break;
case NT_SINGLE_SCREEN_TABLE_2: case NT_SINGLE_SCREEN_TABLE_2:
txt = "Single Screen 2";
break;
case NT_SINGLE_SCREEN_TABLE_3: case NT_SINGLE_SCREEN_TABLE_3:
{ txt = "Single Screen 3";
int i = ntmirroring - NT_SINGLE_SCREEN_TABLE_0;
singleScreenBtn[i]->setChecked(true);
}
break; break;
} }
}
//---------------------------------------------------- mirrorLbl->setText( tr(txt) );
void ppuNameTableViewerDialog_t::horzMirrorClicked(void)
{
ntmirroring = NT_HORIZONTAL;
ChangeMirroring();
}
//----------------------------------------------------
void ppuNameTableViewerDialog_t::vertMirrorClicked(void)
{
ntmirroring = NT_VERTICAL;
ChangeMirroring();
}
//----------------------------------------------------
void ppuNameTableViewerDialog_t::fourScreenClicked(void)
{
ntmirroring = NT_FOUR_SCREEN;
ChangeMirroring();
}
//----------------------------------------------------
void ppuNameTableViewerDialog_t::singleScreen0Clicked(void)
{
ntmirroring = NT_SINGLE_SCREEN_TABLE_0;
ChangeMirroring();
}
//----------------------------------------------------
void ppuNameTableViewerDialog_t::singleScreen1Clicked(void)
{
ntmirroring = NT_SINGLE_SCREEN_TABLE_1;
ChangeMirroring();
}
//----------------------------------------------------
void ppuNameTableViewerDialog_t::singleScreen2Clicked(void)
{
ntmirroring = NT_SINGLE_SCREEN_TABLE_2;
ChangeMirroring();
}
//----------------------------------------------------
void ppuNameTableViewerDialog_t::singleScreen3Clicked(void)
{
ntmirroring = NT_SINGLE_SCREEN_TABLE_3;
ChangeMirroring();
} }
//---------------------------------------------------- //----------------------------------------------------
void ppuNameTableViewerDialog_t::scanLineChanged( const QString &txt ) void ppuNameTableViewerDialog_t::scanLineChanged( const QString &txt )
@ -534,7 +550,11 @@ void ppuNameTableViewerDialog_t::scanLineChanged( const QString &txt )
{ {
NTViewScanline = strtoul( s.c_str(), NULL, 10 ); NTViewScanline = strtoul( s.c_str(), NULL, 10 );
} }
//printf("ScanLine: '%s' %i\n", s.c_str(), PPUViewScanline ); else
{
NTViewScanline = 0;
}
//printf("ScanLine: '%s' %i\n", s.c_str(), NTViewScanline );
} }
//---------------------------------------------------- //----------------------------------------------------
void ppuNameTableViewerDialog_t::menuScrollLinesChanged(bool checked) void ppuNameTableViewerDialog_t::menuScrollLinesChanged(bool checked)
@ -546,9 +566,9 @@ void ppuNameTableViewerDialog_t::menuScrollLinesChanged(bool checked)
//---------------------------------------------------- //----------------------------------------------------
void ppuNameTableViewerDialog_t::menuGridLinesChanged(bool checked) void ppuNameTableViewerDialog_t::menuGridLinesChanged(bool checked)
{ {
drawGridLines = checked; drawTileGridLines = checked;
showGridLineCbox->setChecked( checked ); showTileGridCbox->setChecked( checked );
} }
//---------------------------------------------------- //----------------------------------------------------
void ppuNameTableViewerDialog_t::menuAttributesChanged(bool checked) void ppuNameTableViewerDialog_t::menuAttributesChanged(bool checked)
@ -579,11 +599,20 @@ void ppuNameTableViewerDialog_t::showScrollLinesChanged(int state)
showScrollLineAct->setChecked( drawScrollLines ); showScrollLineAct->setChecked( drawScrollLines );
} }
//---------------------------------------------------- //----------------------------------------------------
void ppuNameTableViewerDialog_t::showGridLinesChanged(int state) void ppuNameTableViewerDialog_t::showTileGridChanged(int state)
{ {
drawGridLines = (state != Qt::Unchecked); drawTileGridLines = (state != Qt::Unchecked);
showGridLineAct->setChecked( drawGridLines ); showTileGridAct->setChecked( drawTileGridLines );
redrawtables = true;
}
//----------------------------------------------------
void ppuNameTableViewerDialog_t::showAttrGridChanged(int state)
{
drawAttrGridLines = (state != Qt::Unchecked);
//showAttrGridAct->setChecked( drawAttrGridLines );
redrawtables = true; redrawtables = true;
} }
@ -627,6 +656,9 @@ ppuNameTableView_t::ppuNameTableView_t(QWidget *parent)
selTable = 0; selTable = 0;
scrollArea = NULL; scrollArea = NULL;
tileGridColor.setRgb(255, 0, 0);
attrGridColor.setRgb( 0, 0,255);
} }
//---------------------------------------------------- //----------------------------------------------------
ppuNameTableView_t::~ppuNameTableView_t(void) ppuNameTableView_t::~ppuNameTableView_t(void)
@ -692,7 +724,7 @@ void ppuNameTableView_t::resizeEvent(QResizeEvent *event)
//viewWidth = event->size().width(); //viewWidth = event->size().width();
//viewHeight = event->size().height(); //viewHeight = event->size().height();
printf("%ix%i\n", event->size().width(), event->size().height() ); //printf("%ix%i\n", event->size().width(), event->size().height() );
redrawtables = 1; redrawtables = 1;
} }
@ -769,58 +801,14 @@ int ppuNameTableView_t::calcTableTileAddr( int NameTable, int TileX, int TileY
return PPUAddress; return PPUAddress;
} }
//---------------------------------------------------- //----------------------------------------------------
void ppuNameTableView_t::computeNameTableProperties( int x, int y ) void ppuNameTableView_t::computeNameTableProperties( int NameTable, int TileX, int TileY )
{ {
int i, xx, yy, w, h, TileID, TileX, TileY, NameTable, PPUAddress, AttAddress, Attrib; int TileID, PPUAddress, AttAddress, Attrib, palAddr;
ppuNameTable_t *tbl = NULL;
NameTable = 0;
if ( vnapage[0] == NULL ) if ( vnapage[0] == NULL )
{ {
return; return;
} }
for (i=0; i<4; i++)
{
xx = nameTable[i].x;
yy = nameTable[i].y;
w = (nameTable[i].w * 256);
h = (nameTable[i].h * 240);
if ( (x >= xx) && (x < (xx+w) ) &&
(y >= yy) && (y < (yy+h) ) )
{
tbl = &nameTable[i];
NameTable = i;
break;
}
}
if ( tbl == NULL )
{
//printf("Mouse not over a tile\n");
return;
}
xx = tbl->x; yy = tbl->y;
w = tbl->w; h = tbl->h;
if ( (NameTable%2) == 1 )
{
TileX = ((x - xx) / (w*8)) + 32;
}
else
{
TileX = (x - xx) / (w*8);
}
if ( (NameTable/2) == 1 )
{
TileY = ((y - yy) / (h*8)) + 30;
}
else
{
TileY = (y - yy) / (h*8);
}
PPUAddress = 0x2000+(NameTable*0x400)+((TileY%30)*32)+(TileX%32); PPUAddress = 0x2000+(NameTable*0x400)+((TileY%30)*32)+(TileX%32);
@ -828,13 +816,16 @@ void ppuNameTableView_t::computeNameTableProperties( int x, int y )
AttAddress = 0x23C0 | (PPUAddress & 0x0C00) | ((PPUAddress >> 4) & 0x38) | ((PPUAddress >> 2) & 0x07); AttAddress = 0x23C0 | (PPUAddress & 0x0C00) | ((PPUAddress >> 4) & 0x38) | ((PPUAddress >> 2) & 0x07);
Attrib = vnapage[(AttAddress>>10)&0x3][AttAddress&0x3FF]; Attrib = vnapage[(AttAddress>>10)&0x3][AttAddress&0x3FF];
Attrib = (Attrib >> ((PPUAddress&2) | ((PPUAddress&64)>>4))) & 0x3; //Attrib = (Attrib >> ((PPUAddress&2) | ((PPUAddress&64)>>4))) & 0x3;
//palAddr = 0x3F00 + ( FCEUPPU_GetAttr( NameTable, TileX, TileY ) * 4 );
palAddr = 0x3F00 + ( (Attrib >> ((PPUAddress&2) | ((PPUAddress&64)>>4))) & 0x3 ) * 4;
//printf("NT:%i Tile X/Y : %i/%i \n", NameTable, TileX, TileY ); //printf("NT:%i Tile X/Y : %i/%i \n", NameTable, TileX, TileY );
if ( parent ) if ( parent )
{ {
parent->setPropertyLabels( TileID, TileX, TileY, NameTable, PPUAddress, AttAddress, Attrib ); parent->setPropertyLabels( TileID, TileX, TileY, NameTable, PPUAddress, AttAddress, Attrib, palAddr );
} }
} }
//---------------------------------------------------- //----------------------------------------------------
@ -872,7 +863,11 @@ void ppuNameTableView_t::keyPressEvent(QKeyEvent *event)
} }
selTile.setY( y ); selTile.setY( y );
computeNameTableProperties( selTable, selTile.x(), selTile.y() );
ensureVis = true; ensureVis = true;
event->accept();
} }
else if ( event->key() == Qt::Key_Down ) else if ( event->key() == Qt::Key_Down )
{ {
@ -894,7 +889,11 @@ void ppuNameTableView_t::keyPressEvent(QKeyEvent *event)
} }
selTile.setY( y ); selTile.setY( y );
computeNameTableProperties( selTable, selTile.x(), selTile.y() );
ensureVis = true; ensureVis = true;
event->accept();
} }
else if ( event->key() == Qt::Key_Left ) else if ( event->key() == Qt::Key_Left )
{ {
@ -916,7 +915,11 @@ void ppuNameTableView_t::keyPressEvent(QKeyEvent *event)
} }
selTile.setX( x ); selTile.setX( x );
computeNameTableProperties( selTable, selTile.x(), selTile.y() );
ensureVis = true; ensureVis = true;
event->accept();
} }
else if ( event->key() == Qt::Key_Right ) else if ( event->key() == Qt::Key_Right )
{ {
@ -938,14 +941,17 @@ void ppuNameTableView_t::keyPressEvent(QKeyEvent *event)
} }
selTile.setX( x ); selTile.setX( x );
computeNameTableProperties( selTable, selTile.x(), selTile.y() );
ensureVis = true; ensureVis = true;
event->accept();
} }
} }
//---------------------------------------------------- //----------------------------------------------------
void ppuNameTableView_t::mouseMoveEvent(QMouseEvent *event) void ppuNameTableView_t::mouseMoveEvent(QMouseEvent *event)
{ {
//printf("MouseMove: (%i,%i) \n", event->pos().x(), event->pos().y() ); //printf("MouseMove: (%i,%i) \n", event->pos().x(), event->pos().y() );
//computeNameTableProperties( event->pos().x(), event->pos().y() );
} }
//---------------------------------------------------------------------------- //----------------------------------------------------------------------------
void ppuNameTableView_t::mousePressEvent(QMouseEvent * event) void ppuNameTableView_t::mousePressEvent(QMouseEvent * event)
@ -956,12 +962,12 @@ void ppuNameTableView_t::mousePressEvent(QMouseEvent * event)
if ( event->button() == Qt::LeftButton ) if ( event->button() == Qt::LeftButton )
{ {
printf(" %i %i %i \n", tIdx, tx, ty ); //printf(" %i %i %i \n", tIdx, tx, ty );
selTable = tIdx; selTable = tIdx;
selTile.setX( tx ); selTile.setX( tx );
selTile.setY( ty ); selTile.setY( ty );
computeNameTableProperties( event->pos().x(), event->pos().y() ); computeNameTableProperties( tIdx, tx, ty );
} }
else if ( event->button() == Qt::RightButton ) else if ( event->button() == Qt::RightButton )
{ {
@ -974,7 +980,6 @@ void ppuNameTableView_t::paintEvent(QPaintEvent *event)
int n,i,j,ii,jj,w,h,x,y,xx,yy,ww,hh; int n,i,j,ii,jj,w,h,x,y,xx,yy,ww,hh;
QPainter painter(this); QPainter painter(this);
QColor scanLineColor(255,255,255); QColor scanLineColor(255,255,255);
QColor gridLineColor(128,128,128);
QPen pen; QPen pen;
viewRect = event->rect(); viewRect = event->rect();
@ -1032,9 +1037,9 @@ void ppuNameTableView_t::paintEvent(QPaintEvent *event)
painter.drawLine( xx, ypos, xx + ww, ypos ); painter.drawLine( xx, ypos, xx + ww, ypos );
} }
} }
if ( drawGridLines ) if ( drawTileGridLines )
{ {
painter.setPen( gridLineColor ); painter.setPen( tileGridColor );
for (x=0; x<256; x+=8) for (x=0; x<256; x+=8)
{ {
@ -1045,6 +1050,19 @@ void ppuNameTableView_t::paintEvent(QPaintEvent *event)
painter.drawLine( xx, yy + y*h, xx + ww, yy + y*h ); painter.drawLine( xx, yy + y*h, xx + ww, yy + y*h );
} }
} }
if ( drawAttrGridLines )
{
painter.setPen( attrGridColor );
for (x=0; x<256; x+=16)
{
painter.drawLine( xx + x*w, yy, xx + x*w, yy + hh );
}
for (y=0; y<240; y+=16)
{
painter.drawLine( xx, yy + y*h, xx + ww, yy + y*h );
}
}
} }
xx = nameTable[ selTable ].tile[ selTile.y() ][ selTile.x() ].x; xx = nameTable[ selTable ].tile[ selTile.y() ][ selTile.x() ].x;
@ -1071,6 +1089,8 @@ void ppuNameTableView_t::paintEvent(QPaintEvent *event)
ensureVis = false; ensureVis = false;
} }
computeNameTableProperties( selTable, selTile.x(), selTile.y() );
} }
//---------------------------------------------------- //----------------------------------------------------
static void initNameTableViewer(void) static void initNameTableViewer(void)
@ -1086,47 +1106,47 @@ static void initNameTableViewer(void)
} }
//---------------------------------------------------- //----------------------------------------------------
static void ChangeMirroring(void) //static void ChangeMirroring(void)
{ //{
switch (ntmirroring) // switch (ntmirroring)
{ // {
case NT_HORIZONTAL: // case NT_HORIZONTAL:
vnapage[0] = vnapage[1] = &NTARAM[0x000]; // vnapage[0] = vnapage[1] = &NTARAM[0x000];
vnapage[2] = vnapage[3] = &NTARAM[0x400]; // vnapage[2] = vnapage[3] = &NTARAM[0x400];
break; // break;
case NT_VERTICAL: // case NT_VERTICAL:
vnapage[0] = vnapage[2] = &NTARAM[0x000]; // vnapage[0] = vnapage[2] = &NTARAM[0x000];
vnapage[1] = vnapage[3] = &NTARAM[0x400]; // vnapage[1] = vnapage[3] = &NTARAM[0x400];
break; // break;
case NT_FOUR_SCREEN: // case NT_FOUR_SCREEN:
vnapage[0] = &NTARAM[0x000]; // vnapage[0] = &NTARAM[0x000];
vnapage[1] = &NTARAM[0x400]; // vnapage[1] = &NTARAM[0x400];
if(ExtraNTARAM) // if(ExtraNTARAM)
{ // {
vnapage[2] = ExtraNTARAM; // vnapage[2] = ExtraNTARAM;
vnapage[3] = ExtraNTARAM + 0x400; // vnapage[3] = ExtraNTARAM + 0x400;
} // }
break; // break;
case NT_SINGLE_SCREEN_TABLE_0: // case NT_SINGLE_SCREEN_TABLE_0:
vnapage[0] = vnapage[1] = vnapage[2] = vnapage[3] = &NTARAM[0x000]; // vnapage[0] = vnapage[1] = vnapage[2] = vnapage[3] = &NTARAM[0x000];
break; // break;
case NT_SINGLE_SCREEN_TABLE_1: // case NT_SINGLE_SCREEN_TABLE_1:
vnapage[0] = vnapage[1] = vnapage[2] = vnapage[3] = &NTARAM[0x400]; // vnapage[0] = vnapage[1] = vnapage[2] = vnapage[3] = &NTARAM[0x400];
break; // break;
case NT_SINGLE_SCREEN_TABLE_2: // case NT_SINGLE_SCREEN_TABLE_2:
if(ExtraNTARAM) // if(ExtraNTARAM)
vnapage[0] = vnapage[1] = vnapage[2] = vnapage[3] = ExtraNTARAM; // vnapage[0] = vnapage[1] = vnapage[2] = vnapage[3] = ExtraNTARAM;
break; // break;
case NT_SINGLE_SCREEN_TABLE_3: // case NT_SINGLE_SCREEN_TABLE_3:
if(ExtraNTARAM) // if(ExtraNTARAM)
vnapage[0] = vnapage[1] = vnapage[2] = vnapage[3] = ExtraNTARAM + 0x400; // vnapage[0] = vnapage[1] = vnapage[2] = vnapage[3] = ExtraNTARAM + 0x400;
break; // break;
default: // default:
case NT_NONE: // case NT_NONE:
break; // break;
} // }
return; // return;
} //}
//---------------------------------------------------- //----------------------------------------------------
inline void DrawChr( ppuNameTableTile_t *tile, const uint8_t *chr, int pal) inline void DrawChr( ppuNameTableTile_t *tile, const uint8_t *chr, int pal)
{ {
@ -1208,8 +1228,6 @@ static void DrawNameTable(int scanline, int ntnum, bool invalidateCache)
int chr = table[ntaddr]*16; int chr = table[ntaddr]*16;
extern int FCEUPPU_GetAttr(int ntnum, int xt, int yt);
//test.. instead of pretending that the nametable is a screen at 0,0 we pretend that it is at the current xscroll and yscroll //test.. instead of pretending that the nametable is a screen at 0,0 we pretend that it is at the current xscroll and yscroll
//int xpos = ((RefreshAddr & 0x400) >> 2) | ((RefreshAddr & 0x1F) << 3) | XOffset; //int xpos = ((RefreshAddr & 0x400) >> 2) | ((RefreshAddr & 0x1F) << 3) | XOffset;
//int ypos = ((RefreshAddr & 0x3E0) >> 2) | ((RefreshAddr & 0x7000) >> 12); //int ypos = ((RefreshAddr & 0x3E0) >> 2) | ((RefreshAddr & 0x7000) >> 12);

View File

@ -62,7 +62,7 @@ class ppuNameTableView_t : public QWidget
void keyPressEvent(QKeyEvent *event); void keyPressEvent(QKeyEvent *event);
void mouseMoveEvent(QMouseEvent *event); void mouseMoveEvent(QMouseEvent *event);
void mousePressEvent(QMouseEvent * event); void mousePressEvent(QMouseEvent * event);
void computeNameTableProperties( int x, int y ); void computeNameTableProperties( int NameTable, int TileX, int TileY );
int convertXY2TableTile( int x, int y, int *tableIdxOut, int *tileXout, int *tileYout ); int convertXY2TableTile( int x, int y, int *tableIdxOut, int *tileXout, int *tileYout );
int calcTableTileAddr( int table, int tileX, int tileY ); int calcTableTileAddr( int table, int tileX, int tileY );
@ -73,6 +73,8 @@ class ppuNameTableView_t : public QWidget
int selTable; int selTable;
QPoint selTile; QPoint selTile;
QPoint selTileLoc; QPoint selTileLoc;
QColor tileGridColor;
QColor attrGridColor;
QRect viewRect; QRect viewRect;
QScrollArea *scrollArea; QScrollArea *scrollArea;
@ -87,53 +89,45 @@ class ppuNameTableViewerDialog_t : public QDialog
ppuNameTableViewerDialog_t(QWidget *parent = 0); ppuNameTableViewerDialog_t(QWidget *parent = 0);
~ppuNameTableViewerDialog_t(void); ~ppuNameTableViewerDialog_t(void);
void setPropertyLabels( int TileID, int TileX, int TileY, int NameTable, int PPUAddress, int AttAddress, int Attrib ); void setPropertyLabels( int TileID, int TileX, int TileY, int NameTable, int PPUAddress, int AttAddress, int Attrib, int palAddr );
protected: protected:
void closeEvent(QCloseEvent *bar); void closeEvent(QCloseEvent *bar);
ppuNameTableView_t *ntView; ppuNameTableView_t *ntView;
QScrollArea *scrollArea; QScrollArea *scrollArea;
QCheckBox *showScrollLineCbox; QCheckBox *showScrollLineCbox;
QCheckBox *showGridLineCbox; QCheckBox *showTileGridCbox;
QCheckBox *showAttrGridCbox;
QCheckBox *showAttrbCbox; QCheckBox *showAttrbCbox;
QCheckBox *ignorePaletteCbox; QCheckBox *ignorePaletteCbox;
QSlider *refreshSlider; QSlider *refreshSlider;
QLineEdit *scanLineEdit; QLineEdit *scanLineEdit;
QTimer *updateTimer; QTimer *updateTimer;
QRadioButton *horzMirrorBtn; QLineEdit *ppuAddrLbl;
QRadioButton *vertMirrorBtn; QLineEdit *nameTableLbl;
QRadioButton *fourScreenBtn; QLineEdit *tileLocLbl;
QRadioButton *singleScreenBtn[4]; QLineEdit *tileIdxLbl;
QFrame *nameTableFrame; QLineEdit *tileAddrLbl;
QFrame *ctlPanelFrame; QLineEdit *attrDataLbl;
QGroupBox *mirrorGroup; QLineEdit *attrAddrLbl;
QGroupBox *dataDisplayGroup; QLineEdit *palAddrLbl;
QLabel *tileID;
QLabel *tileXY;
QLabel *ppuAddrLbl;
QLabel *attrbLbl;
QAction *showScrollLineAct; QAction *showScrollLineAct;
QAction *showGridLineAct; QAction *showTileGridAct;
QAction *showAttributesAct; QAction *showAttributesAct;
QAction *ignPalAct; QAction *ignPalAct;
QLabel *mirrorLbl;
bool compactView; bool compactView;
public slots: public slots:
void closeWindow(void); void closeWindow(void);
private slots: private slots:
void periodicUpdate(void); void periodicUpdate(void);
void updateMirrorButtons(void); void updateMirrorText(void);
void updateVisibility(void); void updateVisibility(void);
void horzMirrorClicked(void);
void vertMirrorClicked(void);
void fourScreenClicked(void);
void singleScreen0Clicked(void);
void singleScreen1Clicked(void);
void singleScreen2Clicked(void);
void singleScreen3Clicked(void);
void showAttrbChanged(int state); void showAttrbChanged(int state);
void ignorePaletteChanged(int state); void ignorePaletteChanged(int state);
void showGridLinesChanged(int state); void showTileGridChanged(int state);
void showAttrGridChanged(int state);
void showScrollLinesChanged(int state); void showScrollLinesChanged(int state);
void refreshSliderChanged(int value); void refreshSliderChanged(int value);
void scanLineChanged( const QString &txt ); void scanLineChanged( const QString &txt );