benji Profile picture
Sep 16, 2022 14 tweets 6 min read Read on X
1/ Have been asked about the Pinni distortion effect quite a few times, so thought I'd explain how it works.

One of my fave effects, displacement maps 🧵:
#gamedev #tutorial #shader #hlsl
2/ Going to start with a basic texture from Pinni to demonstrate each step.

The shader can work in any game engine; in Pinni we use Unity's awful shaders language, but for readability I'll be using HLSL. ImageImage
3/ Distorting an image from a fragment shader basically means taking each UV coordinate and moving it.

We want to move in the opposite direction of the origin, which we can get from the normalized (direction-only) result of our UV coordinate minus the center. Image
4/ Let's try making our texture distort like the graph above.

I've added an `amount` uniform to control the strength of the distortion.
5/ Here's the code for the above video (v_tex are UV coords). With just a couple added lines of code, we've already applied a distortion. Good job!!

...But the effect isn't quite done yet. Image
6/ We want to limit the effect of the distortion so the whole screen doesn't go crazy at once.

The strength of an effect is between 0 and 1, so if we make 0 black and 1 white, we can MAP out where the effect SHOULD be applied.

This is the "map" we base our displacement on. Image
7/ Almost there, but we want a donut for the "ripple".

To make the first circle, we found values based on each UV's distance from the center. We then do it again, but smaller!

Multiply them together and you've got a donut. Image
8/ Don't worry, I'll show code now.

The interpolation was performed using `smoothstep`. We added `spread` for the outer circle's size and then subtract a `width` to find the inner circle.

Spread controls how big the total area is, and width how thick the ring is. Image
9/ You can play with the values to see how each one changes the effects.
10/ With a little tweaking you can get the subtle ripple effect as seen when Pinni barks.
BONUS 1/ as for the rainbow effect that we've posted, that's just as simple to add.

We've already got the donut map of 0 to 1, so let's use that to control the intensity of a tint added to our texture.
BONUS 2/ Here's the code for that.

For the full Pinni effect, we randomly cycle through HSV colors (which are easier to see than RGB). Image
BONUS 3/ That's the whole shader-- about 6 lines of logic and only 4 uniforms. Not bad!

You can take the effect much further with little to no effort. E.g. we pass in a position rather than center screen, and support multiple ripples, among a few other things.

Go wild with it!!
END ???/ Follow me and go wishlist Pinni on Steam if you find any of this interesting and think the game looks cool lol

I'll be posting more code stuff as we get further along and hopefully open source as much of it as I can!

store.steampowered.com/app/1822590/Pi…

• • •

Missing some Tweet in this thread? You can try to force a refresh
 

Keep Current with benji

benji Profile picture

Stay in touch and get notified when new unrolls are available from this author!

Read all threads

This Thread may be Removed Anytime!

PDF

Twitter may remove this content at anytime! Save it as PDF for later use!

Try unrolling a thread yourself!

how to unroll video
  1. Follow @ThreadReaderApp to mention us!

  2. From a Twitter thread mention us with a keyword "unroll"
@threadreaderapp unroll

Practice here first or read more on our help page!

More from @benji__t

Sep 23, 2022
1/ Everybody told me they liked the last thread about simple effects in Pinni, so why not another one?

Customizable transition shaders in less than 4 lines 🧵:
#gamedev #tutorial #shader #hlsl #madewithunity
2/ Once again starting from a basic fragment shader. This will work in ANY engine, but we're using GLSL for simplicity.

Here's our base texture:
3/ What's the goal of this shader?

1. We want to black out the screen up to a certain point
2. That point should depend on the progress of the transition

Let's map the path of the transition in black and white. We can get a value based on each UV's distance from the center.
Read 12 tweets
Jul 16, 2022
1/ Are you an indie dev tired of supporting a proprietary game engine with immoral business practices?

Open source game engines, a 🧵:
2/ Godot has 50.8k stars on Github for all of the right reasons.

If you use Unity for 2D, Godot's workflow will feel right at home, and supports C# as well as their own python-like language.

(also, it was used on Sonic Colors?!?) ImageImage
3/ Monogame (XNA), another C# framework. This is THE 2D game framework imo, used on some of the best selling indie games of all time:

Terraria, Stardew Valley, Celeste, Bastion, and sooo many more... ImageImageImageImage
Read 13 tweets

Did Thread Reader help you today?

Support us! We are indie developers!


This site is made by just two indie developers on a laptop doing marketing, support and development! Read more about the story.

Become a Premium Member ($3/month or $30/year) and get exclusive features!

Become Premium

Don't want to be a Premium member but still want to support us?

Make a small donation by buying us coffee ($5) or help with server cost ($10)

Donate via Paypal

Or Donate anonymously using crypto!

Ethereum

0xfe58350B80634f60Fa6Dc149a72b4DFbc17D341E copy

Bitcoin

3ATGMxNzCUFzxpMCHL5sWSt4DVtS8UqXpi copy

Thank you for your support!

Follow Us!

:(