[go: up one dir, main page]

An Introduction to Shaders

Featuring ilithya

Shaders can be a superpower for a frontend developer, so it’s good to have a general understanding of what they are and how they work. In collaboration with the amazing ilithya, we’re bringing you an introduction to shaders!

This article will cover some main shader concepts and serve as a gentle introduction to the wide world of shaders. If you already have some shader experience, this should help you solidify some of your understanding.

In a separate article, we dig deeper into a couple of ilithya’s shaders and break down how they work. You can read that here.

Let’s hit the trail and learn about shaders!


A Conceptual Shader Introduction

Shaders can feel a bit overwhelming if we immediately jump into the code. Instead, let’s gain a high-level understanding of shaders by using a metaphor.

A Pixel Classroom

Let’s imagine a classroom of pixel students. Real screens can hold thousands of pixels, but for simplicity, there are just 16 pixels in this classroom representing our screen. The students’ desks are lined up in 4 rows and 4 columns.

pixels-1.png

Each pixel is taking a shader test to determine its color. Like any good school, there’s no cheating! Each pixel has the same test and has to complete it on their own. Everyone takes the test at the same time and changes color to the answer at the same time.

So if we want to make a solid pink shader, we’d give everyone a test that returns the color pink.

pixels-2.png

Each student gets the same answer because there are no dynamic values. It’s all hard-coded.

So how would we make a gradient?

We can’t hard-code the gradient by handing students slightly different tests. Remember: each student gets the same test.

However, our pixel students know where they sit in the classroom, and we can reference their column and row numbers on the test. If the test tells them to set their opacity of the pink color equal to 3 divided by their column number, the students across the columns will get:

0 ,

0.33 ,

0.66 ,

and 1.0.

With that set to their opacity our classroom will go from white to pink like this:

pixels-3.png

This little pixel classroom is heavily simplified but helps us grasp some basic shader principles. Shader artists use factors like pixel position, the time, and math like sine waves and random values to create amazing visuals.

It’s important to note that shaders are great for animations. Our pixels are super fast and can take 60 tests every second (60 frames per second), as long as they’re not too complex.

Now that we have a metaphor to work with let’s transition to reality and learn what shaders are.

So what is a shader?

Shaders are a special program that run on your computer’s Graphics Processing Unit (GPU) instead of the CPU. The shader program gets called for each individual pixel in parallel, making them super fast. This was our classroom all taking the test at the same time.

This comes with a catch, though: you need to design shaders differently than you might a JavaScript function.

If I wanted to color a grid of pixels with JavaScript, I might write a loop like this.

// Loop across each pixel and change one at a time
for (let i = 0; i < width; i++) {
  for (let j = 0; j < height; j++) {
    grid[i][j] = someColor;
  }
}

But this changes one pixel at a time in the order of the loops. This would be like our students being told by the teacher one at a time what color they should show.

With shaders you only have access to the inside of the loop, so you’d write this.

// function called for every pixel at the same time
void main() {
COLOR = some_color;
}

Shaders are incredibly versatile and are used in graphics across movies, video games, and the web! That animated gradient on the new Stripe site? That’s a shader!

Vertex and Fragment Shaders

There are two types of shaders, vertex shaders and fragment shaders. While we’re only talking about fragment shaders today, It’s helpful to briefly touch on the difference. Vertex shaders change the vertices of a shape, while fragment shaders change the pixels inside that shape.

A vertex shader defines the shape of our pixel classroom while the fragment shader controls the color of the pixels inside.

verts-pixels.png

We need both to make our image, but our vertex shader is very simple when we want to focus on the colors.

Cool, so I’m beginning to understand what shaders are, and I know they’re awesome. How tough is it to become a shader expert?

Are shaders hard?

Ilithya explained that getting started with shaders can be tough. They’re not written in JavaScript, but in OpenGL Shading Language (GLSL) , a C-style language. She also said that yeah, you should be decent with math if you’re going to be making custom shaders.

But ilithya told me how to start learning shaders without getting a mathematics degree or learning C:

Tweak other people’s shaders.

For any piece of code you’re trying to figure out: try to break it. Learn what each line does through trial and error. Then add comments as you figure it out.

Use a simple shader example as a starting point. Find the numbers in the shader and change them to see what they do. This playing with values, and changing a + to a - to see what happens is exactly how ilithya got started.

Now we’ve covered a conceptual overview of shaders. Let’s take a look at a few shaders to see some of what’s possible.

Shader Examples

Here are just a few examples of shaders used on the web. I recommend searching on CodePen and other similar sites for ‘shader’ to see what’s out there.

ilithya

mav-farm.png

Mav Farm

Lea Rosema

Karim Maaloul

Shader Resources

The Book of Shaders

Ilithya pointed us to the holy grail of shader resources: The Book of Shaders. The authors take you by the hand and show you how a few basic shaders work. Like giving you red and yellow paint, then you mix them yourself to discover orange.

The site has tons of working code demos, and they even point out lines of code that you should edit to change the effect. They even have a super helpful introduction for those coming from JS.

ShaderToy

ShaderToy is basically a CodePen dedicated purely to shaders. There’s some incredible stuff here, so don’t get overwhelmed. Start with the Book of Shaders to learn the basics, but peek here to see what’s possible.