Updated crt-pi shader
-
i think it's in the various files you merge in to the dat via romlister, to add metadata to help searching. eg controls.dat/xml has a 'cocktail' field, which seems to be set to true for vertical games: http://controls.arcadecontrols.com/
however, the file doesn't seem to be complete. eg, i couldn't find donpachi listed at all, which is definitely a vertical game. might be a start, though!
-
@Floob said in Updated crt-pi shader:
I guess the best way to apply these would be on a per rom cfg basis? (unless the vertical and horizontal games were split into their own folder/emulator settings)
If thats the case, a script could potentially parse a mame .dat file that contained the rom orientation then output a .cfg file with the correct .glslp file referenced for each game?If you are going to implement this keep in mind that people who have vertically oriented screens need the opposite shaders to those who have horizontal screens. An option to use the opposite shaders would be needed for those people.
-
the shaders in retropie have been updated to these latest versions. here's some pretty screenshots:
crt-pi
crt-pi-curvature
crt-pi-vertical
crt-pi-curvature-vertical
reinstall retroarch via retropie-setup to get the new ones.
PS @davej - i added pre-modified curvature versions with the mask + curve + scanlines turned on. hope that's ok? can always remove if not :)
-
Just to clarify will the new shaders make their way into the RetroPie distribution package or will we need to download and manually install them from here on out?
-
@Riverstorm said in Updated crt-pi shader:
Just to clarify will the new shaders make their way into the RetroPie distribution package or will we need to download and manually install them from here on out?
they are in. a reinstall of retroarch would get them, or i presume the just released version of retropie :)
-
@dankcushions said in Updated crt-pi shader:
@Riverstorm said in Updated crt-pi shader:
Just to clarify will the new shaders make their way into the RetroPie distribution package or will we need to download and manually install them from here on out?
they are in. a reinstall of retroarch would get them, or i presume the just released version of retropie :)
Oh, thanks Dank, I didn't see the new release. This will give me something to setup over the holiday weekend! ;)
-
@Riverstorm would need to install retroarch from source if the shader was updated after the last binaries were built. I will split out the overlays and shaders for retropie 4.0 so they can be updated independently
-
oh, careful installing retroarch from source as it currently breaks mame2003! i'm trying to fix that at the moment.. hopefully tomorrow
-
@BuZz said in Updated crt-pi shader:
@Riverstorm would need to install retroarch from source if the shader was updated after the last binaries were built. I will split out the overlays and shaders for retropie 4.0 so they can be updated independently
Thanks Buzz, shaders made me a Libretro core convert. It's like art in motion on my screen, simply beautiful! Have a great weekend! ;)
@dankcushions Thanks Dank for the heads up!
-
Is anyone using the shader with Atari 2600 (lr-stella) games? It looks great to me with MAME, FBA, NES and SNES but the Atari seems off or touch to blurry. I've been using River Raid as my test game and looking at the word FUEL and the text on the bottom it looks like it goes from blue to white with slight lighter shading until it soft blurs out to much and not really artifact-ish. Could the rendering engine of Stella be creating a different effect with the Shader?
-
@Riverstorm is your mask type set to 0 in the config file?
-
@Riverstorm The Atari 2600 has a very low horizontal resolution. By default, crt-pi just uses linear filtering horizontally - which, in combination with the low resolution, is what is causing it to look blurry. You can make it sharper by uncommenting the SHARPER line so it reads.
#define SHARPER
-
@davej said in Updated crt-pi shader:
@Riverstorm The Atari 2600 has a very low horizontal resolution. By default, crt-pi just uses linear filtering horizontally - which, in combination with the low resolution, is what is causing it to look blurry. You can make it sharper by uncommenting the SHARPER line so it reads.
#define SHARPER
Perfect! That was the ticket! Is it best to duplicate the files to accommodate the Atari Shader? I duplicated crt-pi.glslp and crt-pi.glsl adding -atari to the name. Then modified the shader 0 line to point to the newly named glsl while uncommenting
#define SHARPER
or how are people doing per emulator tweaks.Should I do anything with the mask or leave as is?
-
@Riverstorm said in Updated crt-pi shader:
Perfect! That was the ticket! Is it best to duplicate the files to accommodate the Atari Shader? I duplicated crt-pi.glslp and crt-pi.glsl adding -atari to the name. Then modified the shader 0 line to point to the newly named glsl while uncommenting
#define SHARPER
or how are people doing per emulator tweaks.That sounds a reasonable approach. I tend to use just one shader unless I'm working on them so I'm not the best person to ask.
Should I do anything with the mask or leave as is?
It's pretty much an aesthetic decision as to which mask to use so whichever you think looks best.
-
@davej said in Updated crt-pi shader:
That sounds a reasonable approach. I tend to use just one shader unless I'm working on them so I'm not the best person to ask.
Thanks Dave, I didn't want to mess up how MAME and other emulators looked so I duplicated it with the tweak for Atari but out of curiosity would leaving
#define SHARPER
on effect how the other emulators look or would they still be the same? -
@Riverstorm said in Updated crt-pi shader:
Thanks Dave, I didn't want to mess up how MAME and other emulators looked so I duplicated it with the tweak for Atari but out of curiosity would leaving
#define SHARPER
on effect how the other emulators look or would they still be the same?Images will look a bit more pixelated with SHARPER enabled. The reasons for having the default as linear filtering is a) it's needed to get 1080P @ 60Hz on a Pi1/Pi2 (I don't know about a Pi3) and b) I think it looks better for games that try to create smooth transitions with limited palettes.
Ultimately, it's down to personal preference.
The image below shows some example differences. Default on the left, sharper on the right.
-
@davej said in Updated crt-pi shader:
Ultimately, it's down to personal preference.
Thanks Dave for the side by side I wouldn't be able to see the difference without it. I prefer the default (exception being Atari ;). I agree on the limited palette-smooth transition. I think consoles on old CRT TV's were able to take advantage of that or I should say they optimized their graphics to create some nice color blending as a side effect of low resolutions. Also on old CRT's I don't think they really had "true" blacks as TV's do now but more of a dark muddy gray and they definitely had more of a blur. :)
-
Hi Dave, I have a Pi 3 I picked up over the weekend and have been playing about with RetroPie and reading up a LOT of info.... However there seems to be an issue with the crt-pi shaders running at 1080p on my tv. The frame rate seems to be a near constant 52.9-53fps in Altered Beast for the Megadrive (haven't changed the default core) and any other Megadrive/Genesis game for that matter. I then tried some Super NES games and the rate was nearly 60 fps.
At first I thought I thought it may be down to CPU use so went ahead and tested different overclock settings by editing the config.txt file, this seems to make no change whatsoever if I set the ARM to 1200, 1400, 800 or stock. I've even messed around vsync on and off but that made no difference.
I then tried reducing the render resolution in the configuration editor to less than 1080p (eg 800x600) and I then get a full 60fps. Has anyone else had an issue?
-
@aikon82
It sounds like the emulator and shader are fighting for memory bandwidth. Although the shader can run at 1080P@60Hz, it can only do so if other parts of the system don't do too much memory access at the same time. On the Pi2, I don't have a Pi3 to test with, some SNES games are OK and some just push it over limit and drop occasional frames. As the Pi3 has similar memory to the Pi2, I suspect the same thing is happening for you.Things you can do to help:
- Overclock the memory as fast as it will go.
- Use a more efficient emulator if there is one. (Some need less memory accesses than others.)
- Change the audio resampler driver to 'nearest'.
You can also try making the following changes to the shader:
- Don't enable CURVATURE or SHARPER.
- Try enabling FAKE_GAMMA.
- Disable GAMMA altogether.
- Set MASK_TYPE to 0.
- Disable MULTISAMPLE.
- Disable SCANLINES.
Although the shader changes don't actually reduce the amount of memory it needs to access, they do mean the GPU can better tolerate the CPU accessing memory when the GPU wants to.
Ironically, Pi1s and Pi Zeros have less of a problem with this issue because you can run their memory faster. They just have a problem running the emulators fast enough. ;)
-
You could check if you have any custom aspect ratio set with "aspect_ratio_index" and make sure that "video_scale_integer" is set to "true". If I set any of these differently I also get the lag, if not, constant 60fps.
Contributions to the project are always appreciated, so if you would like to support us with a donation you can do so here.
Hosting provided by Mythic-Beasts. See the Hosting Information page for more information.