mirror of https://github.com/stella-emu/stella.git
libretro: crop horizontal overscan option
This commit is contained in:
parent
04304fce32
commit
e428768307
|
@ -250,16 +250,15 @@ size_t StellaLIBRETRO::getStateSize()
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
float StellaLIBRETRO::getVideoAspect()
|
float StellaLIBRETRO::getVideoAspectPar()
|
||||||
{
|
{
|
||||||
uInt32 width = myOSystem->console().tia().width() * 2;
|
|
||||||
float par;
|
float par;
|
||||||
|
|
||||||
if (getVideoNTSC())
|
if (getVideoNTSC())
|
||||||
{
|
{
|
||||||
if (!video_aspect_ntsc)
|
if (!video_aspect_ntsc)
|
||||||
// non-interlace square pixel clock -- 1.0 pixel @ color burst -- double-width pixels
|
// non-interlace square pixel clock -- 1.0 pixel @ color burst -- double-width pixels
|
||||||
par = (6.1363635f / 3.579545454f) / 2;
|
par = (6.1363635f / 3.579545454f) / 2.0;
|
||||||
else
|
else
|
||||||
par = video_aspect_ntsc / 100.0;
|
par = video_aspect_ntsc / 100.0;
|
||||||
}
|
}
|
||||||
|
@ -267,13 +266,21 @@ float StellaLIBRETRO::getVideoAspect()
|
||||||
{
|
{
|
||||||
if (!video_aspect_pal)
|
if (!video_aspect_pal)
|
||||||
// non-interlace square pixel clock -- 0.8 pixel @ color burst -- double-width pixels
|
// non-interlace square pixel clock -- 0.8 pixel @ color burst -- double-width pixels
|
||||||
par = (7.3750000f / (4.43361875f * 4/5)) / 2;
|
par = (7.3750000f / (4.43361875f * 4.0f / 5.0f)) / 2.0f;
|
||||||
else
|
else
|
||||||
par = video_aspect_pal / 100.0;
|
par = video_aspect_pal / 100.0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return par;
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
float StellaLIBRETRO::getVideoAspect()
|
||||||
|
{
|
||||||
|
uInt32 width = myOSystem->console().tia().width() * 2;
|
||||||
|
|
||||||
// display aspect ratio
|
// display aspect ratio
|
||||||
return (width * par) / getVideoHeight();
|
return (width * getVideoAspectPar()) / getVideoHeight();
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
@ -322,13 +329,13 @@ void StellaLIBRETRO::setConsoleFormat(uInt32 mode)
|
||||||
{
|
{
|
||||||
switch(mode)
|
switch(mode)
|
||||||
{
|
{
|
||||||
case 0: console_format = "AUTO"; break;
|
case 0: console_format = "AUTO"; break;
|
||||||
case 1: console_format = "NTSC"; break;
|
case 1: console_format = "NTSC"; break;
|
||||||
case 2: console_format = "PAL"; break;
|
case 2: console_format = "PAL"; break;
|
||||||
case 3: console_format = "SECAM"; break;
|
case 3: console_format = "SECAM"; break;
|
||||||
case 4: console_format = "NTSC50"; break;
|
case 4: console_format = "NTSC50"; break;
|
||||||
case 5: console_format = "PAL60"; break;
|
case 5: console_format = "PAL60"; break;
|
||||||
case 6: console_format = "SECAM60"; break;
|
case 6: console_format = "SECAM60"; break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (system_ready)
|
if (system_ready)
|
||||||
|
@ -350,9 +357,9 @@ void StellaLIBRETRO::setVideoPalette(uInt32 mode)
|
||||||
{
|
{
|
||||||
switch (mode)
|
switch (mode)
|
||||||
{
|
{
|
||||||
case 0: video_palette = "standard"; break;
|
case 0: video_palette = "standard"; break;
|
||||||
case 1: video_palette = "z26"; break;
|
case 1: video_palette = "z26"; break;
|
||||||
case 2: video_palette = "custom"; break;
|
case 2: video_palette = "custom"; break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (system_ready)
|
if (system_ready)
|
||||||
|
@ -367,9 +374,9 @@ void StellaLIBRETRO::setVideoPhosphor(uInt32 mode, uInt32 blend)
|
||||||
{
|
{
|
||||||
switch (mode)
|
switch (mode)
|
||||||
{
|
{
|
||||||
case 0: video_phosphor = "byrom"; break;
|
case 0: video_phosphor = "byrom"; break;
|
||||||
case 1: video_phosphor = "never"; break;
|
case 1: video_phosphor = "never"; break;
|
||||||
case 2: video_phosphor = "always"; break;
|
case 2: video_phosphor = "always"; break;
|
||||||
}
|
}
|
||||||
|
|
||||||
video_phosphor_blend = blend;
|
video_phosphor_blend = blend;
|
||||||
|
@ -381,9 +388,9 @@ void StellaLIBRETRO::setVideoPhosphor(uInt32 mode, uInt32 blend)
|
||||||
|
|
||||||
switch (mode)
|
switch (mode)
|
||||||
{
|
{
|
||||||
case 0: myOSystem->frameBuffer().tiaSurface().enablePhosphor(phosphor_default, blend); break;
|
case 0: myOSystem->frameBuffer().tiaSurface().enablePhosphor(phosphor_default, blend); break;
|
||||||
case 1: myOSystem->frameBuffer().tiaSurface().enablePhosphor(false, blend); break;
|
case 1: myOSystem->frameBuffer().tiaSurface().enablePhosphor(false, blend); break;
|
||||||
case 2: myOSystem->frameBuffer().tiaSurface().enablePhosphor(true, blend); break;
|
case 2: myOSystem->frameBuffer().tiaSurface().enablePhosphor(true, blend); break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -393,9 +400,9 @@ void StellaLIBRETRO::setAudioStereo(int mode)
|
||||||
{
|
{
|
||||||
switch (mode)
|
switch (mode)
|
||||||
{
|
{
|
||||||
case 0: audio_mode = "byrom"; break;
|
case 0: audio_mode = "byrom"; break;
|
||||||
case 1: audio_mode = "mono"; break;
|
case 1: audio_mode = "mono"; break;
|
||||||
case 2: audio_mode = "stereo"; break;
|
case 2: audio_mode = "stereo"; break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (system_ready)
|
if (system_ready)
|
||||||
|
|
|
@ -69,6 +69,7 @@ class StellaLIBRETRO
|
||||||
|
|
||||||
bool getConsoleNTSC() { return console_timing == ConsoleTiming::ntsc; }
|
bool getConsoleNTSC() { return console_timing == ConsoleTiming::ntsc; }
|
||||||
|
|
||||||
|
float getVideoAspectPar();
|
||||||
float getVideoAspect();
|
float getVideoAspect();
|
||||||
bool getVideoNTSC();
|
bool getVideoNTSC();
|
||||||
float getVideoRate() { return getVideoNTSC() ? 60.0 : 50.0; }
|
float getVideoRate() { return getVideoNTSC() ? 60.0 : 50.0; }
|
||||||
|
@ -110,16 +111,16 @@ class StellaLIBRETRO
|
||||||
|
|
||||||
void setInputEvent(Event::Type type, Int32 state) { myOSystem->eventHandler().handleEvent(type, state); }
|
void setInputEvent(Event::Type type, Int32 state) { myOSystem->eventHandler().handleEvent(type, state); }
|
||||||
|
|
||||||
Controller::Type getLeftControllerType() { return myOSystem->console().leftController().type(); }
|
Controller::Type getLeftControllerType() { return myOSystem->console().leftController().type(); }
|
||||||
Controller::Type getRightControllerType() { return myOSystem->console().rightController().type(); }
|
Controller::Type getRightControllerType() { return myOSystem->console().rightController().type(); }
|
||||||
|
|
||||||
void setPaddleJoypadSensitivity(int sensitivity)
|
void setPaddleJoypadSensitivity(int sensitivity)
|
||||||
{
|
{
|
||||||
if(getLeftControllerType() == Controller::Type::Paddles)
|
if(getLeftControllerType() == Controller::Type::Paddles)
|
||||||
static_cast<Paddles&>(myOSystem->console().leftController()).setDigitalSensitivity(sensitivity);
|
static_cast<Paddles&>(myOSystem->console().leftController()).setDigitalSensitivity(sensitivity);
|
||||||
if(getRightControllerType() == Controller::Type::Paddles)
|
if(getRightControllerType() == Controller::Type::Paddles)
|
||||||
static_cast<Paddles&>(myOSystem->console().rightController()).setDigitalSensitivity(sensitivity);
|
static_cast<Paddles&>(myOSystem->console().rightController()).setDigitalSensitivity(sensitivity);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
void updateInput();
|
void updateInput();
|
||||||
|
@ -149,7 +150,7 @@ class StellaLIBRETRO
|
||||||
unique_ptr<Int16[]> audio_buffer;
|
unique_ptr<Int16[]> audio_buffer;
|
||||||
uInt32 audio_samples;
|
uInt32 audio_samples;
|
||||||
|
|
||||||
// (31440 rate / 50 Hz) * 16-bit stereo * 1.25x padding
|
// (31440 rate / 50 Hz) * 16-bit stereo * 1.25x padding
|
||||||
static const uInt32 audio_buffer_max = (31440 / 50 * 4 * 5) / 4;
|
static const uInt32 audio_buffer_max = (31440 / 50 * 4 * 5) / 4;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
|
@ -33,6 +33,7 @@ static int setting_ntsc, setting_pal;
|
||||||
static int setting_stereo, setting_filter, setting_palette;
|
static int setting_stereo, setting_filter, setting_palette;
|
||||||
static int setting_phosphor, setting_console, setting_phosphor_blend;
|
static int setting_phosphor, setting_console, setting_phosphor_blend;
|
||||||
static int stella_paddle_joypad_sensitivity;
|
static int stella_paddle_joypad_sensitivity;
|
||||||
|
static int setting_crop_hoverscan, crop_left;
|
||||||
|
|
||||||
static bool system_reset;
|
static bool system_reset;
|
||||||
|
|
||||||
|
@ -63,63 +64,63 @@ static void update_input()
|
||||||
|
|
||||||
switch(input_type[0])
|
switch(input_type[0])
|
||||||
{
|
{
|
||||||
case Controller::Type::BoosterGrip:
|
case Controller::Type::BoosterGrip:
|
||||||
EVENT(Event::JoystickZeroFire5, input_state_cb(0, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_A));
|
EVENT(Event::JoystickZeroFire5, input_state_cb(0, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_A));
|
||||||
EVENT(Event::JoystickZeroFire9, input_state_cb(0, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_Y));
|
EVENT(Event::JoystickZeroFire9, input_state_cb(0, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_Y));
|
||||||
// Fallthrough
|
// Fallthrough
|
||||||
|
|
||||||
case Controller::Type::Joystick:
|
case Controller::Type::Joystick:
|
||||||
default:
|
default:
|
||||||
EVENT(Event::JoystickZeroUp, input_state_cb(0, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_UP));
|
EVENT(Event::JoystickZeroUp, input_state_cb(0, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_UP));
|
||||||
EVENT(Event::JoystickZeroDown, input_state_cb(0, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_DOWN));
|
EVENT(Event::JoystickZeroDown, input_state_cb(0, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_DOWN));
|
||||||
// Fallthrough
|
// Fallthrough
|
||||||
|
|
||||||
case Controller::Type::Driving:
|
case Controller::Type::Driving:
|
||||||
EVENT(Event::JoystickZeroLeft, input_state_cb(0, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_LEFT));
|
EVENT(Event::JoystickZeroLeft, input_state_cb(0, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_LEFT));
|
||||||
EVENT(Event::JoystickZeroRight, input_state_cb(0, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_RIGHT));
|
EVENT(Event::JoystickZeroRight, input_state_cb(0, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_RIGHT));
|
||||||
EVENT(Event::JoystickZeroFire, input_state_cb(0, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_B));
|
EVENT(Event::JoystickZeroFire, input_state_cb(0, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_B));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case Controller::Type::Paddles:
|
case Controller::Type::Paddles:
|
||||||
EVENT(Event::PaddleZeroIncrease, input_state_cb(0, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_LEFT));
|
EVENT(Event::PaddleZeroIncrease, input_state_cb(0, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_LEFT));
|
||||||
EVENT(Event::PaddleZeroDecrease, input_state_cb(0, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_RIGHT));
|
EVENT(Event::PaddleZeroDecrease, input_state_cb(0, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_RIGHT));
|
||||||
EVENT(Event::PaddleZeroFire, input_state_cb(0, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_B));
|
EVENT(Event::PaddleZeroFire, input_state_cb(0, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_B));
|
||||||
//WIP = Event::PaddleZeroAnalog
|
//WIP = Event::PaddleZeroAnalog
|
||||||
|
|
||||||
EVENT(Event::PaddleOneIncrease, input_state_cb(1, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_LEFT));
|
EVENT(Event::PaddleOneIncrease, input_state_cb(1, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_LEFT));
|
||||||
EVENT(Event::PaddleOneDecrease, input_state_cb(1, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_RIGHT));
|
EVENT(Event::PaddleOneDecrease, input_state_cb(1, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_RIGHT));
|
||||||
EVENT(Event::PaddleOneFire, input_state_cb(1, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_B));
|
EVENT(Event::PaddleOneFire, input_state_cb(1, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_B));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
switch(input_type[1])
|
switch(input_type[1])
|
||||||
{
|
{
|
||||||
case Controller::Type::BoosterGrip:
|
case Controller::Type::BoosterGrip:
|
||||||
EVENT(Event::JoystickOneFire5, input_state_cb(1, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_A));
|
EVENT(Event::JoystickOneFire5, input_state_cb(1, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_A));
|
||||||
EVENT(Event::JoystickOneFire9, input_state_cb(1, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_Y));
|
EVENT(Event::JoystickOneFire9, input_state_cb(1, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_Y));
|
||||||
// Fallthrough
|
// Fallthrough
|
||||||
|
|
||||||
case Controller::Type::Joystick:
|
case Controller::Type::Joystick:
|
||||||
default:
|
default:
|
||||||
EVENT(Event::JoystickOneUp, input_state_cb(1, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_UP));
|
EVENT(Event::JoystickOneUp, input_state_cb(1, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_UP));
|
||||||
EVENT(Event::JoystickOneDown, input_state_cb(1, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_DOWN));
|
EVENT(Event::JoystickOneDown, input_state_cb(1, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_DOWN));
|
||||||
// Fallthrough
|
// Fallthrough
|
||||||
|
|
||||||
case Controller::Type::Driving:
|
case Controller::Type::Driving:
|
||||||
EVENT(Event::JoystickOneLeft, input_state_cb(1, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_LEFT));
|
EVENT(Event::JoystickOneLeft, input_state_cb(1, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_LEFT));
|
||||||
EVENT(Event::JoystickOneRight, input_state_cb(1, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_RIGHT));
|
EVENT(Event::JoystickOneRight, input_state_cb(1, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_RIGHT));
|
||||||
EVENT(Event::JoystickOneFire, input_state_cb(1, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_B));
|
EVENT(Event::JoystickOneFire, input_state_cb(1, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_B));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case Controller::Type::Paddles:
|
case Controller::Type::Paddles:
|
||||||
EVENT(Event::PaddleTwoIncrease, input_state_cb(2, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_LEFT));
|
EVENT(Event::PaddleTwoIncrease, input_state_cb(2, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_LEFT));
|
||||||
EVENT(Event::PaddleTwoDecrease, input_state_cb(2, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_RIGHT));
|
EVENT(Event::PaddleTwoDecrease, input_state_cb(2, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_RIGHT));
|
||||||
EVENT(Event::PaddleTwoFire, input_state_cb(2, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_B));
|
EVENT(Event::PaddleTwoFire, input_state_cb(2, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_B));
|
||||||
|
|
||||||
EVENT(Event::PaddleThreeIncrease, input_state_cb(3, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_LEFT));
|
EVENT(Event::PaddleThreeIncrease, input_state_cb(3, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_LEFT));
|
||||||
EVENT(Event::PaddleThreeDecrease, input_state_cb(3, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_RIGHT));
|
EVENT(Event::PaddleThreeDecrease, input_state_cb(3, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_RIGHT));
|
||||||
EVENT(Event::PaddleThreeFire, input_state_cb(3, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_B));
|
EVENT(Event::PaddleThreeFire, input_state_cb(3, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_B));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -166,7 +167,7 @@ static void update_variables(bool init = false)
|
||||||
#define RETRO_GET(x) \
|
#define RETRO_GET(x) \
|
||||||
var.key = x; \
|
var.key = x; \
|
||||||
var.value = NULL; \
|
var.value = NULL; \
|
||||||
if(environ_cb(RETRO_ENVIRONMENT_GET_VARIABLE, &var))
|
if(environ_cb(RETRO_ENVIRONMENT_GET_VARIABLE, &var) && var.value)
|
||||||
|
|
||||||
RETRO_GET("stella_filter")
|
RETRO_GET("stella_filter")
|
||||||
{
|
{
|
||||||
|
@ -187,6 +188,13 @@ static void update_variables(bool init = false)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
RETRO_GET("stella_crop_hoverscan")
|
||||||
|
{
|
||||||
|
setting_crop_hoverscan = !strcmp(var.value, "enabled");
|
||||||
|
|
||||||
|
geometry_update = true;
|
||||||
|
}
|
||||||
|
|
||||||
RETRO_GET("stella_ntsc_aspect")
|
RETRO_GET("stella_ntsc_aspect")
|
||||||
{
|
{
|
||||||
int value = 0;
|
int value = 0;
|
||||||
|
@ -317,6 +325,8 @@ static void update_variables(bool init = false)
|
||||||
|
|
||||||
if(!init && !system_reset)
|
if(!init && !system_reset)
|
||||||
{
|
{
|
||||||
|
crop_left = setting_crop_hoverscan ? (stella.getVideoZoom() == 2 ? 25 : 8) : 0;
|
||||||
|
|
||||||
if(geometry_update) update_geometry();
|
if(geometry_update) update_geometry();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -329,21 +339,22 @@ static bool reset_system()
|
||||||
// clean restart
|
// clean restart
|
||||||
stella.destroy();
|
stella.destroy();
|
||||||
|
|
||||||
// apply libretro settings first
|
// apply pre-boot settings first
|
||||||
update_variables(true);
|
update_variables(true);
|
||||||
|
|
||||||
// start system
|
// start system
|
||||||
if(!stella.create(log_cb ? true : false)) return false;
|
if(!stella.create(log_cb ? true : false)) return false;
|
||||||
|
|
||||||
// reset libretro window
|
|
||||||
update_geometry();
|
|
||||||
|
|
||||||
// get auto-detect controllers
|
// get auto-detect controllers
|
||||||
input_type[0] = stella.getLeftControllerType();
|
input_type[0] = stella.getLeftControllerType();
|
||||||
input_type[1] = stella.getRightControllerType();
|
input_type[1] = stella.getRightControllerType();
|
||||||
stella.setPaddleJoypadSensitivity(stella_paddle_joypad_sensitivity);
|
stella.setPaddleJoypadSensitivity(stella_paddle_joypad_sensitivity);
|
||||||
|
|
||||||
system_reset = false;
|
system_reset = false;
|
||||||
|
|
||||||
|
// reset libretro window, apply post-boot settings
|
||||||
|
update_variables(false);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -389,13 +400,13 @@ void retro_get_system_av_info(struct retro_system_av_info *info)
|
||||||
info->timing.fps = stella.getVideoRate();
|
info->timing.fps = stella.getVideoRate();
|
||||||
info->timing.sample_rate = stella.getAudioRate();
|
info->timing.sample_rate = stella.getAudioRate();
|
||||||
|
|
||||||
info->geometry.base_width = stella.getRenderWidth();
|
info->geometry.base_width = stella.getRenderWidth() - crop_left * (stella.getVideoZoom() == 1 ? 2 : 1);
|
||||||
info->geometry.base_height = stella.getRenderHeight();
|
info->geometry.base_height = stella.getRenderHeight();
|
||||||
|
|
||||||
info->geometry.max_width = stella.getVideoWidthMax();
|
info->geometry.max_width = stella.getVideoWidthMax();
|
||||||
info->geometry.max_height = stella.getVideoHeightMax();
|
info->geometry.max_height = stella.getVideoHeightMax();
|
||||||
|
|
||||||
info->geometry.aspect_ratio = stella.getVideoAspect();
|
info->geometry.aspect_ratio = stella.getVideoAspectPar() * (float) info->geometry.base_width / (float) info->geometry.base_height;
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
@ -405,25 +416,25 @@ void retro_set_controller_port_device(unsigned port, unsigned device)
|
||||||
{
|
{
|
||||||
switch (device)
|
switch (device)
|
||||||
{
|
{
|
||||||
case RETRO_DEVICE_NONE:
|
case RETRO_DEVICE_NONE:
|
||||||
input_devices[port] = RETRO_DEVICE_NONE;
|
input_devices[port] = RETRO_DEVICE_NONE;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case RETRO_DEVICE_JOYPAD:
|
case RETRO_DEVICE_JOYPAD:
|
||||||
input_devices[port] = RETRO_DEVICE_JOYPAD;
|
input_devices[port] = RETRO_DEVICE_JOYPAD;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case RETRO_DEVICE_MOUSE:
|
case RETRO_DEVICE_MOUSE:
|
||||||
input_devices[port] = RETRO_DEVICE_MOUSE;
|
input_devices[port] = RETRO_DEVICE_MOUSE;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case RETRO_DEVICE_KEYBOARD:
|
case RETRO_DEVICE_KEYBOARD:
|
||||||
input_devices[port] = RETRO_DEVICE_KEYBOARD;
|
input_devices[port] = RETRO_DEVICE_KEYBOARD;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
if (log_cb) log_cb(RETRO_LOG_ERROR, "%s\n", "[libretro]: Invalid device, setting type to RETRO_DEVICE_JOYPAD ...");
|
if (log_cb) log_cb(RETRO_LOG_ERROR, "%s\n", "[libretro]: Invalid device, setting type to RETRO_DEVICE_JOYPAD ...");
|
||||||
input_devices[port] = RETRO_DEVICE_JOYPAD;
|
input_devices[port] = RETRO_DEVICE_JOYPAD;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -439,11 +450,12 @@ void retro_set_environment(retro_environment_t cb)
|
||||||
{ "stella_filter", "TV effects; disabled|composite|s-video|rgb|badly adjusted" },
|
{ "stella_filter", "TV effects; disabled|composite|s-video|rgb|badly adjusted" },
|
||||||
{ "stella_ntsc_aspect", "NTSC aspect %; par|86|87|88|89|90|91|92|93|94|95|96|97|98|99|100|101|102|103|104|105|106|107|108|109|110|111|112|113|114|115|116|117|118|119|120|121|122|123|124|125|50|75|76|77|78|79|80|81|82|83|84|85" },
|
{ "stella_ntsc_aspect", "NTSC aspect %; par|86|87|88|89|90|91|92|93|94|95|96|97|98|99|100|101|102|103|104|105|106|107|108|109|110|111|112|113|114|115|116|117|118|119|120|121|122|123|124|125|50|75|76|77|78|79|80|81|82|83|84|85" },
|
||||||
{ "stella_pal_aspect", "PAL aspect %; par|104|105|106|107|108|109|110|111|112|113|114|115|116|117|118|119|120|121|122|123|124|125|50|75|76|77|78|79|80|81|82|83|84|85|86|87|88|89|90|91|92|93|94|95|96|97|98|99|100|101|102|103" },
|
{ "stella_pal_aspect", "PAL aspect %; par|104|105|106|107|108|109|110|111|112|113|114|115|116|117|118|119|120|121|122|123|124|125|50|75|76|77|78|79|80|81|82|83|84|85|86|87|88|89|90|91|92|93|94|95|96|97|98|99|100|101|102|103" },
|
||||||
|
{ "stella_crop_hoverscan", "Crop horizontal overscan; disabled|enabled" },
|
||||||
{ "stella_stereo", "Stereo sound; auto|off|on" },
|
{ "stella_stereo", "Stereo sound; auto|off|on" },
|
||||||
{ "stella_palette", "Palette colors; standard|z26" },
|
{ "stella_palette", "Palette colors; standard|z26" },
|
||||||
{ "stella_phosphor", "Phosphor mode; auto|off|on" },
|
{ "stella_phosphor", "Phosphor mode; auto|off|on" },
|
||||||
{ "stella_phosphor_blend", "Phosphor blend %; 60|65|70|75|80|85|90|95|100|0|5|10|15|20|25|30|35|40|45|50|55" },
|
{ "stella_phosphor_blend", "Phosphor blend %; 60|65|70|75|80|85|90|95|100|0|5|10|15|20|25|30|35|40|45|50|55" },
|
||||||
{ "stella_paddle_joypad_sensitivity", "Paddle joypad sensitivity; 3|4|5|6|7|8|9|10|11|12|13|14|15|16|17|18|19|20|1|2" },
|
{ "stella_paddle_joypad_sensitivity", "Paddle joypad sensitivity; 3|4|5|6|7|8|9|10|11|12|13|14|15|16|17|18|19|20|1|2" },
|
||||||
{ NULL, NULL },
|
{ NULL, NULL },
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -560,7 +572,7 @@ void retro_run()
|
||||||
//printf("retro_run - %d %d %d - %d\n", stella.getVideoWidth(), stella.getVideoHeight(), stella.getVideoPitch(), stella.getAudioSize() );
|
//printf("retro_run - %d %d %d - %d\n", stella.getVideoWidth(), stella.getVideoHeight(), stella.getVideoPitch(), stella.getAudioSize() );
|
||||||
|
|
||||||
if(stella.getVideoReady())
|
if(stella.getVideoReady())
|
||||||
video_cb(stella.getVideoBuffer(), stella.getVideoWidth(), stella.getVideoHeight(), stella.getVideoPitch());
|
video_cb(reinterpret_cast<uInt32*>(stella.getVideoBuffer()) + crop_left, stella.getVideoWidth() - crop_left, stella.getVideoHeight(), stella.getVideoPitch());
|
||||||
|
|
||||||
if(stella.getAudioReady())
|
if(stella.getAudioReady())
|
||||||
audio_batch_cb(stella.getAudioBuffer(), stella.getAudioSize());
|
audio_batch_cb(stella.getAudioBuffer(), stella.getAudioSize());
|
||||||
|
|
Loading…
Reference in New Issue