mirror of https://github.com/stella-emu/stella.git
First pass at converting part of 'ystart' to 'vcenter'.
The logic here is somewhat convoluted. I suggest renaming 'ystart' to 'startline', and having it internal to TIA only. The 'vcenter' option will then modify that value from certain default constants (for NTSC and PAL).
This commit is contained in:
parent
c2fc39f44d
commit
fd136e0d49
|
@ -431,8 +431,8 @@ PhysicalKeyboardHandler::EventMappingArray PhysicalKeyboardHandler::DefaultCommo
|
||||||
|
|
||||||
{Event::VidmodeDecrease, KBDK_MINUS, MOD3},
|
{Event::VidmodeDecrease, KBDK_MINUS, MOD3},
|
||||||
{Event::VidmodeIncrease, KBDK_EQUALS, MOD3},
|
{Event::VidmodeIncrease, KBDK_EQUALS, MOD3},
|
||||||
{Event::YStartDecrease, KBDK_PAGEDOWN, MOD3},
|
{Event::VCenterDecrease, KBDK_PAGEDOWN, MOD3},
|
||||||
{Event::YStartIncrease, KBDK_PAGEUP, MOD3},
|
{Event::VCenterIncrease, KBDK_PAGEUP, MOD3},
|
||||||
{Event::VolumeDecrease, KBDK_LEFTBRACKET, MOD3},
|
{Event::VolumeDecrease, KBDK_LEFTBRACKET, MOD3},
|
||||||
{Event::VolumeIncrease, KBDK_RIGHTBRACKET, MOD3},
|
{Event::VolumeIncrease, KBDK_RIGHTBRACKET, MOD3},
|
||||||
{Event::SoundToggle, KBDK_RIGHTBRACKET, KBDM_CTRL},
|
{Event::SoundToggle, KBDK_RIGHTBRACKET, KBDM_CTRL},
|
||||||
|
|
|
@ -151,7 +151,7 @@ Console::Console(OSystem& osystem, unique_ptr<Cartridge>& cart,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (atoi(myProperties.get(PropType::Display_YStart).c_str()) == 0) {
|
if (atoi(myProperties.get(PropType::Display_VCenter).c_str()) == 0) {
|
||||||
autodetectYStart();
|
autodetectYStart();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -679,7 +679,7 @@ void Console::fry() const
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void Console::changeYStart(int direction)
|
void Console::changeVerticalCenter(int direction)
|
||||||
{
|
{
|
||||||
uInt32 ystart = myTIA->ystart();
|
uInt32 ystart = myTIA->ystart();
|
||||||
|
|
||||||
|
@ -711,7 +711,7 @@ void Console::changeYStart(int direction)
|
||||||
ostringstream ss;
|
ostringstream ss;
|
||||||
ss << ystart;
|
ss << ystart;
|
||||||
|
|
||||||
myProperties.set(PropType::Display_YStart, ss.str());
|
myProperties.set(PropType::Display_VCenter, ss.str());
|
||||||
if (ystart != myTIA->ystart()) myTIA->setYStart(ystart);
|
if (ystart != myTIA->ystart()) myTIA->setYStart(ystart);
|
||||||
|
|
||||||
// use vertical center instead of y-start for display
|
// use vertical center instead of y-start for display
|
||||||
|
@ -743,7 +743,7 @@ void Console::updateYStart(uInt32 ystart)
|
||||||
void Console::setTIAProperties()
|
void Console::setTIAProperties()
|
||||||
{
|
{
|
||||||
// FIXME - ystart is probably disappearing soon, or at least autodetection is
|
// FIXME - ystart is probably disappearing soon, or at least autodetection is
|
||||||
uInt32 ystart = atoi(myProperties.get(PropType::Display_YStart).c_str());
|
uInt32 ystart = atoi(myProperties.get(PropType::Display_VCenter).c_str());
|
||||||
if(ystart != 0)
|
if(ystart != 0)
|
||||||
ystart = BSPF::clamp(ystart, 0u, TIAConstants::maxYStart);
|
ystart = BSPF::clamp(ystart, 0u, TIAConstants::maxYStart);
|
||||||
else {
|
else {
|
||||||
|
|
|
@ -256,11 +256,11 @@ class Console : public Serializable, public ConsoleIO
|
||||||
void fry() const;
|
void fry() const;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Change the "Display.YStart" variable.
|
Change the "Display.VCenter" variable.
|
||||||
|
|
||||||
@param direction +1 indicates increase, -1 indicates decrease.
|
@param direction +1 indicates increase, -1 indicates decrease.
|
||||||
*/
|
*/
|
||||||
void changeYStart(int direction);
|
void changeVerticalCenter(int direction);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Returns the current framerate.
|
Returns the current framerate.
|
||||||
|
|
|
@ -83,7 +83,7 @@ class Event
|
||||||
ToggleFullScreen,
|
ToggleFullScreen,
|
||||||
VidmodeStd, VidmodeRGB, VidmodeSVideo, VidModeComposite, VidModeBad, VidModeCustom,
|
VidmodeStd, VidmodeRGB, VidmodeSVideo, VidModeComposite, VidModeBad, VidModeCustom,
|
||||||
PreviousAttribute, NextAttribute, DecreaseAttribute, IncreaseAttribute,
|
PreviousAttribute, NextAttribute, DecreaseAttribute, IncreaseAttribute,
|
||||||
ScanlinesDecrease, ScanlinesIncrease,
|
ScanlinesDecrease, ScanlinesIncrease, VCenterDecrease, VCenterIncrease,
|
||||||
|
|
||||||
ToggleP0Collision, ToggleP0Bit, ToggleP1Collision, ToggleP1Bit,
|
ToggleP0Collision, ToggleP0Bit, ToggleP1Collision, ToggleP1Bit,
|
||||||
ToggleM0Collision, ToggleM0Bit, ToggleM1Collision, ToggleM1Bit,
|
ToggleM0Collision, ToggleM0Bit, ToggleM1Collision, ToggleM1Bit,
|
||||||
|
@ -120,8 +120,6 @@ class Event
|
||||||
CompuMateQuote, CompuMateBackspace, CompuMateEquals, CompuMatePlus,
|
CompuMateQuote, CompuMateBackspace, CompuMateEquals, CompuMatePlus,
|
||||||
CompuMateSlash,
|
CompuMateSlash,
|
||||||
|
|
||||||
YStartDecrease, YStartIncrease,
|
|
||||||
|
|
||||||
LastType
|
LastType
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -419,12 +419,12 @@ void EventHandler::handleEvent(Event::Type event, Int32 value, bool repeated)
|
||||||
if(pressed) myOSystem.frameBuffer().changeVidMode(+1);
|
if(pressed) myOSystem.frameBuffer().changeVidMode(+1);
|
||||||
return;
|
return;
|
||||||
|
|
||||||
case Event::YStartDecrease:
|
case Event::VCenterDecrease:
|
||||||
if (pressed) myOSystem.console().changeYStart(-1);
|
if (pressed) myOSystem.console().changeVerticalCenter(-1);
|
||||||
return;
|
return;
|
||||||
|
|
||||||
case Event::YStartIncrease:
|
case Event::VCenterIncrease:
|
||||||
if (pressed) myOSystem.console().changeYStart(+1);
|
if (pressed) myOSystem.console().changeVerticalCenter(+1);
|
||||||
return;
|
return;
|
||||||
|
|
||||||
case Event::ToggleFullScreen:
|
case Event::ToggleFullScreen:
|
||||||
|
@ -1830,8 +1830,8 @@ EventHandler::EmulActionList EventHandler::ourEmulActionList = { {
|
||||||
{ Event::ToggleFullScreen, "Toggle fullscreen", "" },
|
{ Event::ToggleFullScreen, "Toggle fullscreen", "" },
|
||||||
{ Event::OverscanDecrease, "Decrease overscan in fullscreen mode", "" },
|
{ Event::OverscanDecrease, "Decrease overscan in fullscreen mode", "" },
|
||||||
{ Event::OverscanIncrease, "Increase overscan in fullscreen mode", "" },
|
{ Event::OverscanIncrease, "Increase overscan in fullscreen mode", "" },
|
||||||
{ Event::YStartIncrease, "Move display up", "" },
|
{ Event::VCenterIncrease, "Move display up", "" },
|
||||||
{ Event::YStartDecrease, "Move display down", "" },
|
{ Event::VCenterDecrease, "Move display down", "" },
|
||||||
{ Event::FormatDecrease, "Decrease display format", "" },
|
{ Event::FormatDecrease, "Decrease display format", "" },
|
||||||
{ Event::FormatIncrease, "Increase display format", "" },
|
{ Event::FormatIncrease, "Increase display format", "" },
|
||||||
{ Event::TogglePalette, "Switch palette (Standard/Z26/User)", "" },
|
{ Event::TogglePalette, "Switch palette (Standard/Z26/User)", "" },
|
||||||
|
@ -1959,7 +1959,7 @@ const Event::EventSet EventHandler::AudioVideoEvents = {
|
||||||
Event::ScanlinesDecrease, Event::ScanlinesIncrease,
|
Event::ScanlinesDecrease, Event::ScanlinesIncrease,
|
||||||
Event::PhosphorDecrease, Event::PhosphorIncrease, Event::TogglePhosphor,
|
Event::PhosphorDecrease, Event::PhosphorIncrease, Event::TogglePhosphor,
|
||||||
Event::FormatDecrease, Event::FormatIncrease,
|
Event::FormatDecrease, Event::FormatIncrease,
|
||||||
Event::YStartDecrease, Event::YStartIncrease,
|
Event::VCenterDecrease, Event::VCenterIncrease,
|
||||||
Event::OverscanDecrease, Event::OverscanIncrease,
|
Event::OverscanDecrease, Event::OverscanIncrease,
|
||||||
Event::TogglePalette,
|
Event::TogglePalette,
|
||||||
};
|
};
|
||||||
|
|
|
@ -587,7 +587,7 @@ unique_ptr<Console> OSystem::openConsole(const FilesystemNode& romfile, string&
|
||||||
CMDLINE_PROPS_UPDATE("rd", PropType::Console_RightDiff);
|
CMDLINE_PROPS_UPDATE("rd", PropType::Console_RightDiff);
|
||||||
CMDLINE_PROPS_UPDATE("tv", PropType::Console_TVType);
|
CMDLINE_PROPS_UPDATE("tv", PropType::Console_TVType);
|
||||||
CMDLINE_PROPS_UPDATE("format", PropType::Display_Format);
|
CMDLINE_PROPS_UPDATE("format", PropType::Display_Format);
|
||||||
CMDLINE_PROPS_UPDATE("ystart", PropType::Display_YStart);
|
CMDLINE_PROPS_UPDATE("ystart", PropType::Display_VCenter); // TODO (SA): change option
|
||||||
CMDLINE_PROPS_UPDATE("pp", PropType::Display_Phosphor);
|
CMDLINE_PROPS_UPDATE("pp", PropType::Display_Phosphor);
|
||||||
CMDLINE_PROPS_UPDATE("ppblend", PropType::Display_PPBlend);
|
CMDLINE_PROPS_UPDATE("ppblend", PropType::Display_PPBlend);
|
||||||
|
|
||||||
|
|
|
@ -253,7 +253,7 @@ void Properties::print() const
|
||||||
<< get(PropType::Controller_SwapPaddles) << "|"
|
<< get(PropType::Controller_SwapPaddles) << "|"
|
||||||
<< get(PropType::Controller_MouseAxis) << "|"
|
<< get(PropType::Controller_MouseAxis) << "|"
|
||||||
<< get(PropType::Display_Format) << "|"
|
<< get(PropType::Display_Format) << "|"
|
||||||
<< get(PropType::Display_YStart) << "|"
|
<< get(PropType::Display_VCenter) << "|"
|
||||||
<< get(PropType::Display_Phosphor) << "|"
|
<< get(PropType::Display_Phosphor) << "|"
|
||||||
<< get(PropType::Display_PPBlend)
|
<< get(PropType::Display_PPBlend)
|
||||||
<< endl;
|
<< endl;
|
||||||
|
@ -298,7 +298,7 @@ void Properties::printHeader()
|
||||||
<< "Controller_SwapPaddles|"
|
<< "Controller_SwapPaddles|"
|
||||||
<< "Controller_MouseAxis|"
|
<< "Controller_MouseAxis|"
|
||||||
<< "Display_Format|"
|
<< "Display_Format|"
|
||||||
<< "Display_YStart|"
|
<< "Display_VCenter|"
|
||||||
<< "Display_Phosphor|"
|
<< "Display_Phosphor|"
|
||||||
<< "Display_PPBlend"
|
<< "Display_PPBlend"
|
||||||
<< endl;
|
<< endl;
|
||||||
|
@ -325,7 +325,7 @@ string Properties::ourDefaultProperties[static_cast<uInt8>(PropType::NumTypes)]
|
||||||
"NO", // Controller.SwapPaddles
|
"NO", // Controller.SwapPaddles
|
||||||
"AUTO", // Controller.MouseAxis
|
"AUTO", // Controller.MouseAxis
|
||||||
"AUTO", // Display.Format
|
"AUTO", // Display.Format
|
||||||
"0", // Display.YStart
|
"0", // Display.VCenter
|
||||||
"NO", // Display.Phosphor
|
"NO", // Display.Phosphor
|
||||||
"0" // Display.PPBlend
|
"0" // Display.PPBlend
|
||||||
};
|
};
|
||||||
|
@ -351,7 +351,7 @@ const char* const Properties::ourPropertyNames[static_cast<uInt8>(PropType::NumT
|
||||||
"Controller.SwapPaddles",
|
"Controller.SwapPaddles",
|
||||||
"Controller.MouseAxis",
|
"Controller.MouseAxis",
|
||||||
"Display.Format",
|
"Display.Format",
|
||||||
"Display.YStart",
|
"Display.VCenter",
|
||||||
"Display.Phosphor",
|
"Display.Phosphor",
|
||||||
"Display.PPBlend"
|
"Display.PPBlend"
|
||||||
};
|
};
|
||||||
|
|
|
@ -39,7 +39,7 @@ enum class PropType : uInt8 {
|
||||||
Controller_SwapPaddles,
|
Controller_SwapPaddles,
|
||||||
Controller_MouseAxis,
|
Controller_MouseAxis,
|
||||||
Display_Format,
|
Display_Format,
|
||||||
Display_YStart,
|
Display_VCenter,
|
||||||
Display_Phosphor,
|
Display_Phosphor,
|
||||||
Display_PPBlend,
|
Display_PPBlend,
|
||||||
NumTypes
|
NumTypes
|
||||||
|
|
|
@ -137,7 +137,8 @@ GameInfoDialog::GameInfoDialog(
|
||||||
ypos += lineHeight + VGAP;
|
ypos += lineHeight + VGAP;
|
||||||
t = new StaticTextWidget(myTab, font, HBORDER, ypos + 1, "V-Center ");
|
t = new StaticTextWidget(myTab, font, HBORDER, ypos + 1, "V-Center ");
|
||||||
myVCenter = new SliderWidget(myTab, font, t->getRight() + 2, ypos,
|
myVCenter = new SliderWidget(myTab, font, t->getRight() + 2, ypos,
|
||||||
"", 0, kYStartChanged, 7 * fontWidth, "px");
|
"", 0, kVCenterChanged, 7 * fontWidth, "px");
|
||||||
|
// TODO (SA):check relationship of ystart and vcenter
|
||||||
myVCenter->setMinValue(TIAConstants::minYStart - TIAConstants::defaultYStart);
|
myVCenter->setMinValue(TIAConstants::minYStart - TIAConstants::defaultYStart);
|
||||||
myVCenter->setMaxValue(TIAConstants::maxYStart - TIAConstants::defaultYStart);
|
myVCenter->setMaxValue(TIAConstants::maxYStart - TIAConstants::defaultYStart);
|
||||||
myVCenter->setTickmarkIntervals(4);
|
myVCenter->setTickmarkIntervals(4);
|
||||||
|
@ -456,11 +457,12 @@ void GameInfoDialog::loadEmulationProperties(const Properties& props)
|
||||||
const string& blend = props.get(PropType::Display_PPBlend);
|
const string& blend = props.get(PropType::Display_PPBlend);
|
||||||
myPPBlend->setValue(atoi(blend.c_str()));
|
myPPBlend->setValue(atoi(blend.c_str()));
|
||||||
|
|
||||||
// set vertical center (y-start)
|
// set vertical center
|
||||||
int vCenter = atoi(props.get(PropType::Display_YStart).c_str());
|
int vCenter = atoi(props.get(PropType::Display_VCenter).c_str());
|
||||||
if (vCenter)
|
if (vCenter)
|
||||||
{
|
{
|
||||||
// convert y-start into v-center
|
// convert y-start into v-center
|
||||||
|
// TODO (SA): fix this
|
||||||
vCenter = TIAConstants::defaultYStart - vCenter;
|
vCenter = TIAConstants::defaultYStart - vCenter;
|
||||||
myVCenter->setValueLabel(vCenter);
|
myVCenter->setValueLabel(vCenter);
|
||||||
}
|
}
|
||||||
|
@ -548,9 +550,9 @@ void GameInfoDialog::saveConfig()
|
||||||
myPPBlend->getValueLabel());
|
myPPBlend->getValueLabel());
|
||||||
int vCenter = myVCenter->getValue();
|
int vCenter = myVCenter->getValue();
|
||||||
if (vCenter)
|
if (vCenter)
|
||||||
// convert v-center into y-start
|
// convert v-center into y-start TODO (SA): fix this
|
||||||
vCenter = TIAConstants::defaultYStart - vCenter;
|
vCenter = TIAConstants::defaultYStart - vCenter;
|
||||||
myGameProperties.set(PropType::Display_YStart, std::to_string(vCenter));
|
myGameProperties.set(PropType::Display_VCenter, std::to_string(vCenter));
|
||||||
myGameProperties.set(PropType::Cart_Sound, mySound->getState() ? "STEREO" : "MONO");
|
myGameProperties.set(PropType::Cart_Sound, mySound->getState() ? "STEREO" : "MONO");
|
||||||
|
|
||||||
// Console properties
|
// Console properties
|
||||||
|
@ -792,7 +794,7 @@ void GameInfoDialog::handleCommand(CommandSender* sender, int cmd,
|
||||||
myPPBlend->setValueUnit("%");
|
myPPBlend->setValueUnit("%");
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case kYStartChanged:
|
case kVCenterChanged:
|
||||||
if (myVCenter->getValue() == 0)
|
if (myVCenter->getValue() == 0)
|
||||||
{
|
{
|
||||||
myVCenter->setValueLabel("Default");
|
myVCenter->setValueLabel("Default");
|
||||||
|
|
|
@ -103,7 +103,7 @@ class GameInfoDialog : public Dialog, public CommandSender
|
||||||
EditTextWidget* myNote;
|
EditTextWidget* myNote;
|
||||||
|
|
||||||
enum {
|
enum {
|
||||||
kYStartChanged = 'YSch',
|
kVCenterChanged = 'Vcch',
|
||||||
kPhosphorChanged = 'PPch',
|
kPhosphorChanged = 'PPch',
|
||||||
kPPBlendChanged = 'PBch',
|
kPPBlendChanged = 'PBch',
|
||||||
kLeftCChanged = 'LCch',
|
kLeftCChanged = 'LCch',
|
||||||
|
|
|
@ -21,7 +21,7 @@ my %prop_type = (
|
||||||
"Controller.SwapPaddles" => 15,
|
"Controller.SwapPaddles" => 15,
|
||||||
"Controller.MouseAxis" => 16,
|
"Controller.MouseAxis" => 16,
|
||||||
"Display.Format" => 17,
|
"Display.Format" => 17,
|
||||||
"Display.YStart" => 18,
|
"Display.VCenter" => 18,
|
||||||
"Display.Phosphor" => 19,
|
"Display.Phosphor" => 19,
|
||||||
"Display.PPBlend" => 20
|
"Display.PPBlend" => 20
|
||||||
);
|
);
|
||||||
|
@ -44,7 +44,7 @@ my @prop_type_as_string = (
|
||||||
"Controller.SwapPaddles",
|
"Controller.SwapPaddles",
|
||||||
"Controller.MouseAxis",
|
"Controller.MouseAxis",
|
||||||
"Display.Format",
|
"Display.Format",
|
||||||
"Display.YStart",
|
"Display.VCenter",
|
||||||
"Display.Phosphor",
|
"Display.Phosphor",
|
||||||
"Display.PPBlend"
|
"Display.PPBlend"
|
||||||
);
|
);
|
||||||
|
|
Loading…
Reference in New Issue