Changed Qt name table viewer layout to more like mesen.
This commit is contained in:
parent
b5008d89bc
commit
aff634b0ed
|
@ -37,6 +37,7 @@
|
|||
#include "../../debug.h"
|
||||
#include "../../palette.h"
|
||||
|
||||
#include "Qt/ConsoleUtilities.h"
|
||||
#include "Qt/NameTableViewer.h"
|
||||
#include "Qt/main.h"
|
||||
#include "Qt/dface.h"
|
||||
|
@ -55,9 +56,12 @@ static int xpos = 0, ypos = 0;
|
|||
static int attview = 0;
|
||||
static int hidepal = 0;
|
||||
static bool drawScrollLines = true;
|
||||
static bool drawGridLines = true;
|
||||
static bool drawTileGridLines = true;
|
||||
static bool drawAttrGridLines = false;
|
||||
static bool redrawtables = true;
|
||||
|
||||
//extern int FCEUPPU_GetAttr(int ntnum, int xt, int yt);
|
||||
|
||||
// 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 };
|
||||
|
||||
|
@ -88,7 +92,7 @@ enum NT_MirrorType
|
|||
static NT_MirrorType ntmirroring = NT_NONE, oldntmirroring = NT_NONE;
|
||||
|
||||
static void initNameTableViewer(void);
|
||||
static void ChangeMirroring(void);
|
||||
//static void ChangeMirroring(void);
|
||||
//----------------------------------------------------
|
||||
int openNameTableViewWindow( QWidget *parent )
|
||||
{
|
||||
|
@ -108,16 +112,24 @@ int openNameTableViewWindow( QWidget *parent )
|
|||
ppuNameTableViewerDialog_t::ppuNameTableViewerDialog_t(QWidget *parent)
|
||||
: QDialog( parent, Qt::Window )
|
||||
{
|
||||
QVBoxLayout *mainLayout, *vbox;
|
||||
QHBoxLayout *hbox;
|
||||
QHBoxLayout *mainLayout;
|
||||
QVBoxLayout *vbox1, *vbox2;
|
||||
QHBoxLayout *hbox, *hbox1;
|
||||
QGridLayout *grid;
|
||||
QGroupBox *frame;
|
||||
QMenuBar *menuBar;
|
||||
QMenu *viewMenu, *subMenu;
|
||||
QAction *act, *zoomAct[4];
|
||||
QActionGroup *group;
|
||||
QLabel *lbl;
|
||||
QFont font;
|
||||
char stmp[64];
|
||||
int useNativeMenuBar;
|
||||
fceuDecIntValidtor *validator;
|
||||
|
||||
font.setFamily("Courier New");
|
||||
font.setStyle( QFont::StyleNormal );
|
||||
font.setStyleHint( QFont::Monospace );
|
||||
|
||||
nameTableViewWindow = this;
|
||||
|
||||
|
@ -148,13 +160,13 @@ ppuNameTableViewerDialog_t::ppuNameTableViewerDialog_t(QWidget *parent)
|
|||
viewMenu->addAction(act);
|
||||
|
||||
// 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->setCheckable(true);
|
||||
act->setChecked(drawGridLines);
|
||||
act->setStatusTip(tr("Show Grid Lines"));
|
||||
act->setChecked(drawTileGridLines);
|
||||
act->setStatusTip(tr("Show Tile Grid"));
|
||||
connect(act, SIGNAL(triggered(bool)), this, SLOT(menuGridLinesChanged(bool)) );
|
||||
showGridLineAct = act;
|
||||
showTileGridAct = act;
|
||||
|
||||
viewMenu->addAction(act);
|
||||
|
||||
|
@ -219,18 +231,17 @@ ppuNameTableViewerDialog_t::ppuNameTableViewerDialog_t(QWidget *parent)
|
|||
|
||||
setWindowTitle( tr("Name Table Viewer") );
|
||||
|
||||
mainLayout = new QVBoxLayout();
|
||||
mainLayout = new QHBoxLayout();
|
||||
|
||||
mainLayout->setMenuBar( menuBar );
|
||||
|
||||
setLayout( mainLayout );
|
||||
|
||||
//vbox = new QVBoxLayout();
|
||||
//frame = new QGroupBox( tr("Name Tables") );
|
||||
vbox1 = new QVBoxLayout();
|
||||
vbox2 = new QVBoxLayout();
|
||||
frame = new QGroupBox( tr("Tile Info") );
|
||||
ntView = new ppuNameTableView_t(this);
|
||||
grid = new QGridLayout();
|
||||
ctlPanelFrame = new QFrame();
|
||||
//nameTableFrame = new QFrame();
|
||||
|
||||
scrollArea = new QScrollArea();
|
||||
scrollArea->setWidgetResizable(false);
|
||||
|
@ -239,115 +250,146 @@ ppuNameTableViewerDialog_t::ppuNameTableViewerDialog_t(QWidget *parent)
|
|||
scrollArea->setVerticalScrollBarPolicy( Qt::ScrollBarAsNeeded );
|
||||
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 );
|
||||
|
||||
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") );
|
||||
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") );
|
||||
ignorePaletteCbox = new QCheckBox( tr("Ignore Palette") );
|
||||
|
||||
showScrollLineCbox->setChecked( drawScrollLines );
|
||||
showGridLineCbox->setChecked( drawGridLines );
|
||||
showTileGridCbox->setChecked( drawTileGridLines );
|
||||
showAttrGridCbox->setChecked( drawAttrGridLines );
|
||||
showAttrbCbox->setChecked( attview );
|
||||
ignorePaletteCbox->setChecked( hidepal );
|
||||
|
||||
grid->addWidget( showScrollLineCbox, 0, 0, Qt::AlignLeft );
|
||||
grid->addWidget( showGridLineCbox , 1, 0, Qt::AlignLeft );
|
||||
grid->addWidget( showAttrbCbox , 2, 0, Qt::AlignLeft );
|
||||
grid->addWidget( ignorePaletteCbox , 2, 1, Qt::AlignLeft );
|
||||
vbox2->addWidget( showScrollLineCbox );
|
||||
vbox2->addWidget( showTileGridCbox );
|
||||
vbox2->addWidget( showAttrGridCbox );
|
||||
vbox2->addWidget( showAttrbCbox );
|
||||
vbox2->addWidget( ignorePaletteCbox );
|
||||
|
||||
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( 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();
|
||||
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();
|
||||
hbox->addWidget( new QLabel( tr("Display on Scanline:") ) );
|
||||
hbox->addWidget( scanLineEdit );
|
||||
grid->addLayout( hbox, 1, 1, Qt::AlignRight );
|
||||
hbox->addWidget( new QLabel( tr("Display on Scanline:") ), 1, Qt::AlignRight );
|
||||
hbox->addWidget( scanLineEdit, 1, Qt::AlignLeft );
|
||||
|
||||
hbox1->addLayout( hbox, 1 );
|
||||
|
||||
validator = new fceuDecIntValidtor( 0, 255, this );
|
||||
scanLineEdit->setMaxLength( 3 );
|
||||
scanLineEdit->setInputMask( ">900;" );
|
||||
scanLineEdit->setValidator( validator );
|
||||
sprintf( stmp, "%i", NTViewScanline );
|
||||
scanLineEdit->setText( tr(stmp) );
|
||||
|
||||
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);
|
||||
|
||||
updateTimer = new QTimer( this );
|
||||
|
@ -356,6 +398,7 @@ ppuNameTableViewerDialog_t::ppuNameTableViewerDialog_t(QWidget *parent)
|
|||
|
||||
updateTimer->start( 33 ); // 30hz
|
||||
|
||||
updateMirrorText();
|
||||
updateVisibility();
|
||||
}
|
||||
//----------------------------------------------------
|
||||
|
@ -384,13 +427,12 @@ void ppuNameTableViewerDialog_t::closeWindow(void)
|
|||
//----------------------------------------------------
|
||||
void ppuNameTableViewerDialog_t::periodicUpdate(void)
|
||||
{
|
||||
updateMirrorButtons();
|
||||
updateMirrorText();
|
||||
|
||||
if ( redrawtables )
|
||||
{
|
||||
//this->update();
|
||||
//this->scrollArea->update();
|
||||
this->scrollArea->viewport()->update();
|
||||
|
||||
redrawtables = false;
|
||||
}
|
||||
}
|
||||
|
@ -418,110 +460,84 @@ void ppuNameTableViewerDialog_t::changeZoom4x(void)
|
|||
void ppuNameTableViewerDialog_t::updateVisibility(void)
|
||||
{
|
||||
|
||||
if ( compactView )
|
||||
{
|
||||
ctlPanelFrame->hide();
|
||||
mirrorGroup->hide();
|
||||
dataDisplayGroup->hide();
|
||||
}
|
||||
else
|
||||
{
|
||||
ctlPanelFrame->show();
|
||||
mirrorGroup->show();
|
||||
dataDisplayGroup->show();
|
||||
}
|
||||
//if ( compactView )
|
||||
//{
|
||||
// ctlPanelFrame->hide();
|
||||
// mirrorGroup->hide();
|
||||
// dataDisplayGroup->hide();
|
||||
//}
|
||||
//else
|
||||
//{
|
||||
// ctlPanelFrame->show();
|
||||
// mirrorGroup->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);
|
||||
|
||||
tileXY->setText( tr(stmp) );
|
||||
|
||||
sprintf(stmp,"PPU Address: %04X",PPUAddress);
|
||||
sprintf( stmp, "%0d, %0d", TileX, TileY);
|
||||
tileLocLbl->setText( tr(stmp) );
|
||||
|
||||
sprintf(stmp,"%04X",PPUAddress);
|
||||
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 )
|
||||
{
|
||||
default:
|
||||
case NT_NONE:
|
||||
txt = "None";
|
||||
break;
|
||||
case NT_HORIZONTAL:
|
||||
horzMirrorBtn->setChecked(true);
|
||||
txt = "Horizontal";
|
||||
break;
|
||||
case NT_VERTICAL:
|
||||
vertMirrorBtn->setChecked(true);
|
||||
txt = "Vertical";
|
||||
break;
|
||||
case NT_FOUR_SCREEN:
|
||||
fourScreenBtn->setChecked(true);
|
||||
txt = "Four Screen";
|
||||
break;
|
||||
case NT_SINGLE_SCREEN_TABLE_0:
|
||||
txt = "Single Screen 0";
|
||||
break;
|
||||
case NT_SINGLE_SCREEN_TABLE_1:
|
||||
txt = "Single Screen 1";
|
||||
break;
|
||||
case NT_SINGLE_SCREEN_TABLE_2:
|
||||
txt = "Single Screen 2";
|
||||
break;
|
||||
case NT_SINGLE_SCREEN_TABLE_3:
|
||||
{
|
||||
int i = ntmirroring - NT_SINGLE_SCREEN_TABLE_0;
|
||||
|
||||
singleScreenBtn[i]->setChecked(true);
|
||||
}
|
||||
txt = "Single Screen 3";
|
||||
break;
|
||||
}
|
||||
}
|
||||
//----------------------------------------------------
|
||||
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();
|
||||
|
||||
mirrorLbl->setText( tr(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 );
|
||||
}
|
||||
//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)
|
||||
|
@ -546,9 +566,9 @@ void ppuNameTableViewerDialog_t::menuScrollLinesChanged(bool checked)
|
|||
//----------------------------------------------------
|
||||
void ppuNameTableViewerDialog_t::menuGridLinesChanged(bool checked)
|
||||
{
|
||||
drawGridLines = checked;
|
||||
drawTileGridLines = checked;
|
||||
|
||||
showGridLineCbox->setChecked( checked );
|
||||
showTileGridCbox->setChecked( checked );
|
||||
}
|
||||
//----------------------------------------------------
|
||||
void ppuNameTableViewerDialog_t::menuAttributesChanged(bool checked)
|
||||
|
@ -579,11 +599,20 @@ void ppuNameTableViewerDialog_t::showScrollLinesChanged(int state)
|
|||
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;
|
||||
}
|
||||
|
@ -627,6 +656,9 @@ ppuNameTableView_t::ppuNameTableView_t(QWidget *parent)
|
|||
|
||||
selTable = 0;
|
||||
scrollArea = NULL;
|
||||
|
||||
tileGridColor.setRgb(255, 0, 0);
|
||||
attrGridColor.setRgb( 0, 0,255);
|
||||
}
|
||||
//----------------------------------------------------
|
||||
ppuNameTableView_t::~ppuNameTableView_t(void)
|
||||
|
@ -692,7 +724,7 @@ void ppuNameTableView_t::resizeEvent(QResizeEvent *event)
|
|||
//viewWidth = event->size().width();
|
||||
//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;
|
||||
}
|
||||
|
@ -769,58 +801,14 @@ int ppuNameTableView_t::calcTableTileAddr( int NameTable, int TileX, int TileY
|
|||
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;
|
||||
ppuNameTable_t *tbl = NULL;
|
||||
|
||||
NameTable = 0;
|
||||
int TileID, PPUAddress, AttAddress, Attrib, palAddr;
|
||||
|
||||
if ( vnapage[0] == NULL )
|
||||
{
|
||||
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);
|
||||
|
||||
|
@ -828,13 +816,16 @@ void ppuNameTableView_t::computeNameTableProperties( int x, int y )
|
|||
|
||||
AttAddress = 0x23C0 | (PPUAddress & 0x0C00) | ((PPUAddress >> 4) & 0x38) | ((PPUAddress >> 2) & 0x07);
|
||||
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 );
|
||||
|
||||
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 );
|
||||
|
||||
computeNameTableProperties( selTable, selTile.x(), selTile.y() );
|
||||
|
||||
ensureVis = true;
|
||||
|
||||
event->accept();
|
||||
}
|
||||
else if ( event->key() == Qt::Key_Down )
|
||||
{
|
||||
|
@ -894,7 +889,11 @@ void ppuNameTableView_t::keyPressEvent(QKeyEvent *event)
|
|||
}
|
||||
selTile.setY( y );
|
||||
|
||||
computeNameTableProperties( selTable, selTile.x(), selTile.y() );
|
||||
|
||||
ensureVis = true;
|
||||
|
||||
event->accept();
|
||||
}
|
||||
else if ( event->key() == Qt::Key_Left )
|
||||
{
|
||||
|
@ -916,7 +915,11 @@ void ppuNameTableView_t::keyPressEvent(QKeyEvent *event)
|
|||
}
|
||||
selTile.setX( x );
|
||||
|
||||
computeNameTableProperties( selTable, selTile.x(), selTile.y() );
|
||||
|
||||
ensureVis = true;
|
||||
|
||||
event->accept();
|
||||
}
|
||||
else if ( event->key() == Qt::Key_Right )
|
||||
{
|
||||
|
@ -938,14 +941,17 @@ void ppuNameTableView_t::keyPressEvent(QKeyEvent *event)
|
|||
}
|
||||
selTile.setX( x );
|
||||
|
||||
computeNameTableProperties( selTable, selTile.x(), selTile.y() );
|
||||
|
||||
ensureVis = true;
|
||||
|
||||
event->accept();
|
||||
}
|
||||
}
|
||||
//----------------------------------------------------
|
||||
void ppuNameTableView_t::mouseMoveEvent(QMouseEvent *event)
|
||||
{
|
||||
//printf("MouseMove: (%i,%i) \n", event->pos().x(), event->pos().y() );
|
||||
//computeNameTableProperties( event->pos().x(), event->pos().y() );
|
||||
}
|
||||
//----------------------------------------------------------------------------
|
||||
void ppuNameTableView_t::mousePressEvent(QMouseEvent * event)
|
||||
|
@ -956,12 +962,12 @@ void ppuNameTableView_t::mousePressEvent(QMouseEvent * event)
|
|||
|
||||
if ( event->button() == Qt::LeftButton )
|
||||
{
|
||||
printf(" %i %i %i \n", tIdx, tx, ty );
|
||||
//printf(" %i %i %i \n", tIdx, tx, ty );
|
||||
selTable = tIdx;
|
||||
selTile.setX( tx );
|
||||
selTile.setY( ty );
|
||||
|
||||
computeNameTableProperties( event->pos().x(), event->pos().y() );
|
||||
computeNameTableProperties( tIdx, tx, ty );
|
||||
}
|
||||
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;
|
||||
QPainter painter(this);
|
||||
QColor scanLineColor(255,255,255);
|
||||
QColor gridLineColor(128,128,128);
|
||||
QPen pen;
|
||||
|
||||
viewRect = event->rect();
|
||||
|
@ -1032,9 +1037,9 @@ void ppuNameTableView_t::paintEvent(QPaintEvent *event)
|
|||
painter.drawLine( xx, ypos, xx + ww, ypos );
|
||||
}
|
||||
}
|
||||
if ( drawGridLines )
|
||||
if ( drawTileGridLines )
|
||||
{
|
||||
painter.setPen( gridLineColor );
|
||||
painter.setPen( tileGridColor );
|
||||
|
||||
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 );
|
||||
}
|
||||
}
|
||||
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;
|
||||
|
@ -1071,6 +1089,8 @@ void ppuNameTableView_t::paintEvent(QPaintEvent *event)
|
|||
|
||||
ensureVis = false;
|
||||
}
|
||||
computeNameTableProperties( selTable, selTile.x(), selTile.y() );
|
||||
|
||||
}
|
||||
//----------------------------------------------------
|
||||
static void initNameTableViewer(void)
|
||||
|
@ -1086,47 +1106,47 @@ static void initNameTableViewer(void)
|
|||
|
||||
}
|
||||
//----------------------------------------------------
|
||||
static void ChangeMirroring(void)
|
||||
{
|
||||
switch (ntmirroring)
|
||||
{
|
||||
case NT_HORIZONTAL:
|
||||
vnapage[0] = vnapage[1] = &NTARAM[0x000];
|
||||
vnapage[2] = vnapage[3] = &NTARAM[0x400];
|
||||
break;
|
||||
case NT_VERTICAL:
|
||||
vnapage[0] = vnapage[2] = &NTARAM[0x000];
|
||||
vnapage[1] = vnapage[3] = &NTARAM[0x400];
|
||||
break;
|
||||
case NT_FOUR_SCREEN:
|
||||
vnapage[0] = &NTARAM[0x000];
|
||||
vnapage[1] = &NTARAM[0x400];
|
||||
if(ExtraNTARAM)
|
||||
{
|
||||
vnapage[2] = ExtraNTARAM;
|
||||
vnapage[3] = ExtraNTARAM + 0x400;
|
||||
}
|
||||
break;
|
||||
case NT_SINGLE_SCREEN_TABLE_0:
|
||||
vnapage[0] = vnapage[1] = vnapage[2] = vnapage[3] = &NTARAM[0x000];
|
||||
break;
|
||||
case NT_SINGLE_SCREEN_TABLE_1:
|
||||
vnapage[0] = vnapage[1] = vnapage[2] = vnapage[3] = &NTARAM[0x400];
|
||||
break;
|
||||
case NT_SINGLE_SCREEN_TABLE_2:
|
||||
if(ExtraNTARAM)
|
||||
vnapage[0] = vnapage[1] = vnapage[2] = vnapage[3] = ExtraNTARAM;
|
||||
break;
|
||||
case NT_SINGLE_SCREEN_TABLE_3:
|
||||
if(ExtraNTARAM)
|
||||
vnapage[0] = vnapage[1] = vnapage[2] = vnapage[3] = ExtraNTARAM + 0x400;
|
||||
break;
|
||||
default:
|
||||
case NT_NONE:
|
||||
break;
|
||||
}
|
||||
return;
|
||||
}
|
||||
//static void ChangeMirroring(void)
|
||||
//{
|
||||
// switch (ntmirroring)
|
||||
// {
|
||||
// case NT_HORIZONTAL:
|
||||
// vnapage[0] = vnapage[1] = &NTARAM[0x000];
|
||||
// vnapage[2] = vnapage[3] = &NTARAM[0x400];
|
||||
// break;
|
||||
// case NT_VERTICAL:
|
||||
// vnapage[0] = vnapage[2] = &NTARAM[0x000];
|
||||
// vnapage[1] = vnapage[3] = &NTARAM[0x400];
|
||||
// break;
|
||||
// case NT_FOUR_SCREEN:
|
||||
// vnapage[0] = &NTARAM[0x000];
|
||||
// vnapage[1] = &NTARAM[0x400];
|
||||
// if(ExtraNTARAM)
|
||||
// {
|
||||
// vnapage[2] = ExtraNTARAM;
|
||||
// vnapage[3] = ExtraNTARAM + 0x400;
|
||||
// }
|
||||
// break;
|
||||
// case NT_SINGLE_SCREEN_TABLE_0:
|
||||
// vnapage[0] = vnapage[1] = vnapage[2] = vnapage[3] = &NTARAM[0x000];
|
||||
// break;
|
||||
// case NT_SINGLE_SCREEN_TABLE_1:
|
||||
// vnapage[0] = vnapage[1] = vnapage[2] = vnapage[3] = &NTARAM[0x400];
|
||||
// break;
|
||||
// case NT_SINGLE_SCREEN_TABLE_2:
|
||||
// if(ExtraNTARAM)
|
||||
// vnapage[0] = vnapage[1] = vnapage[2] = vnapage[3] = ExtraNTARAM;
|
||||
// break;
|
||||
// case NT_SINGLE_SCREEN_TABLE_3:
|
||||
// if(ExtraNTARAM)
|
||||
// vnapage[0] = vnapage[1] = vnapage[2] = vnapage[3] = ExtraNTARAM + 0x400;
|
||||
// break;
|
||||
// default:
|
||||
// case NT_NONE:
|
||||
// break;
|
||||
// }
|
||||
// return;
|
||||
//}
|
||||
//----------------------------------------------------
|
||||
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;
|
||||
|
||||
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
|
||||
//int xpos = ((RefreshAddr & 0x400) >> 2) | ((RefreshAddr & 0x1F) << 3) | XOffset;
|
||||
//int ypos = ((RefreshAddr & 0x3E0) >> 2) | ((RefreshAddr & 0x7000) >> 12);
|
||||
|
|
|
@ -62,7 +62,7 @@ class ppuNameTableView_t : public QWidget
|
|||
void keyPressEvent(QKeyEvent *event);
|
||||
void mouseMoveEvent(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 calcTableTileAddr( int table, int tileX, int tileY );
|
||||
|
||||
|
@ -73,6 +73,8 @@ class ppuNameTableView_t : public QWidget
|
|||
int selTable;
|
||||
QPoint selTile;
|
||||
QPoint selTileLoc;
|
||||
QColor tileGridColor;
|
||||
QColor attrGridColor;
|
||||
QRect viewRect;
|
||||
QScrollArea *scrollArea;
|
||||
|
||||
|
@ -87,53 +89,45 @@ class ppuNameTableViewerDialog_t : public QDialog
|
|||
ppuNameTableViewerDialog_t(QWidget *parent = 0);
|
||||
~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:
|
||||
void closeEvent(QCloseEvent *bar);
|
||||
|
||||
ppuNameTableView_t *ntView;
|
||||
QScrollArea *scrollArea;
|
||||
QCheckBox *showScrollLineCbox;
|
||||
QCheckBox *showGridLineCbox;
|
||||
QCheckBox *showTileGridCbox;
|
||||
QCheckBox *showAttrGridCbox;
|
||||
QCheckBox *showAttrbCbox;
|
||||
QCheckBox *ignorePaletteCbox;
|
||||
QSlider *refreshSlider;
|
||||
QLineEdit *scanLineEdit;
|
||||
QTimer *updateTimer;
|
||||
QRadioButton *horzMirrorBtn;
|
||||
QRadioButton *vertMirrorBtn;
|
||||
QRadioButton *fourScreenBtn;
|
||||
QRadioButton *singleScreenBtn[4];
|
||||
QFrame *nameTableFrame;
|
||||
QFrame *ctlPanelFrame;
|
||||
QGroupBox *mirrorGroup;
|
||||
QGroupBox *dataDisplayGroup;
|
||||
QLabel *tileID;
|
||||
QLabel *tileXY;
|
||||
QLabel *ppuAddrLbl;
|
||||
QLabel *attrbLbl;
|
||||
QLineEdit *ppuAddrLbl;
|
||||
QLineEdit *nameTableLbl;
|
||||
QLineEdit *tileLocLbl;
|
||||
QLineEdit *tileIdxLbl;
|
||||
QLineEdit *tileAddrLbl;
|
||||
QLineEdit *attrDataLbl;
|
||||
QLineEdit *attrAddrLbl;
|
||||
QLineEdit *palAddrLbl;
|
||||
QAction *showScrollLineAct;
|
||||
QAction *showGridLineAct;
|
||||
QAction *showTileGridAct;
|
||||
QAction *showAttributesAct;
|
||||
QAction *ignPalAct;
|
||||
QLabel *mirrorLbl;
|
||||
bool compactView;
|
||||
|
||||
public slots:
|
||||
void closeWindow(void);
|
||||
private slots:
|
||||
void periodicUpdate(void);
|
||||
void updateMirrorButtons(void);
|
||||
void updateMirrorText(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 ignorePaletteChanged(int state);
|
||||
void showGridLinesChanged(int state);
|
||||
void showTileGridChanged(int state);
|
||||
void showAttrGridChanged(int state);
|
||||
void showScrollLinesChanged(int state);
|
||||
void refreshSliderChanged(int value);
|
||||
void scanLineChanged( const QString &txt );
|
||||
|
|
Loading…
Reference in New Issue