유니티 쉐이더 팁 - Rime 스타일의 폭포 제작



유니티 쉐이더 팁 - Rime 스타일의 폭포 제작

금별 1 429 2019.11.26 17:21

There are games with such a memorable visual that it is terrible to consider the time spent on its development, take at least the latest God of War or RDR2. And there are projects that bribe their atmospheric, even if they are far from AAA. As an example, RiME has been praised for its style, sound and history. And recently, the level designer of the game went to the CD Projekt Red team to work on Cyberpunk 2077. RiME also inspired 3D artist Math Roodhuizen to create his own art.

And amid all this, I stumbled upon ArtStation on a realistic water creation guide. If last time it was about the river, then this time about the stylized waterfall. In the first part we will explain how to create a "ripple effect", and even directly in the game engine. For convenience, all steps are accompanied by gifs and / or pictures.
 

8lukajs1s-31mo7gfvimmginvuq.gif


First, thanks to Simon Trumpler, an artist from Tequila Games who worked on RiME . I was still new to shaders and VFX when I found his stuff and thought, “Wow, can I be able to do the same?”. I recommend reading the report to learn more about how to create stylized effects (such as fire, for example).

Now let's talk about the creation of a waterfall. This will be especially useful for people who are not familiar with the Shader Graph system. Our goal: to learn new ways of working and better understand the shaders.

I will use the example of Unity, but most of the methods are applicable in UE4 - if you are used to working there, just follow me. For convenience, each step is visualized by a gif or picture.

