本文实例为大家分享了Unity3D Shader实现动态星空的具体代码,供大家参考,具体内容如下
Shader "Unlit/Test" { Properties { [Gamma][Header(CubeMap)]_MainColor("MainColor",COLOR)=(0.5,0.5,0.5,1) _Spec("Spec",Range(1,8))=1 [NoScaleOffset]_Tex("CubeMap",CUBE)="black"{} [Header(Rotation)][Toggle(_ENABLEROTATION_ON)]_EnableRotation("Enable Rotation",Float)=0 [IntRange]_Rotation("Rotation",Range(0,360))=0 _RotationSpeed("RotationSpeed",float)=1 [Header(Fog)][Toggle(_ENABLEFOG_ON)]_EnableFog("Enable Fog",float)=0 _FogHeight("FogHeight",Range(0,1))=1 _FogSmooth("FogSmooth",Range(0.01,1))=0.01 _FogHill("FogHill",Range(0,1))=0.5 } SubShader { Tags { "RenderType"="Background" "Queue"="Background" "IgnoreProjector"="True" "ForceNoShadowCasting"="True"} LOD 100 Cull Off ZWrite Off CGPROGRAM #include "UnityShaderVariables.cginc" #include "UnityCG.cginc" #pragma target 3.0 #pragma shader_feature _ENABLEROTATION_ON #pragma shader_feature _ENABLEFOG_ON #pragma surface surf Lint keepalpha noshadow noambient novertexlights nolightmap nodynlightmap nodirlightmap nofog nometa noforwardadd vertex:vertexRo struct Input { float3 worldPos; float3 vertextofrag; }; uniform float4 _MainColor; uniform float _Spec; uniform samplerCUBE _Tex; uniform half _Rotation; uniform half _RotationSpeed; uniform half _FogHeight; uniform half _FogSmooth; uniform half _FogHill; uniform half4 _Tex_HDR; half3 decode_HDR(half4 data) { return DecodeHDR(data,_Tex_HDR); } void vertexRo(inout appdata_full v,out Input o) { UNITY_INITIALIZE_OUTPUT(Input,o); float3 _worldPos=mul(unity_ObjectToWorld,v.vertex); float _lerpResult=lerp(1.0,(unity_OrthoParams.y/unity_OrthoParams.x),unity_OrthoParams.w); float3 _append=float3(_worldPos.x,_worldPos.y*_lerpResult,_worldPos.z); float3 _nor_append=normalize(_append); float _timeMove=_Time.y; float3 _timeMove1=float3(cos(radians(_Rotation+_timeMove*_RotationSpeed)),0,sin(radians(_Rotation+_timeMove*_RotationSpeed))*-1); float3 _timeMove2=float3(0,_lerpResult,0); float3 _timeMove3=float3(sin(radians(_Rotation+_timeMove*_RotationSpeed)),0,cos(radians(_Rotation+_timeMove*_RotationSpeed))); float3 _nor_worldPos=normalize(_worldPos); #ifdef _ENABLEROTATION_ON o.vertextofrag=mul(float3x3(_timeMove1,_timeMove2,_timeMove3),_nor_worldPos); #else o.vertextofrag=_nor_append; #endif } fixed4 LightingLint(SurfaceOutput s,float3 lightDir,float atten) { return fixed4(0,0,0,s.Alpha); } void surf(Input i,inout SurfaceOutput o) { half4 CUBEdata=texCUBE(_Tex,i.vertextofrag); half3 CUBEdataHDR=decode_HDR(CUBEdata); float4 CUBEColor=(float4(CUBEdataHDR,0))*_MainColor*_Spec*unity_ColorSpaceDouble; float3 _nor_worldPos=normalize(i.worldPos); float _lerpFog=lerp(saturate(pow(_nor_worldPos.y/_FogHeight,1-_FogSmooth)),0,_FogHill); float4 FinalColor=lerp(unity_FogColor,CUBEColor,_lerpFog); #ifdef _ENABLEFOG_ON o.Emission=FinalColor.rgb; #else o.Emission=CUBEColor.rgb; #endif o.Alpha=1; } ENDCG } }
Spec:亮度
Rotation:开始旋转角度,可以调节
RotationSpeed:旋转速度
Fog开头:雾化效果,可以看算法实现
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
本文向大家介绍Silverlight实现星星闪烁动画,包括了Silverlight实现星星闪烁动画的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了Silverlight实现星星闪烁动画展示的具体代码,供大家参考,具体内容如下 原理很简单,生成1000个圆,从随机数来布置它们的位置,通过动画来处理它们的透明度,动画时长也是随机生成。 1、创建图形数组并设置背景透明,渐变笔触,大小等,
本文向大家介绍JS实现星星海特效,包括了JS实现星星海特效的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了JS实现星星海特效的具体代码,供大家参考,具体内容如下 知识点 1.CSS使用@keyframes自定义动画,使用animation调用自定义动画 2.opacity 透明度。从 0.0 (完全透明)到 1.0(完全不透明) 3.CSS中transform 4.animation
本文向大家介绍canvas实现十二星座星空图,包括了canvas实现十二星座星空图的使用技巧和注意事项,需要的朋友参考一下 效果如下: 代码如下: 以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持呐喊教程!
本文向大家介绍vue实现评价星星功能,包括了vue实现评价星星功能的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了vue实现评价星星的具体代码,供大家参考,具体内容如下 代码: 关于vue.js组件的教程,请大家点击专题vue.js组件学习教程进行学习。 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教程。
本文向大家介绍js实现漫天星星效果,包括了js实现漫天星星效果的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了漫天小星星效果的实现代码,供大家参考,具体内容如下 效果图: 实现代码: 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教程。
本文向大家介绍js实现动态时钟,包括了js实现动态时钟的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了js实现动态时钟的具体代码,供大家参考,具体内容如下 示例展示: 更多JavaScript时钟特效点击查看:JavaScript时钟特效专题 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教程。