New CRT shader from Guest + CRT Guest Advanced updates

New Release Version (2023-07-13-r1):

Notable changes:

  • Base (black) Mask strength feature added

Download link:

https://mega.nz/file/p1p2yS7Z#4caaGaPofPLjyJhjuFslEAE7C4oqhONTqz6nYQ-VOzg

11 Likes

I think i’ll need some extra time to update the new grade version like the older one was adapted. I guess it’s best to put it on my schedule.

1 Like

Definitely, looks better. Great job!

This one and the next image appear to have a very slight black separation and possibly a very slight black outline between the inactive mask and the boundary of the phosphor glow but it could just be me.

20230713_140412

20230713_140517

It’s not visible at all to me in these red transitions though.

20230713_140711

This shows the combination of Magic Glow and the new Base (Black) Mask Strength feature quite well.

20230713_140929

The area to the left of the green character (in the original image) seems to display some afterglow.

Thanks a lot @guest.r! I’m looking forward to tweaking and playing around with this new setting!

Before this, one of the ways to get this type of effect albeit improperly was to increase the gamma so that areas which would normally be dark now show visible mask the downside of this would have been washing out the mask on the brighter end. Now we can have nicer edge transitions and fades/blends to near black without suffering this penalty.

I want to see the effect this has on previously very sharp, harsh presets.

Thanks again for your hard work and dedication to the community!

3 Likes

No problem at all. I’m just glad you’ll consider adding it in that way at a certain point. I wasn’t planning to do another update until I get that new grade in but in the mean time I’ll see what this new update is about that you just posted. Thank you for always making this shader better.

Hmm, there seems to be an issue with how this new feature interacts with Magic Glow around the edges of pixels. To best illustrate the problem, here’s the Base Mask strength parameter set to maximum, with Magic Glow enabled and set to its default value of 0.08:

Here’s the same, but using regular Glow:

2 Likes

Maybe it’s the same thing I was noticing just amplified. It could be one cancelling the other. Remember, the two are supposed to either mix (additively) or be one in front (or on top of the other). It is quite possible that depending on the math and implementation that one is cancelling the other.

Remember both algorithms are trying to determine the final output colour of basically the same pixels. Maybe some tweaks to the way both are blended might need to take place?

Regular Glow doesn’t show the same issue but regular Glow doesn’t use the emulated phosphors exclusively to generate its effect.

It just lights extra pixels even in between the mask and regardless of the phosphor colours instead of exclusively allowing the RGB mix of the phosphor colours to determine the colour.

One possible workaround in the meantime could be to not “abuse” the setting until this cancellation is visible. Remember this is supposed to be something that’s very subtle and hardly ever visible. Perhaps testing at much lower levels of Base (Black) Mask strength might reveal a much more acceptable level of cancellation or maybe none that is visible at all?

If that be the case then there’s no need for change in the shader. So maybe try balancing Magic Glow and Base (Black) Mask a bit until you can barely see the unexcited Mask and there’s no black halo between the transitions and perhaps you might have your sweetspot right there.

Testing it further, it’s weirder than I thought. The black “halo” doesn’t change size or shape no matter what you change in the Glow parameters (it only seems to respond to Scanline and Sharpness changes, which change the shape of pixels, so that’s to be expected). Also, even if you set Glow Strength to 0 (which should disable it altogether), it still appears so long as Magic Glow is enabled, and immediately goes away when you disable it (i.e. enable regular Glow). Even stranger still is that the Magic Glow Mask Strength parameter appears tied to the Base Mask parameter, so if you lower it all the way down, you can no longer see the phosphors in the Base Mask, although raising the Base Mask parameter still brightens up the black areas of the screen. Not sure if that’s intended.

As for striking a balance, as it is, you basically have to have Base Mask set to 0.02 or 0.03 at most to not really notice the “halo”.

Anyway, here’s a shot using negative Glow values (also testing out the NES color decode shader, so that’s why the colors look different). I think it looks alright:

2 Likes

Interesting that you got it to work because I was just about to type that I concur with your findings. It’s really weird in my testing so far if you leave everything else at defaults and just enable Magic Glow and start to turn Base (Black) Mask strength up.

So I guess you need to be using negative glow values only for this to work then?

Does the NES Colour Palette have anything to do with it?

Okay, just realized that the black halo is exactly the area that gets affected by glow when you switch from Magic Glow to Ordinary Glow.

Changing (Magic) Glow Strength from +0.08 to -0.08 didn’t help.

I’m using the Sony CXA2025AS Palette in Mesen.

When I switch the Palette to Raw it seems to go away but I’ve never used the NES color decoder shader so I guess I have to prepend that for everything to work properly at least in Mesen.

