Unityのシェーダーを利用して、以下のような光のラインが走る表現(スキャンライン)を作る方法を解説します。
data:image/s3,"s3://crabby-images/c4328/c43289fa49907bfeae0b1ca2f7f6bc40c611a987" alt="2 - STYLY 空間スキャンライン表現"
空間スキャンライン表現
サンプル
GitHubサンプル
サンプル空間
空間スキャンラインの作り方
ここでは、空間スキャンラインを作る方法を解説いたします。
x座標を色として使う
Unityのシェーダーでは、画面に映っているオブジェクトの画素が空間中のどの位置にあるかという、座標をとることができます。 例えば、空間のx座標をオブジェクトの色として使うと以下のような見た目になります。
data:image/s3,"s3://crabby-images/36e69/36e693e3be4f64be4ac4b98edd79ad05b34f72ed" alt="3_position_x - STYLY オブジェクトの色にx座標を適用"
オブジェクトの色にx座標を適用
x座標が0.0より小さい部分は黒色に、 1.0より大きい部分は白色に、0.0 ~ 1.0の部分は灰色になります。 UnityのShaderLabで書いた場合は以下になります。
float x = IN.worldPos.x; // x座標 o.Emission = x; // 色として出力
光の線を作る
0.0 ≦ x座標 ≦ 0.1を満たすときはオブジェクトの色を白く、それ以外は黒くします。
data:image/s3,"s3://crabby-images/e3b24/e3b24a91a3e63144895bfa35b6d9df6340deef2a" alt="5_x_between - STYLY 0≦x≦0.1の部分を白くする"
0≦x≦0.1の部分を白くする
UnityのShaderLabで書いた場合は以下になります
float x = IN.worldPos.x; // x座標 o.Emission = step(0.0, x) * step(x, 0.1); // 色として出力
光の残像を加える
これに光の残像を加えます。
data:image/s3,"s3://crabby-images/c8033/c803349c9798c5e7a797b554980b6f77e30d4c0a" alt="6 - STYLY 光の残像を加える"
光の残像を加える
UnityのShaderLabで書いた場合
float x = IN.worldPos.x; // x座標 float scanline = step(0.0, x) * step(x, 0.1); // 光の線 float trajectory = step(x, 0.0) * smoothstep(-4.0, 0.0, x); // 光の残像 o.Emission = scanline + trajectory * 0.3; // 色として出力
アニメーションを作る
光の線を動かす
光の線の繰り返しを作り、これを時間で動かします。
data:image/s3,"s3://crabby-images/68af2/68af21cdb2ea821281675ab23feabad4619b94f9" alt="7_time - STYLY 線を時間で動かす"
線を時間で動かす
UnityのShaderLabで書いた場合
float x = IN.worldPos.x; // x座標 x -= _Time.z * 6.0; // x座標から時間をマイナス x = fmod(x, 12.0); // x座標を0.0 ~ 12.0の間で繰り返す float scanline = step(-0.1, x) * step(x, 0.0); // 光の線 float trajectory = step(x, 0.0) * smoothstep(-4.0, 0.0, x); // 光の残像 o.Emission = scanline + trajectory * 0.3; // 色として出力
色をつけて完成
最後に色を乗算することで今回の空間スキャンライン表現の完成です。
data:image/s3,"s3://crabby-images/c3f33/c3f330726615abb54f262e31cd57f674bd99b8ae" alt="8 - STYLY 色を付ける"
色を付ける
float x = IN.worldPos.x; // x座標 x -= _Time.z * 6.0; // 時間をマイナス x = fmod(x, 12.0); // x座標を0.0 ~ 12.0の間で繰り返す float scanline = step(-0.1, x) * step(x, 0.0); // 光の線 float trajectory = step(x, 0.0) * smoothstep(-4.0, 0.0, x); // 光の残像 o.Emission = scanline * _LineColor + trajectory * _TrajectoryColor; // 色として出力
実際にUnityで作る
シェーダーファイルの作成
Create/Shader/Unlit Shaderを選択し、シェーダーファイルを作成します。
data:image/s3,"s3://crabby-images/746be/746bec1c91e59903aac329e275e49b95e134a996" alt="9_create_shader - STYLY シェーダーファイルの作成"
シェーダーファイルの作成
シェーダーファイル名はWorldScanlineとします。
data:image/s3,"s3://crabby-images/52ce4/52ce4b9fa86accef4d2e79b93adebc0f33516cf7" alt="10_rename_shader - STYLY 作成したシェーダーファイル"
作成したシェーダーファイル
シェーダーの編集
WorldScanlineシェーダーを開き、中身を以下のように書き換えます。
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/Material を選択してマテリアルを作成します。
data:image/s3,"s3://crabby-images/42653/426532f28806974786ff5893236b82ab7c3ba3c0" alt="11_create_material - STYLY マテリアル作成"
マテリアル作成
data:image/s3,"s3://crabby-images/e2d25/e2d25ea8932365d3735702b2d9b0e651955a5435" alt="12_material - STYLY 作成したマテリアル"
作成したマテリアル
マテリアルを箱に張り付ける
HierarhchyのCreate/Cubeを選択し、Cube(箱)を作成します。
data:image/s3,"s3://crabby-images/fdd84/fdd84fd4c5db8abfc049ff251aeebe1d6934c863" alt="13 - STYLY Cubeオブジェクトの作成"
Cubeオブジェクトの作成
data:image/s3,"s3://crabby-images/317e4/317e48135c140208f25b1a1c73fc884343b43975" alt="14_cube - STYLY 作成したCubeオブジェクト"
作成したCubeオブジェクト
作成したCubeオブジェクトに先ほど作成したマテリアルをドラッグ&ドロップし、Cubeにマテリアルをくっつけます。
data:image/s3,"s3://crabby-images/87199/87199729acb7dfde4386ac4c54dd8c50798b2cc8" alt="15_drag_and_drop - STYLY マテリアルを箱オブジェクトに適用"
マテリアルを箱オブジェクトに適用
スキャンラインマテリアルを適用した状態でゲームを再生すると、以下のようにラインが流れる箱になります。
data:image/s3,"s3://crabby-images/a30b9/a30b9df7275bf1dafa2df827da3797a3e708a316" alt="16_cube - STYLY マテリアル適用結果"
マテリアル適用結果
板を作る
SciFiな感じの板を作る
以下のようなSciFiな雰囲気ただよう板の作り方を解説します。
data:image/s3,"s3://crabby-images/f0f12/f0f12801d3843765de28bfe24092bf62c5ec7402" alt="17 - STYLY 板状に並べた立方体に対するスキャンライン表現"
板状に並べた立方体に対するスキャンライン表現
まずは、Cubeをたくさん並べて以下のような板を作ります。
data:image/s3,"s3://crabby-images/ed653/ed653ace717068563b9fd9f50b65008821c3de74" alt="16_cube_plane - STYLY 立方体を並べる"
立方体を並べる
マテリアルのパラメータを以下のように設定し、それぞれのCubeに適用します。
data:image/s3,"s3://crabby-images/83900/83900019f3d31ed03184c7e5978e7be7bcf40c26" alt="17_material - STYLY マテリアルのパラメータ設定"
マテリアルのパラメータ設定
マテリアルを適用すると以下のような見た目になります。
data:image/s3,"s3://crabby-images/f0f12/f0f12801d3843765de28bfe24092bf62c5ec7402" alt="17 - STYLY スキャンラインシェーダーを適用した結果"
スキャンラインシェーダーを適用した結果
UnityからSTYLYにアセットをアップロードする方法
UnityからSTYLYへデータをアップロードする方法については下記リンクの記事をご覧ください。 https://styly.cc/ja/manual/unity-asset-uploader/