背景無限循環滾動效果如下示:
步驟如下:
- 導入背景圖片后,設置圖片的格式,如下圖;
2.圖片格式也可以設置是Texture格式,但是Wrap Mode 一定要是Repeat[重復發生];然后記得Apply一下。[解釋:Wrap mode :循環模式;換行模式;包裹模式;纏繞]
3.在Hierachy視圖中,新建2D Object-〉Sprite 或者一個Image,將之前設置好的精靈放入Texture。
4.在Project視圖鼠標右鍵新建一個Shader,命名隨意,然后在編輯器中修改Shader的代碼,如下:
Shader "Unlit/ScrollX" { Properties { _MainTex("Base Layer(RGB)", 2D) = "white" {} // 紋理 _ScrollX("Base layer Scroll Speed",Float) = 1.0 // 滾動速度 _Mutiplier("Layer Mutiplier", Float) = 1 //整體亮度 } SubShader { Tags{ "RenderType" = "Opaque" "Queue" = "Geometry" } LOD 100 Pass { Tags{ "LightMode" = "ForwardBase" } CGPROGRAM #pragma vertex vert #pragma fragment frag #include "UnityCG.cginc" struct a2v { float4 vertex : POSITION; float2 texcoord : TEXCOORD0; }; struct v2f { float4 pos : SV_POSITION; float2 uv : TEXCOORD0; }; sampler2D _MainTex; float4 _MainTex_ST; float _ScrollX; float _Mutiplier; v2f vert(a2v v) { v2f o; o.pos = UnityObjectToClipPos(v.vertex); o.uv.xy = TRANSFORM_TEX(v.texcoord, _MainTex) + frac(float2 (_ScrollX, 0.0) * _Time.y); return o; } fixed4 frag(v2f i) : SV_Target { fixed4 c = tex2D(_MainTex, i.uv.xy); c.rgb *= _Mutiplier; return c; } ENDCG } } FallBack "VertexLit" }
5.選中上一步建立好的Shader,鼠標右鍵新建一個Material[這是快捷創建方式,此時創建的Material所利用的Shader就是之前新建的shader],將需要設置滾動的背景圖放到材質球的紋理圖內,如下圖;
6.將材質球放到步驟2中創建的對象的Material中,運行即可。
當然,這是針對背景是規則圖形的,至於扇形面或者圓形,弧形的只能另外在考慮了。 另外第三步中,也是可以創建RawImage的,不過,就是圖片對比Image和Sprite會變的暗些。圖示,
這個並不是很清楚....