mirror of https://github.com/stella-emu/stella.git
fixed #1057
This commit is contained in:
parent
4bb07a90a3
commit
91417312f1
|
@ -141,44 +141,48 @@ RiotWidget::RiotWidget(GuiObject* boss, const GUI::Font& lfont,
|
||||||
addFocusWidget(myTimWrite);
|
addFocusWidget(myTimWrite);
|
||||||
|
|
||||||
t = new StaticTextWidget(boss, lfont,
|
t = new StaticTextWidget(boss, lfont,
|
||||||
myTimWrite->getRight() + hGap * 2,
|
myTimWrite->getRight() + hGap * 3,
|
||||||
ypos + _lineHeight * 1.5 + 2 , "#");
|
ypos + _lineHeight * 1.5 + 2 , "#");
|
||||||
myTimAvail = new DataGridWidget(boss, nfont, t->getRight() + hGap / 2, t->getTop() - 2,
|
myTimAvail = new DataGridWidget(boss, nfont, t->getRight(), t->getTop() - 2,
|
||||||
1, 1, 6, 30, Common::Base::Fmt::_10_6);
|
1, 1, 6, 30, Common::Base::Fmt::_10_6);
|
||||||
myTimAvail->setToolTip("Number of CPU cycles available for current timer interval.\n");
|
myTimAvail->setToolTip("Number of CPU cycles available for current timer interval.\n");
|
||||||
myTimAvail->setTarget(this);
|
myTimAvail->setTarget(this);
|
||||||
myTimAvail->setEditable(false);
|
myTimAvail->setEditable(false);
|
||||||
|
|
||||||
// Timer registers (RO)
|
// Timer registers (RO)
|
||||||
static constexpr std::array<string_view, 3> readNames = {
|
static constexpr std::array<string_view, 4> readNames = {
|
||||||
"INTIM", " Clocks", "TIMINT"
|
"INTIM", " Clocks", "TIMINT", "Divider #"
|
||||||
};
|
};
|
||||||
ypos = myTimWrite->getBottom() + _lineHeight / 2;
|
ypos = myTimWrite->getBottom() + _lineHeight / 2;
|
||||||
for(int row = 0; row < 3; ++row)
|
for(int row = 0; row < 4; ++row)
|
||||||
{
|
{
|
||||||
new StaticTextWidget(boss, lfont, hBorder, ypos + row * _lineHeight + 2,
|
new StaticTextWidget(boss, lfont, hBorder, ypos + row * _lineHeight + 2,
|
||||||
readNames[row]);
|
readNames[row]);
|
||||||
}
|
}
|
||||||
xpos = hBorder + lwidth;
|
xpos = hBorder + lwidth;
|
||||||
myTimRead = new DataGridWidget(boss, nfont, xpos, ypos, 1, 3, 2, 30, Common::Base::Fmt::_16);
|
myTimRead = new DataGridWidget(boss, nfont, xpos, ypos, 1, 3, 4, 30, Common::Base::Fmt::_16_2);
|
||||||
myTimRead->setToolTip(0, 1, "Remaining timer interval clocks.\n");
|
myTimRead->setToolTip(0, 1, "Remaining timer interval clocks.\n");
|
||||||
myTimRead->setToolTip(0, 2, "Timer interrupt flag in bit 7.\n");
|
myTimRead->setToolTip(0, 2, "Timer interrupt flag in bit 7.\n");
|
||||||
myTimRead->setTarget(this);
|
myTimRead->setTarget(this);
|
||||||
myTimRead->setEditable(false);
|
myTimRead->setEditable(false);
|
||||||
|
|
||||||
t = new StaticTextWidget(boss, lfont,
|
t = new StaticTextWidget(boss, lfont,
|
||||||
myTimWrite->getRight() + hGap * 2,
|
myTimWrite->getRight() + hGap * 3,
|
||||||
ypos + _lineHeight * 0.5 + 2 , "#");
|
ypos + _lineHeight * 0.5 + 2 , "#");
|
||||||
new StaticTextWidget(boss, lfont,
|
new StaticTextWidget(boss, lfont,
|
||||||
myTimWrite->getRight() + hGap * 2,
|
myTimWrite->getRight() + hGap * 3,
|
||||||
ypos + _lineHeight * 1.5 + 2 , "#");
|
ypos + _lineHeight * 1.5 + 2 , "#");
|
||||||
myTimTotal = new DataGridWidget(boss, nfont, t->getRight() + hGap / 2, t->getTop() - 2,
|
myTimTotal = new DataGridWidget(boss, nfont, t->getRight(), t->getTop() - 2,
|
||||||
1, 2, 6, 30, Common::Base::Fmt::_10_6);
|
1, 2, 6, 30, Common::Base::Fmt::_10_6);
|
||||||
myTimTotal->setToolTip(0, 0, "Number of CPU cycles since last TIMxxT write.\n");
|
myTimTotal->setToolTip(0, 0, "Number of CPU cycles since last TIMxxT write.\n");
|
||||||
myTimTotal->setToolTip(0, 1, "Number of CPU cycles remaining.\n");
|
myTimTotal->setToolTip(0, 1, "Number of CPU cycles remaining.\n");
|
||||||
myTimTotal->setTarget(this);
|
myTimTotal->setTarget(this);
|
||||||
myTimTotal->setEditable(false);
|
myTimTotal->setEditable(false);
|
||||||
|
|
||||||
|
ypos = myTimTotal->getBottom() + _lineHeight / 2;
|
||||||
|
myTimDivider = new DataGridWidget(boss, nfont, xpos, ypos, 1, 1, 4, 12, Common::Base::Fmt::_10_4);
|
||||||
|
myTimDivider->setTarget(this);
|
||||||
|
myTimDivider->setEditable(false);
|
||||||
|
|
||||||
// Controller ports
|
// Controller ports
|
||||||
const int col = mySWCHAWriteBits->getRight() + hGap * 2.5;
|
const int col = mySWCHAWriteBits->getRight() + hGap * 2.5;
|
||||||
|
@ -376,13 +380,13 @@ void RiotWidget::loadConfig()
|
||||||
alist.clear(); vlist.clear(); changed.clear();
|
alist.clear(); vlist.clear(); changed.clear();
|
||||||
alist.push_back(0);
|
alist.push_back(0);
|
||||||
Int32 avail = 0;
|
Int32 avail = 0;
|
||||||
if(state.TIM1T)
|
if(state.TIMDIV == 1)
|
||||||
avail = (state.TIM1T - 1) * 1;
|
avail = (state.TIM1T - 1) * 1;
|
||||||
else if(state.TIM8T)
|
else if(state.TIMDIV == 8)
|
||||||
avail = (state.TIM8T - 1) * 8;
|
avail = (state.TIM8T - 1) * 8;
|
||||||
else if(state.TIM64T)
|
else if(state.TIMDIV == 64)
|
||||||
avail = (state.TIM64T - 1) * 64;
|
avail = (state.TIM64T - 1) * 64;
|
||||||
else if(state.T1024T)
|
else if(state.TIMDIV == 1024)
|
||||||
avail = (state.T1024T - 1) * 1024;
|
avail = (state.T1024T - 1) * 1024;
|
||||||
vlist.push_back(avail);
|
vlist.push_back(avail);
|
||||||
changed.push_back(state.TIM1T != oldstate.TIM1T ||
|
changed.push_back(state.TIM1T != oldstate.TIM1T ||
|
||||||
|
@ -408,6 +412,11 @@ void RiotWidget::loadConfig()
|
||||||
changed.push_back(state.TIMCLKS != oldstate.TIMCLKS);
|
changed.push_back(state.TIMCLKS != oldstate.TIMCLKS);
|
||||||
myTimTotal->setList(alist, vlist, changed);
|
myTimTotal->setList(alist, vlist, changed);
|
||||||
|
|
||||||
|
alist.clear(); vlist.clear(); changed.clear();
|
||||||
|
alist.push_back(0); vlist.push_back(state.TIMDIV);
|
||||||
|
changed.push_back(state.TIMDIV != oldstate.TIMDIV);
|
||||||
|
myTimDivider->setList(alist, vlist, changed);
|
||||||
|
|
||||||
// Console switches (inverted, since 'selected' in the UI
|
// Console switches (inverted, since 'selected' in the UI
|
||||||
// means 'grounded' in the system)
|
// means 'grounded' in the system)
|
||||||
myP0Diff->setSelectedIndex(riot.diffP0(), state.swchbReadBits[1] != oldstate.swchbReadBits[1]);
|
myP0Diff->setSelectedIndex(riot.diffP0(), state.swchbReadBits[1] != oldstate.swchbReadBits[1]);
|
||||||
|
|
|
@ -63,6 +63,7 @@ class RiotWidget : public Widget, public CommandSender
|
||||||
DataGridWidget* myTimAvail{nullptr};
|
DataGridWidget* myTimAvail{nullptr};
|
||||||
DataGridWidget* myTimRead{nullptr};
|
DataGridWidget* myTimRead{nullptr};
|
||||||
DataGridWidget* myTimTotal{nullptr};
|
DataGridWidget* myTimTotal{nullptr};
|
||||||
|
DataGridWidget* myTimDivider{nullptr};
|
||||||
|
|
||||||
ControllerWidget *myLeftControl{nullptr}, *myRightControl{nullptr};
|
ControllerWidget *myLeftControl{nullptr}, *myRightControl{nullptr};
|
||||||
PopUpWidget *myP0Diff{nullptr}, *myP1Diff{nullptr};
|
PopUpWidget *myP0Diff{nullptr}, *myP1Diff{nullptr};
|
||||||
|
|
Loading…
Reference in New Issue