Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/etopuz/shadernotes
Shaders created in unity for learning and experimenting purposes
https://github.com/etopuz/shadernotes
cg distortion-effects lambertian-shading phong-lighting shader shader-development shader-programming shaderlab shaders stencil-shaders unity unity-3d unity-shader unity-shaders unity-tutorial unity2d unity3d unity3d-script unityshader
Last synced: 11 days ago
JSON representation
Shaders created in unity for learning and experimenting purposes
- Host: GitHub
- URL: https://github.com/etopuz/shadernotes
- Owner: etopuz
- Created: 2024-06-21T12:20:03.000Z (8 months ago)
- Default Branch: main
- Last Pushed: 2025-01-10T13:06:18.000Z (about 1 month ago)
- Last Synced: 2025-01-31T03:55:57.583Z (21 days ago)
- Topics: cg, distortion-effects, lambertian-shading, phong-lighting, shader, shader-development, shader-programming, shaderlab, shaders, stencil-shaders, unity, unity-3d, unity-shader, unity-shaders, unity-tutorial, unity2d, unity3d, unity3d-script, unityshader
- Language: C#
- Homepage:
- Size: 74.4 MB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
## Shaders And CG Notes On Unity
Experiments and notes based on different sources. This page shows the effects and key points of shaders created. Also for each experiment, there is a link to see full codes. Shaders are created in [cg](https://developer.download.nvidia.com/cg/Cg_language.html) for now.## Sources
- [The Unity Shaders Bible](https://www.jettelly.com/store/books/the-unity-shaders-bible/)
- [Freya Holmér's Shader Video Series](https://www.youtube.com/watch?v=kfM-yu0iQBk&list=PLImQaTpSAdsCnJon-Eir92SZMl7tPBS4Z)
- [Minions Art's Shader Tutorials](https://www.patreon.com/minionsart)## Assets
- [FREE Animated Isometric Prototyping Hero by Engvee](https://engvee.itch.io/animated-isometric-prototyping-hero)
- [Kenney's Prototype Textures](https://www.kenney.nl/assets/prototype-textures)Many thanks to the creators of these valuable sources.
## Experiments
### Experiment_002 Stencil Shader
data:image/s3,"s3://crabby-images/a058c/a058ca2d4e58355f2f9ca357f37a1867f60cbc9c" alt="Hole Mechanic From Donut County"
data:image/s3,"s3://crabby-images/c0716/c071623fa521a7fe5e47ca6b206c846baa8535f4" alt="StencilMask Shader"
data:image/s3,"s3://crabby-images/f8f1c/f8f1cf7c6954ce803303e333e794cb135754409b" alt="StencilBlocked Shader"
[See Full Stencil Shader Codes](Assets/Experiments/Experiment2_Stencil/Code/Shaders)
### Experiment_003 Kaleidoscope Effect
data:image/s3,"s3://crabby-images/07622/07622ef29b1f7f201d4686f00967d2b488dff792" alt="Kaleidoscope Effect"
data:image/s3,"s3://crabby-images/225b3/225b320dbeea62b61573c22a9acb953eb5d1e9db" alt="Kaleidoscope Shader"
[See Full Kaleidoscope Effect Shader Codes](Assets/Experiments/Experiment3_Kaleidoscope/Code/Shaders/Kaleidoscope.shader)
**Note**: Unity_Rotate_Degrees_float is a function written by Unity included in Shader Graph. The function rotates the value of input UV around a reference point defined by the input Center by the amount of input rotation. [See in Shader Graph Manual](https://docs.unity3d.com/Packages/[email protected]/manual/Rotate-Node.html)
### Experiment_004 Zoom Effect
data:image/s3,"s3://crabby-images/8a70d/8a70dd99cf42a6a3d3b9efd83d78b4109d5e6a30" alt="Zoom Effect"
data:image/s3,"s3://crabby-images/8e668/8e668165f759f1146ad6f0c0690c213319194e69" alt="Kaleidoscope Shader"
\
[See Full Zoom Effect Shader Codes](Assets/Experiments/Experiment4_Zoom/Code/Shaders/ZoomShader.shader)### Experiment_005 Health Bar
#### Experiment_005.1 Simple Health Bar
data:image/s3,"s3://crabby-images/eefb1/eefb1a9bd5d30c9a7a1e51d0b3b3d2e8b5956d2c" alt="Simple Health Bar"
data:image/s3,"s3://crabby-images/0580d/0580daf7ece6cb11b4a90c7f05e9ec211fb8bd8c" alt="Simple Health Bar Shader"#### Experiment_005.2 Fancy Health Bar
data:image/s3,"s3://crabby-images/63979/63979d5d734095891b6dde4314ac3904b72913be" alt="Fancy Health Bar"
data:image/s3,"s3://crabby-images/c3d2b/c3d2b681e59e4f33c082d76e999153d952da2575" alt="Fancy Health Bar Shader"[See Full Healthbar Shader Codes](Assets/Experiments/Experiment5_HealthBar/Code/Shaders)
\
\
**Note**: My implementation for roundness and border is overcomplex. It can be easily made with SDF. Please watch [this part from Freya Holmér's Shader Video](https://youtu.be/mL8U8tIiRRg?t=4737) if you'd like to see a clean implementation.### Experiment_006 Sprite Outline Effect
data:image/s3,"s3://crabby-images/bdaf2/bdaf235051a833ca9f6a1a4cc78792746a27050c" alt="Sprite Outline"
data:image/s3,"s3://crabby-images/eb501/eb501bc2d7766cba5e9661a975551b382b815fee" alt="Sprite Outline Shader"
\
[See Full Sprite Outline Shader Codes](Assets/Experiments/Experiment6_SpriteOutline/Code/Shaders/SpriteOutlineShader.shader)### Experiment_007 Lighting
data:image/s3,"s3://crabby-images/e79ac/e79aca6be679740a6290a7064aff60f1f05fa939" alt="Lambertian Phong"
data:image/s3,"s3://crabby-images/2b0fa/2b0fa5ebcfe9c6058861acf9981d352f211093f6" alt="Lambertian Phong Shader"
\
[See Full Lighting codes](Assets/Experiments/Experiment7_Lighting/Code/Shaders)
\
\
**Note 1**: _LightColor0, _WorldSpaceLightPos0 and _WorldSpaceCameraPos are built-in shader variables in Unity. See document [here](https://docs.unity3d.com/Manual/SL-UnityShaderVariables.html).
\
**Note 2**: reflect is a cg function that returns the reflection vector given an incidence vector i and a normal vector n. See document [here](https://developer.download.nvidia.com/cg/reflect.html).
\
**Note 3**: We used Tags{"LightMode" = "ForwardBase"} in code because we want to use Forward rendering. This rendering target is the default in Unity. See document [here](https://docs.unity3d.com/560/Documentation/Manual/SL-PassTags.html).### Experiment_008 Fresnel Effect
data:image/s3,"s3://crabby-images/e5a68/e5a682d7ab5a6d620c6b793076660d78f26c99d2" alt="Fresnel Effect"
data:image/s3,"s3://crabby-images/b4b8a/b4b8a164ccb6501180cff683af8c903a77cd9fe6" alt="Fresnel Shader"
[See Full Fresnel Effect Shader Codes](Assets/Experiments/Experiment8_Fresnel/Code/Shaders/Fresnel.shader)
\
**Note**: This effect only works properly on rounded objects due to its nature. It is a popular technique used in many games.### Experiment_009 Gradient Effect
data:image/s3,"s3://crabby-images/3729a/3729ac1b7583aa5699e3a8c904db48c641ca972b" alt="Gradient Effect"
data:image/s3,"s3://crabby-images/e72c6/e72c6b5ea62887e57c25e5010746f45866c0bf55" alt="Gradient Shader"
[See Full Gradient Effect Shader Codes](https://github.com/etopuz/ShaderNotes/blob/main/Assets/Experiments/Experiment9_Gradient/Code/Shaders/VertexGradient.shader)
### Experiment_010 UV Distortion Effect
data:image/s3,"s3://crabby-images/9ea52/9ea52f74291a935d7aec53fbe8385922bacd2482" alt="UV Distortion Effect"
data:image/s3,"s3://crabby-images/c1c09/c1c09f8f2259802f64f2aff4c34784fc3f5abb5c" alt="UV Distortion Shader"
[See Full UV Distortion Effect Shader Codes](https://github.com/etopuz/ShaderNotes/blob/main/Assets/Experiments/Experiment10_UV_Distortion/Code/Shaders/UV_Distortion.shader)