unity shader 案例 - 马赛克效果

效果图:
这里写图片描述

shader代码:

Shader "Unlit/MaSaiKe"
{
	Properties
	{
		_MainTex ("Texture", 2D) = "white" {}
		_TillSize("Till Size",Range(0.001,0.05))=0.005
	}
	SubShader
	{
		Pass{
			CGPROGRAM
			#pragma vertex vert
			#pragma fragment frag
			#include "UnityCG.cginc"

			struct a2v{
				float4 vertex:POSITION;
				float2 texcoord:TEXCOORD0;
			};
			struct v2f{
				float4 pos:POSITION;
				float2 uv:TEXCOORD0;
			};

			sampler2D _MainTex;
			float _TillSize;

			v2f vert(a2v v){
				v2f o;
				o.pos=mul(UNITY_MATRIX_MVP,v.vertex);
				o.uv=v.texcoord;
				return o;
			}

			fixed4 frag(v2f i):SV_Target{
				i.uv.x = floor(i.uv.x/_TillSize) * _TillSize;
				i.uv.y = floor(i.uv.y/_TillSize) * _TillSize;

				fixed4 col = tex2D(_MainTex,i.uv);
				return col;
			}

			ENDCG
		}			
	}
}

原理:将uv的坐标除以一个缩放值,然后向下(floor)或者向上(ceil)取值,在乘以缩放值,即可得到马赛克效果。

  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值