top of page

Toon shader framework for character and environment

Writer's picture: feng jessicafeng jessica


involved technology: Unity Shader、HLSL、URP、Computer Graphics、ShaderGUI


This project was completed during my internship in Tencent games. it is also a training assignment for the shader framework. At the same time, I need to build the shader framework, complete the demo containing the environment and the character, and package it to the mobile phone to run.




Performance



the phone i am using for testing the performance is OPPO findX2 which has Qualcomm 585 CPU and Adreno 650 GPU with Android OS 10 system. here is some picture of the performance:






the fps is around 60.



Shader framework and document Architecture




Attributes.hlsl: some ATTRIBUTES AND CBUFFER DATA declarations and initialization, as well as functions for sampling mapping.

Common.hlsl: some common mathematical functions that will be used, as well as some custom auxiliary functions.

Shading.hlsl: some light calculation related functions and the total function of fragment when shading pass.

Includes.hlsl: shader dependency library.

PBRToonOutlinepass.hlsl: shading PASS

PBRToonForwardPass.hlsl : forward rendering PASS

MetaPass.hlsl : Meta PASS

Standard.shader: shader common to character scenes, divided into two categories, one compiles to Opengl/opengl ES renderers only. One class compiles to renderers other than Opengl/opengl ES renderers. Each class has 6 PASSes, Outline, Light Shading (Forward), ShadowCaster, Depth Pass, Depth Normal Pass and Meta Pass.



Shader property ,Implementation principle and process



1. shader property


The objects in the environment and the character will use the same shader as follow:




2.surface option





Workflow Mode : Specular or Metallic

SurfaceType : Opaque or Transparent

Render Face : Front Back Both (For Forward Pass)

Alpha Clipping : enable the Alpha Clipping or not



3. Base Map





The input of the basic texture,Albedo ,Normal and AO.

Albedo and AO merge channels into one texture for input.

Emission input a single texture.



4.Shadow





This is about the setting options for shadows. You can choose whether to use the ramp map as the shadow. If not, use the universal Toon rendering calculation method which is NdotL+2 line. And use Two thresholds to control the dividing line.

UseRampMapShadow : Use RampMap to control shadow attenuation.

VOffset: V coordinate sampled by RampMap

Shadow1Color: The first layer of shadow color

Shadow2Color: Second layer shadow color

Shadow1Step: First layer shadow threshold

Shadow1Feather: The first layer of shadow feathering value

Shadow2Step: Second layer shadow threshold

Shadow2Feather: The second layer of shadow feathering value

EnableInShadowMap : Enable InshadowMap or not. inShadowMap is the fixed shadow map.

Receive Shadow: Receive Shadow or not



5.Specular





This is about the Specular setting options. Merge normal map and Metal Smooth map. Take the normal map RG channel, Metal and Smooth each occupy a channel to merge into one texture. The normal calculation uses the RG channel to calculate the Z channel result.

You can choose whether it is the Specular rendering of the hair. If it is, the anisotropic hair Specular map will be sampled. If not, the GGX Specular item will be used for regular PBR calculation.

SpecularStep : Specular threshold

SpecularFeather : Specular feathering

Smoothness : Smoothness

HairSpecular : Use anisotropic hair Specular map or not

HairShiftMap : Tangent offset graph, offset intensity

SpecularShift : The first layer of Specular offset

SpecularShiftSec : The second layer of Specular offset

SpecularSecMul : The second layer of Specular intensity(*Specular)

EnablesSpecularHighlights : Use specular or not



6.Rim And Outline





Outline option use the normal expansion algorithm, and use the SmoothOutline algorithm to smooth the stroke.


OpenRim : Enable Rim Light or Not

EnableOutline : Enable Outline or not

UseSmoothNormal : Enable Smooth Outline or not. the algorithm using is from here:https://github.com/Jason-Ma-233/JasonMaToonRenderPipeline#%E5%B9%B3%E6%BB%91%E6%B3%95%E7%BA%BF%E5%AF%BC%E5%85%A5%E5%B7%A5%E5%85%B7ModelOutlineImporter)

OutlineColor:

OutlineWidth:



7.AdvancedOptions





Environment Reflections : Enable refelction or not

Enable GPU Instancing : Enable GPU Instancing or not

RenderQueue : Render Queue








75 views0 comments

Recent Posts

See All

The Pyres

Comments


bottom of page