So right now my colours are completely off. Maybe the halo only affects Black. There’s currently no black on my screen due to the Raw Palette being enabled without the decoder.

Update:

When I presented the nes-color-decoder.slang the black halo came back. Again when I switch Magic Glow to Ordinary Glow the glow fills almost the identical area as the black halo.

What I can say is that using the Ordinary Glow with negative values seems to be providing the effect that I was expecting. With positive values not so much due to the coloured pixels infiltrating the mask.

Definitely looking good with negative values. Even with the default low positive values the horizontal spread doesn’t seem enough to negatively impact the mask that much and you definitely don’t want to go overboard on the negative values either or you’ll end up with a “heatsink”.

So Magic Glow + Base (Black) Mask Strength seems to be a no go but it probably isn’t needed because Ordinary Glow works fine with it, especially negative values.

So probably nothing to fix. In any case this new parameter can actually replace the Magic Glow in a way that’s more realistic in my opinion so the two don’t necessarily need to be active at the same time.

Thanks again @guest.r!

No, the color decode shader has nothing to do with it. Negative Glow Strength values only do anything different if you use regular Glow. From what I can tell, Magic Glow does the same thing with positive and negative values. In other words, there’s three types of Glow:

  1. Regular Glow (positive values)
  2. Regular Glow (negative values)
  3. Magic Glow (positive and negative values do the same thing)

Base Mask works just fine with the first two. It’s Magic Glow that has the black “halo” problem regardless of what value you use, whether it’s positive, negative or even 0.

1 Like

So it seems like all’s well that ends well then. Looking forward to another one of @RetroGames4K’s CRT vs CRT Shader challenges because this was the one missing feature from shaders that always gave it away for me.

2 Likes

Oh sweet, I’ve been really wanting something like this!

Unfortunately it seems to not work correctly with slots, as they’re being displayed over the phosphor pattern. Realistically, the slot mask sits behind the phosphor strips and is only visible when it blocks the electron beam, and not when the phosphors are lit externally. Hopefully it’s easy enough to fix the order of the effects to address this.

Also suggesting naming the setting something like “Unlit Phosphor Level” or “Ambient Phosphor Level” instead.

After further testing it seems the green strip isn’t visible enough at a reasonable low brightness (near black rather than gray) like it appears in the real CRT photos. Could you consider biasing green at lower levels, or maybe break out the setting for each phosphor color?

1 Like

Haven’t tested Slot Masks yet but I’m really looking forward to. Hope it gets sorted out.

Update:

I didn’t observe this in my testing. Can you provide a screenshot to better illustrate? Slot Mask seems fine to me so far.

I think I’ve seen it before on the shaders, and works on slotmasks too, to achieve that effect I think is raising black level up if I remember, but I’m not sure if it’s that option or another.

3 Likes

This is probably a different implementation probably by HyperSpaceMadness or Dogway. I remember when this was added to the Mega Bezel Reflection Shader.

I don’t think that was available in CRT-GUEST-ADVANCED/NTSC until now though.

2 Likes

This is CRT Guest Advanced, and has the option Raise black level.

1 Like

What happens to the Mask in the Black areas of the screen when you raise the Black Level?

1 Like

No, black level is different, it applies to the scan lines. That is not what this ambient phosphor effect does.

Just increase Slot Mask Strength Dark Pixels to 1 and it should be clearly seen in the background. This is at 0.12, 0.06, and 0.03. This should not show the slots as they’re situated behind the phosphor stripes.

3 Likes

I don’t doubt you but for these things I think we should pull out our reference material just to verify and properly communicate how it’s supposed to look. Can you provide a clear image?

I’ll definitely go and see if I can dig one up.

What about you @RetroGames4K? Can you provide a clear gameplay photo of a dark area of the slot mask CRT screen showing how the unlit phosphors look!

This is an interesting shot:

https://www.reddit.com/r/crtgaming/comments/14vvweg/the_plot_thickens_i_got_my_old_crts_back/?utm_source=share&utm_medium=android_app&utm_name=androidcss&utm_term=1&utm_content=1

It looks like I’m seeing the phosphors in front of the mask but due to the lighting and camera settings, it appears as though the slot mask wires are also visible.

Here are some more examples including different screen types:

https://www.reddit.com/r/crtgaming/comments/u7jupn/panasonic_bth1390y_triad_shadow_mask/?utm_medium=android_app&utm_source=share

https://www.reddit.com/r/crtgaming/comments/u8944a/legendary_crt_princeton_af30_hd_reference_monitor/?utm_medium=android_app&utm_source=share

1 Like

For me it seems it lits up the phosphors of the black areas, if I don’t use it, it remains totally black.

I made the photos the best I could to apreciate black phosphors of my CRT. Also to note, on bare eyes are more visible.

5 Likes