3
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

シンプルな縦グラデーションカラーのSkyboxシェーダ

Last updated at Posted at 2022-03-05

スクリーンショット 2022-03-06 013652.png
ふと「光源位置やら、大域照明やら、そんな事どうでも良いから、指定した色を線形にグラデーションしてくれるようなSkyboxが欲しい!」と思ったので作ってみました。

シェーダ

という事でシェーダコードです。

GradationSkybox.shader
Shader "ScreenPocket/Skybox/Gradation"
{
    Properties
    {
        _TopColor ("Top", Color) = (1, 0, 0, 1)
        _MiddleColor ("Middle", Color) = (0, 1, 0, 1)
        _BottomColor ("Bottom", Color) = (0, 0, 1, 1)
        _Length ("Length", Float) = 1
    }

    SubShader
    {
        Tags { "Queue"="Background" "RenderType"="Background" "PreviewType"="Skybox" }
        Cull Off ZWrite Off

        Pass {

            CGPROGRAM
            #pragma vertex vert
            #pragma fragment frag

            #include "UnityCG.cginc"

            uniform half3 _TopColor;
            uniform half3 _MiddleColor;
            uniform half3 _BottomColor;
            uniform half _Length;

            struct appdata_t
            {
                float4 vertex : POSITION;
                UNITY_VERTEX_INPUT_INSTANCE_ID
            };

            struct v2f
            {
                float4  pos            : SV_POSITION;
                float3  color          : TEXCOORD0;
                UNITY_VERTEX_OUTPUT_STEREO
            };

            v2f vert (appdata_t v)
            {
                v2f OUT;
                UNITY_SETUP_INSTANCE_ID(v);
                UNITY_INITIALIZE_VERTEX_OUTPUT_STEREO(OUT);
                
                OUT.pos = UnityObjectToClipPos(v.vertex);
                OUT.color = lerp(lerp(_MiddleColor,_TopColor,saturate(v.vertex.y/_Length)),_BottomColor, saturate((-v.vertex.y)/_Length));
                return OUT;
            }
            
            half4 frag (v2f IN) : SV_Target
            {
                return half4(IN.color,1);
            }
            ENDCG
        }
    }
Fallback Off
}

ポイントは下記

  • MVP変換前のv.vertex.yは-1~0~1の球になっているので、その座標位置をそのまま使って線形補間(lerp())しました。
  • Topが天球の一番上、Middleが水平線、Bottomが天球の一番下の色となります。
  • 色の補間はFragmentシェーダでやろうかと思いましたが、頂点シェーダで行っても十分滑らかだったので、負荷を抑えるために頂点シェーダ側で行いました。
  • グラデーションの具合をある程度調整したいので、Lengthの値でグラデ幅を調整できるようにしています

使い方

  1. 適当にシェーダを作る
  2. 上記のコードをコピペ
  3. 適当なマテリアルを作って、ScreenPocket/Skybox/Gradation シェーダを設定
  4. Top、Middle、Bottomの色を確定し、Lengthでグラデーション幅を決める
  5. Window/Rendering/LightingでLightingパネルを開き、Environmentタブを選択し、Skybox Materialに作ったマテリアルを設定する
  6. カメラのInspectorからEnvironment/Background TypeをSkyboxにする

で確認できるかと思います。

ちゃんと上を見ると赤に
スクリーンショット 2022-03-06 020124.png
下を見ると青になっています
スクリーンショット 2022-03-06 020156.png

終わりに

厳密なSkyboxは必要ないけど、単色で塗りつぶすのは面白くないなぁ…という時や、水中の表現に使えるかと思います。
カーブを線形以外に対応したり、Gradientで自由な色テーブルに対応出来たりすると汎用性が上がりそうですね。

↓水中の一例
スクリーンショット 2022-03-06 020851.png

3
2
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
3
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?