I explain how to render ‘scanline’, which looks like laser running on a surface, with Unity’s shader as shown below.
data:image/s3,"s3://crabby-images/c4328/c43289fa49907bfeae0b1ca2f7f6bc40c611a987" alt="2 - STYLY 空間スキャンライン表現"
Scanline in VR space
Samples
The sample available in GitHub:
The sample VR space
How to make scanline in VR space
I explain how to create a scanline in VR space.
Use the x coordinate as colour
Unity’s shader takes the coordinate, where the pixel of the object on the screen is located, as a parameter. For example, if you used the x coordinate as the colour of the object, it would look like the shown below.
data:image/s3,"s3://crabby-images/36e69/36e693e3be4f64be4ac4b98edd79ad05b34f72ed" alt="3_position_x - STYLY オブジェクトの色にx座標を適用"
Use the x coordinate as the colour of an object
The part where the X coordinate is smaller than 0.0 is coloured in black, where it is larger than 1.0 is coloured in white, and it’s coloured in grey in the case the X coordinate takes the value between 0.0 and 1.0. The code for Unity’s ShaderLab is shown below.
float x = IN.worldPos.x; // x coordinate o.Emission = x; // Use x as colour
Create scanline
When the condition, 0.0 ≦ the X coordinate ≦ 0.1, is satisfied, colour the object white. Otherwise, colour it black.
data:image/s3,"s3://crabby-images/e3b24/e3b24a91a3e63144895bfa35b6d9df6340deef2a" alt="5_x_between - STYLY 0≦x≦0.1の部分を白くする"
The part with the condition, 0≦x≦0.1, is coloured white.
The code for Unity’s ShaderLab is shown below.
float x = IN.worldPos.x; // x coordinate o.Emission = step(0.0, x) * step(x, 0.1); // Use x as colour
Add the trace effect
Add a trace to the scanline.
data:image/s3,"s3://crabby-images/c8033/c803349c9798c5e7a797b554980b6f77e30d4c0a" alt="6 - STYLY 光の残像を加える"
Add a trace to the scanline.
The code for Unity’s ShaderLab is shown below.
float x = IN.worldPos.x; // x coodinate float scanline = step(0.0, x) * step(x, 0.1); // scanline float trajectory = step(x, 0.0) * smoothstep(-4.0, 0.0, x); // trace of scanline o.Emission = scanline + trajectory * 0.3; // output line and trace
Create animation
Move Scanline
Create a series of scanlines and animate them.
data:image/s3,"s3://crabby-images/68af2/68af21cdb2ea821281675ab23feabad4619b94f9" alt="7_time - STYLY 線を時間で動かす"
Animate scanlines
The code for Unity’s ShaderLab is shown below.
float x = IN.worldPos.x; // x coordinate x -= _Time.z * 6.0; // subtract time from x coodinate x = fmod(x, 12.0); // generate the float between 0.0 and 12.0 float scanline = step(-0.1, x) * step(x, 0.0); // scanline float trajectory = step(x, 0.0) * smoothstep(-4.0, 0.0, x); // trace of scanline o.Emission = scanline + trajectory * 0.3; // output as colour
Colour the scanlines ~ completion
Finally, colour the scanlines. Now we finished rendering the scanlines in VR space.
data:image/s3,"s3://crabby-images/c3f33/c3f330726615abb54f262e31cd57f674bd99b8ae" alt="8 - STYLY 色を付ける"
Colour the scanlines
float x = IN.worldPos.x; // x coordinate x -= _Time.z * 6.0; // subtract time from x coodinate x = fmod(x, 12.0); // generate the float between 0.0 and 12.0 float scanline = step(-0.1, x) * step(x, 0.0); // scanline float trajectory = step(x, 0.0) * smoothstep(-4.0, 0.0, x); // trace of scanline o.Emission = scanline * _LineColor + trajectory * _TrajectoryColor; // output as colour
Create Scanline with Unity
Create a shader file
Select ‘Create > Shader > Unlit Shader’ to create a shader file.
data:image/s3,"s3://crabby-images/746be/746bec1c91e59903aac329e275e49b95e134a996" alt="9_create_shader - STYLY シェーダーファイルの作成"
Create a shader file
Name the shader file ‘WorldScanline’.
data:image/s3,"s3://crabby-images/52ce4/52ce4b9fa86accef4d2e79b93adebc0f33516cf7" alt="10_rename_shader - STYLY 作成したシェーダーファイル"
The shader file created.
Edit the shader file
Open the ‘WorldScanline’ shader, edit it as shown below.
Shader "STYLY/Examples/WorldScanline" { Properties{ _MainTex("Albedo (RGB)", 2D) = "black" {} _LineColor("Scan Line Color", Color) = (1,1,1,1) _TrajectoryColor("Scan Trajectory Color", Color) = (0.3, 0.3, 0.3, 1) _LineSpeed("Scan Line Speed", Float) = 1.0 _LineSize("Scan Line Size", Float) = 0.02 _TrajectorySize("Scan Trajectory Size", Float) = 1.0 _IntervalSec("Scan Interval", Float) = 2.0 [Space] [Space] _Glossiness("Smoothness", Range(0,1)) = 0.5 _Metallic("Metallic", Range(0,1)) = 0.0 } SubShader{ Tags { "RenderType" = "Opaque" } LOD 200 CGPROGRAM // Physically based Standard lighting model, and enable shadows on all light types #pragma surface surf Standard fullforwardshadows // Use shader model 3.0 target, to get nicer looking lighting #pragma target 3.0 sampler2D _MainTex; struct Input { float2 uv_MainTex; float3 worldPos; }; // line parameters fixed4 _LineColor; // color of line half _LineSpeed; // speed of line movement half _LineSize; // thickness of line fixed4 _TrajectoryColor; // color of trajectory half _TrajectorySize; // size of trajectory half _IntervalSec; // interval(sec) // other half _Glossiness; half _Metallic; void surf(Input IN, inout SurfaceOutputStandard o) { #define LINE_POS (_Time.w * _LineSpeed) #define INTERVAL (_IntervalSec * _LineSpeed) #define STEP_EDGE (_LineSize) #define STEP_EDGE_1 (STEP_EDGE + _TrajectorySize) #define STEP_EDGE_2 (STEP_EDGE) float scanline = step( fmod(abs(IN.worldPos.x - LINE_POS), INTERVAL), STEP_EDGE ); float trajectory = smoothstep( STEP_EDGE_1, STEP_EDGE_2, fmod(abs(IN.worldPos.x - LINE_POS), INTERVAL) ); fixed4 baseColor = tex2D(_MainTex, IN.uv_MainTex); o.Albedo = baseColor.rgb; o.Emission = _LineColor * scanline + _TrajectoryColor * trajectory; o.Metallic = _Metallic; o.Smoothness = _Glossiness; } ENDCG } FallBack "Diffuse" }
Create a material
Right-click the shader file and select ‘Create > Material’ to create a material.
data:image/s3,"s3://crabby-images/42653/426532f28806974786ff5893236b82ab7c3ba3c0" alt="11_create_material - STYLY マテリアル作成"
Create a material
data:image/s3,"s3://crabby-images/e2d25/e2d25ea8932365d3735702b2d9b0e651955a5435" alt="12_material - STYLY 作成したマテリアル"
The material created
Assign the material to a Cube
In the Hierarchy window, select ‘Create > 3D Object > Cube’ to create a Cube object.
data:image/s3,"s3://crabby-images/fdd84/fdd84fd4c5db8abfc049ff251aeebe1d6934c863" alt="13 - STYLY Cubeオブジェクトの作成"
Crate a Cube object.
data:image/s3,"s3://crabby-images/317e4/317e48135c140208f25b1a1c73fc884343b43975" alt="14_cube - STYLY 作成したCubeオブジェクト"
The Cube object created.
Drag the material created earlier into the Cube to assign the material to it.
data:image/s3,"s3://crabby-images/87199/87199729acb7dfde4386ac4c54dd8c50798b2cc8" alt="15_drag_and_drop - STYLY マテリアルを箱オブジェクトに適用"
Assign the material to the Cube object.
By playing the game with the scanline material applied, you can see the animated scanline on the Cube.
data:image/s3,"s3://crabby-images/a30b9/a30b9df7275bf1dafa2df827da3797a3e708a316" alt="16_cube - STYLY マテリアル適用結果"
The result – after applying the material
Create board
Create a ‘Sci-Fi’ board
I explain how to create a board full of Sci-Fi atmosphere.
data:image/s3,"s3://crabby-images/f0f12/f0f12801d3843765de28bfe24092bf62c5ec7402" alt="17 - STYLY 板状に並べた立方体に対するスキャンライン表現"
Render a scanline on the cubes arranged like a board.
Firstly, arrange a lot of Cubes to form the board-like shape as shown below.
data:image/s3,"s3://crabby-images/ed653/ed653ace717068563b9fd9f50b65008821c3de74" alt="16_cube_plane - STYLY 立方体を並べる"
Arrange Cubes
Set the parameters of the material as shown below and assign it to each cube.
data:image/s3,"s3://crabby-images/83900/83900019f3d31ed03184c7e5978e7be7bcf40c26" alt="17_material - STYLY マテリアルのパラメータ設定"
The setting for the material.
Once the material has been applied, the appearance would be like the shown below.
data:image/s3,"s3://crabby-images/f0f12/f0f12801d3843765de28bfe24092bf62c5ec7402" alt="17 - STYLY スキャンラインシェーダーを適用した結果"
The result – after applying the scanline shader
How to upload an asset from Unity to STYLY
Please refer to the article below to learn how to upload an asset from Unity to STYLY. https://styly.cc/ja/manual/unity-asset-uploader/