So, you will need:
 

  • Unity 2018.
  • Amplify Shader Editor (Unity plugin). But if you do not want to spend money on it, install Unity 2017 and download the free Shaderforge from the asset store (the new version of the engine does not support this plugin, but it still works in Unity 2017). Both tools are almost the same, except that some moments are called differently.
  • Autodesk Maya.
  • Something to create or edit textures. I use Photoshop, and sometimes even Substance Designer (but you definitely won't need it for this waterfall).


First, about the "ripple effect" that occurs when a waterfall falls on the surface. It can also be used for other purposes, for example, to create pulsations around objects in water.

ubjko5iypg5csetxipvglwfpjy8.gif

Open Unity and make sure you have the shader plugin installed. At the time of this writing, Unity has its own Shader Graph, which is still being developed. And while it’s not ready, I still recommend using the Amplify Shader Editor for Unity 2018 or Shaderforge in Unity 2017.

Create a new material and give it a name (I have it MAT_WaterWrinkles). Then right-click on the material in the Project Tab and go to Create> Amplify Shader> Surface Shader. In this case, the new shader will automatically apply.



You can select a shader at any time in the Materials tab> drop-down list of shaders (for Shaderforge there will be something like a PBL shader). Remember that the shader must be named both in the folder list and in the shader itself after it is opened.

8g05ve_dflwmkgqywfjpq30crdu.jpeg

As soon as you open a new shader, you will see something like this:

7ieepkf2levm_2zi1pjphvgeuue.jpeg

I will not write a detailed guide on the use of Shader Graph, and if you are completely new, first read the introductory guides.

In any case, to get the desired effect, we first need the usual Panner. Here it is with a test texture on the plane:

83hd9fk8wgk-hcuhmoxac7rcz_u.gif

Panner moves the UV coordinates. Make sure the Wrap Mode texture is set to Repeat. In Shaderforge, you may have to connect a temporary node to the Panner input, with Amplify some of these basic values ​​are already included in the node itself.

So, we have a moving texture. But we want to achieve this effect:

ubjko5iypg5csetxipvglwfpjy8.gif

And for this you need to scroll like this:

lwwwemj-vv8amtlxpfkynjek1gq.gif

As you can see, the structure of the node is the same - Panner simply moves the UV coordinates in the U and V directions (or X and Y). To get the right panning direction, we need to create a custom grid with UV. GIF for clarity:

By applying the same material to a different grid, we can control the direction of the texture in 3D space when it moves in the UV space.

j91odru3w4elitmc02elpxlm00s.gif

To enhance the effect, add a few more polygons and distort UV so that the texture in the center moves faster than at the edges. And place the UV so that the seam is not visible.

vsfvqynzumjlprdxippxpz_odqg.jpeg

An important conclusion follows from this: good effects rarely consist of one system and often represent a combination of several.

We got the texture moving in the right direction at the right speed. The UV sweep is placed in such a way that moving from right to left in the UV space with Panner turns into a movement in and out in the 3D space. To avoid seams in the texture on the 3D model, UV sweep must be added (hotkey X for snap to the grid) to the vertices of the texture space vertically. As a result, we have achieved the desired effect.



Now the transparency. Let's start with the basic things. Many simple calculations that you do in a shader will have values ​​from 0 (black) to 1 (white). That is, 0.5 is a shade of gray, and 0.2 is a shade of dark gray. When you apply these values ​​(in this case to the Opacity channel of the main output node), you will control the level of transparency of the material. Keep in mind that you first need to enable this feature. In Amplify, you can change the rendering type (in blend mode) from opaque to, for example, transparent. In this case, we will use the rendering type Transparent Cutout - the pixel displayed by this material is either completely transparent or completely opaque. This can be seen on the gif above - there are no "translucent" pixels displayed by this shader.

0zv2zwyehiurwcxxdvdq9c6jmrg.jpeg

Take the gradient texture in increments and place it on the shader. Here it connects to the output of the albedo (color) main node.

ftvmx1e9ujfhpcfcizmjwof5jmy.jpeg

And here it connects to the output of the Opacity Mask (this parameter is enabled when rendering type is Transparent Cutout).

zvl7oholli9y2wtctoafl_gcoda.jpeg

You can see that the gradient texture uses black and white pixel values ​​to determine transparency or opacity. Everything from 1 (white) to 0.5 (gray) becomes opaque, and everything from 0.5 (gray) to 1 (black) is completely transparent (or not displayed at all). Opacity Mask creates a hard line and rounds the values ​​to 0 or 1, depending on which number is closer.

Another grayscale texture:

ol_vkageq7enmygek80rhan1-hk.jpeg

Connected to the Opacity Mask:

cd9wjtycl78kqj0wx_f8mimpnti.jpeg

You get the idea. And guess how you can use it:

2urqdccavjdibo7blc0frlq-xpk.gif

You see a mostly blue image scrolling in the Shader Graph. And the fact that I use only R (red) output of this node. For the sake of optimization, I packed two grayscale textures (grayscale textures) into one file, but this is not necessary. Similar images can be packaged using Photoshop or Substance Designer.

px7k6ulmvnbqonfar8_sqjkfzga.jpeg

The ripple effect is a good start, but you can do better. Why not put two grayscale textures on top of each other to make the ripple effect more random?

zgtn78eo71em4hd8zyosznmyfjy.gif

I use the same texture, but I add different channels. I scroll through them at different speeds and slightly in different directions. The texture has a good gradient of gray values, which gives the feeling of a random ripple effect.

There is one more thing on the next gif that we haven’t discussed yet - so your option may look a little different:

7uowbnsld8tvgzcl6amkm2wajps.gif

You can see, for example, a pixel with a value of 0.2 (which is not rendered) passes over a pixel with a value of 0.4 (which is also not rendered) and suddenly becomes a pixel with a value of 0.6 - because we use an additional node (0.2 is added to 0.4 and it turns out to be 0.6). Adding these two wave grayscale textures on top of each other at different speeds and gives close to the desired effect.

2urqdccavjdibo7blc0frlq-xpk.gif

Here, to demonstrate the result, I added grayscale-textures on each other in Photoshop.

vaatuyfg9hr2clslyh3xoskstra.gif

However, the seam at the end of the mesh is still distinct. And we need to get this:

e-qs5fmcvn2fjqd3jdjxnoty-nw.gif

Instead of this:

4964w_tiq28mxap8bnczbd0tqm8.gif

In the first of the two gifs, the pulsations slowly subside and become smaller as they approach the edge of the grid. The easiest way to do this is to use vertex color (vertex colors).

Each model vertex contains its own data (for example, X, Y, and Z coordinates), as well as a color that has a value from 0 to 1. You can also set the color of the vertices in the 3D editor.


Most of the outer vertices are black (that is, they have a value of 0). They become white (closer to 1) when approaching the center. Note that you will need additional Subdivisions to get vertices that can be colored.

buuoppsouwnxep4s4ujpbbazixk.jpeg

For example, in Maya for coloring, you can go to the Mesh Display> Paint Vertex Color menu and click on the More Options field.

Now we can connect Vertex Color in our shader using Multiply.

66sm-wwyze85kybg_srrerrqabo.gif

I applied a gradient over the textures used and set the layer mode to Multiply.

xiwid1mg_pfo461adllkdm2t6-k.gif

The gradient enhances the gray value to 0 (black), so it will be more difficult to render the pixels (they are not displayed below the value of 0.5). This leads to the fact that the ripple lines shrink closer to the edge (the colors of the peaks mainly act as a gradient).

e-qs5fmcvn2fjqd3jdjxnoty-nw.gif

I added a few more nodes to control the thickness of the ripple lines. Here is the complete graph:

vub-soqrrulpflvlb3xhnzacme8.jpeg

Just experiment with the speed / direction of scrolling, adjust the texture and try to change the tiling to squeeze the maximum out of the effect.

This will help us in creating a more complex shader - a waterfall. We'll talk about it in the next part.

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

Comments

키자비 02.17 00:52

멋지네요~ 감사합니다.

번호 포토 분류 제목 글쓴이 날짜 조회
공지 외국 교육 이펙트 튜토리얼 모음(사이트/유튜브/비메오등등..) 댓글+4 금별 2018.05.12 1739
공지 이펙트 추천 사이트/블로그 댓글+6 금별 2018.05.12 2905
159 언리얼4 200 Unreal Engine Niagara Tutorials | 200 Real Time VFX Tutorials ashif 08.09 9
158 언리얼4 Firy Dissolve Effect in Unreal Engine Material Editor ashif 08.08 12
157 유니티 유니티 쉐이더그래프 - 노이즈 관련 이미지 팁 금별 08.06 21
156 언리얼4 Smoke in UE4 Niagara Pack01 in Unreal Engine Marketplace ashif 08.05 12
155 언리얼4 Fire character Effect | Unreal Engine Niagara Tutorials | UE4 Niagara Flame boy ashif 08.03 21
154 유니티 유니티 - 매직 카드제작 트릭팁 금별 08.02 46
153 언리얼4 Eye of Sauron from The Lord of the Rings | Unreal Engine Niagara Tutorials | UE4 Niagara Eye FX ashif 07.31 41
152 언리얼4 언리얼4 - 머터리얼에서 양면 렌더링 방법 금별 07.30 51
151 언리얼4 언리얼4 - Vertex(정점) Offset 흡수 효과 금별 07.30 71
150 유니티 유니티 앰플리파이 쉐이더 이펙트 - 물속성+불속성 토네이토 금별 07.30 50
149 언리얼4 Bubble Burst Effect | Unreal Engine Niagara Tutorials | UE4 Niagara Bubble Burst ashif 07.30 21
148 언리얼4 언리얼4 나이아가라 - 트레일관련 미니팁 금별 05.30 157
147 유니티 유니티 - 기어즈5 Hammer of Dawn 이펙트 만들기 금별 05.16 142
146 유니티 포토샵으로 디졸브 쉐이더를 사용해 2D 툰이펙트 제작팁 댓글+2 금별 05.16 361
145 언리얼4 언리얼4 이펙트 튜토리얼 - 애펙을 사용한 트랜지션 효과 만들기 금별 04.01 242
144 유니티 유니티 URP 쉐이더그래프 팁 - 블러만들기 금별 04.01 196
143 유니티 유니티 HDRP에서 소규모 고품질의 영상 제작 - Unite Tokyo 2019 금별 03.29 185
142 3D Visual Effects Bootcamp: The Rise of Realtime 금별 03.26 95
141 언리얼4 언리얼4 머터리얼 튜토리얼 - Procedural 노이즈제작 금별 03.26 126
140 언리얼4 언리얼4 머터리얼 팁 - 머터리얼만으로 밴드형태 구현하기 금별 03.26 114
139 언리얼4 언리얼4 머터리얼 팁 - 머터리얼만으로 트위스트 구현하기 금별 03.26 119
138 유니티 유니티 쉐이더 그래프 - Orthographic 뎁스 금별 03.26 131


Banner
Facebook Twitter GooglePlus KakaoStory NaverBand