Chinese-Style Water Painting Shader
Skills: Shader, Unity, Substance Painter
This shader is inspired by the following reel. In this project, I aspire to create the unique Chinese-style whater painting feeling with shader.
Two kind of outline
1. Inner outline
I started by creating the inner outline. I detect the edges by coulacting the dot product between the normal vector and the view vector
data:image/s3,"s3://crabby-images/63ce7/63ce7cafcc0b6379b76b52458a8cff8d1fd60504" alt=""
data:image/s3,"s3://crabby-images/25beb/25bebeeb6dd9a1fdbd26052ce2c0ebb15d0a5ffb" alt=""
The result of the first outline shader.
data:image/s3,"s3://crabby-images/0445b/0445ba0c8157c25652417fa96f1d3886cf18b5ee" alt=""
This code stores the position of the vertex in each frame into textures.
2. Outter outline
Then I handled the outter outline. In this one, I used a basic vertex extrusion along the normal vector. I also played with the alpha using some noise maps.
data:image/s3,"s3://crabby-images/ef129/ef1299ace6c297d4fbc52657c95da523849022c9" alt=""
Combine
data:image/s3,"s3://crabby-images/f48f3/f48f392095553d7fa9f70cd1104c40a68fa3049e" alt=""
HandPaint-Feeling Texture
After finishing the outline, in Substance Designer, I worked on the HandPaint-Feeling Texture. I created different version of brush texture, and than I conbined those bushs together while playing around with the colors.
data:image/s3,"s3://crabby-images/4bc99/4bc99481c4c7658d02c262ff4ff59b300614871a" alt=""
Making different brush textures.
data:image/s3,"s3://crabby-images/214f4/214f4acbf2190e064bc6ee12003052409a3e5605" alt=""
Playing around with brush colors.
Result
data:image/s3,"s3://crabby-images/1b007/1b0079273e2756c3585cf730f9081b340e7be074" alt=""
Demo