Pixel Lo-fi in Unity

image

The visual style of my under development game LAUNDRY GAME (yes, this is an unscrupulous advertisement) is based on large clear pixels in 3D. I love low resolution 3D. I was asked a lot of questions about how I did this, so I decided to write a tutorial.

Note: this is only my decision! There are methods using shaders, blitting graphics and other tricks, but for my small solo project such a solution turned out to be quite enough.

Addition 1: smart guy Pete Brisburn sent a script here in case you don’t like the “quad in the sky” trick (steps 4-6)!

Stage 1: preparing the source scene



First you need to prepare the scene! I created this little cube with my bird friend Oscar J. Ruffles . He runs around the cube and constantly screams. (These are just the character controller and animator connected together.)

But take a look at these disgusting smoothing lines! Fu, let's get rid of them.

Stage 2: remove the MSAA cameras



Highlight Main Camera and uncheck the Allow MSAA box. As you can see, pixels are much sharper. But there is no upscaling yet! That is, all pixels will be small. It needs to be fixed.

Stage 3: rendering the camera in the render texture



I zoom in (to get huge sharp pixels) using RenderTexture and rendering the Main Camera into this texture. This will allow us to use this RenderTexture like any regular texture!


Here are the options that I will use for my RenderTexture . Size is the size at which we zoom. The smaller the number, the larger the pixels. I usually use numbers between 300 and 600 for both values ​​(excellent Celeste , for example, performs a zoom from 320x200).

Filter Mode is a way to perform up / downscaling. The “Point” mode does not add anti-aliasing, that is, it preserves the sharpness of pixels that we need so much.

But what happened?


Now we render Camera not on the screen, but in RenderTexture, so nothing is rendered on the screen!

To fix this, we need to set up another camera , but this time a little different.

Stage 4: Create a Zoom Camera + Quad



Let's start by creating a new camera in the scene (let's call it QuadCamera ) and attach a 3D quad to it as a child.

Stage 5: place it somewhere in the void



Then we need to take the QuadCamera and shove it somewhere. No matter where, the main thing is that it should never be visible from the Main Camera . I usually lift it high into the sky or lower it deep down.

Step 6: Attach the Render Texture to the Quad and Place It in Front of the Camera



Then we take quad. I set Sprites-Default for it (a standard Unity material that is not affected by lighting) so that it will not be affected by any random lighting in the scene. Then drag the RenderTexture onto the quad. Now quad shows our scene! Then we move the quad so that it is in front of the QuadCamera (the camera that now renders the target screen).


As you can see, now the scale of rendering has been increased! Oscar can constantly click its pixel beak! But at the same time, we got much closer to his head.

Stage 7: adjust the cameras



At the last stage, we’ll go back to my Main Camera and set it up so that we see about the same thing as before. Here you can increase the size of the render texture so that the pixels become slightly smaller, or reduce it, so that only 7 pixels fit on the screen. It is time for experimentation, find what suits you personally.

Bonus: make textures not blurry



As we have seen, the texture of the model (Oscar's big eye) has been blurred all this time. This happened because when importing textures into Unity, the standard parameters are selected for generating mip-textures and smooth scaling. But we do not need this. Therefore, when importing textures, you must disable Generate Mip Maps and select Point mode for Filter Mode .

Source: https://habr.com/ru/post/465479/


All Articles