温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Unity shader实现高斯模糊效果

发布时间:2020-09-19 07:07:59 来源:脚本之家 阅读:453 作者:贪玩的孩纸时代 栏目:编程语言

本文实例为大家分享了Unity shader实现高斯模糊效果的具体代码,供大家参考,具体内容如下

正常图:

Unity shader实现高斯模糊效果

高斯模糊效果图:

Unity shader实现高斯模糊效果

shader代码:

Shader "Custom/GaoSiMoHu"
{
 Properties
 {
 _MainTex ("Texture", 2D) = "white" {}
 _BlurSize("Blur size",Float)=1.0
 }
 SubShader
 {
 ZTest Always
 cull off
 ZWrite off

 CGINCLUDE//这个可以使其他pass块都可以使用,而不用在两个pass里都写,减少了写的次数
 sampler2D _MainTex;
 half4 _MainTex_TexelSize;
 float _BlurSize;
 struct v2f{
  float4 pos:SV_POSITION;
  half2 uv[5]:TEXCOORD0;
 };
 fixed4 fragBlur(v2f i):SV_Target{
  float weight[3]={
  0.4026,
  0.2442,
  0.0545
  };

  fixed3 sum = tex2D(_MainTex,i.uv[0]).rgb * weight[0];

  for(int it = 1; it < 3; it++){
  sum += tex2D(_MainTex,i.uv[it]).rgb * weight[it];
  sum += tex2D(_MainTex,i.uv[2 * it]).rgb * weight[it];
  }

  return fixed4(sum,1.0);
 }
 ENDCG

 Pass{
  NAME "GAUSSIAN_BLUR_VERTICAL"//这个pass的唯一名字,可以在其他地方调用,usepass + 名字
  CGPROGRAM

  #pragma vertex vertlurVertical
  #pragma fragment fragBlur
  #include "UnityCG.cginc"
  
  v2f vertlurVertical(appdata_img v){
  v2f o;
  o.pos = UnityObjectToClipPos(v.vertex);
  half2 uv = v.texcoord;
  o.uv[0]=uv;
  o.uv[1]=uv + float2(0.0,_MainTex_TexelSize.y * 1.0) * _BlurSize;
  o.uv[2]=uv - float2(0.0,_MainTex_TexelSize.y * 1.0) * _BlurSize;
  o.uv[3]=uv + float2(0.0,_MainTex_TexelSize.y * 2.0) * _BlurSize;
  o.uv[4]=uv - float2(0.0,_MainTex_TexelSize.y * 2.0) * _BlurSize;

  return o;
  }
  ENDCG
 }

 Pass{
  NAME "GAUSSIAN_BLUR_HORIZONTAL"
  CGPROGRAM
  #pragma vertex vertlurHorizontal
  #pragma fragment fragBlur
  #include "UnityCG.cginc"

  v2f vertlurHorizontal(appdata_img v){
  v2f o;
  o.pos = UnityObjectToClipPos(v.vertex);
  half2 uv = v.texcoord;
  o.uv[0]=uv;
  o.uv[1]=uv + float2(0.0,_MainTex_TexelSize.x * 1.0) * _BlurSize;
  o.uv[2]=uv - float2(0.0,_MainTex_TexelSize.x * 1.0) * _BlurSize;
  o.uv[3]=uv + float2(0.0,_MainTex_TexelSize.x * 2.0) * _BlurSize;
  o.uv[4]=uv - float2(0.0,_MainTex_TexelSize.x * 2.0) * _BlurSize;

  return o;
  }
  ENDCG
 }
 }
}

调节_BlurSize即可看到效果

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持亿速云。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI