[Shader]Unity裁剪四方形Image为圆形

摘要:
创建着色器和着色器。请从官方网站下载内置着色器(UI)效果:想法:切割成圆形,然后移除大于圆形半径的像素。简单代码:定义圆半径_半径(“radius”,范围(0-0.5))=0.5frag元素处理float2或=float2(0.5,0.5)-uv//如果(长度(nor)˃_半径)//计算出的圆心到uv坐标的距离大于半径,则圆心为0.5,0.5

<1>新建材质球和shader,shader请在官方下载内置shader(UI)

     效果:[Shader]Unity裁剪四方形Image为圆形第1张[Shader]Unity裁剪四方形Image为圆形第2张

     思路:

              裁剪成圆,那就剔除大于圆半径的像素,很鸡儿简单

    代码:

             定义圆形半径 _Radius("半径",Range(0-0.5))=0.5

             frag片元处理

                   float2 nor = float2(0.5,0.5)-uv;//圆心在0.5,0.5

                   if(length(nor)>_Radius)//计算圆心到UV坐标的距离 大于半径剔除

                         col.a = 0;

                   clip(col.a-0.01);//剔除alpha小于0

源码:

      

// Unity built-in shader source. Copyright (c) 2016 Unity Technologies. MIT license (see license.txt)

Shader "Tang/imgCut"
{
    Properties
    {
        [PerRendererData] _MainTex("Sprite Texture", 2D) = "white" {}
    _Color("Tint", Color) = (1,1,1,1)

        _StencilComp("Stencil Comparison", Float) = 8
        _Stencil("Stencil ID", Float) = 0
        _StencilOp("Stencil Operation", Float) = 0
        _StencilWriteMask("Stencil Write Mask", Float) = 255
        _StencilReadMask("Stencil Read Mask", Float) = 255
        _ColorMask("Color Mask", Float) = 15

        //my member
        _Radius("圆半径",Range(0,0.5)) = 0.3

        [Toggle(UNITY_UI_ALPHACLIP)] _UseUIAlphaClip("Use Alpha Clip", Float) = 0
    }

        SubShader
    {
        Tags
    {
        "Queue" = "Transparent"
        "IgnoreProjector" = "True"
        "RenderType" = "Transparent"
        "PreviewType" = "Plane"
        "CanUseSpriteAtlas" = "True"
    }

        Stencil
    {
        Ref[_Stencil]
        Comp[_StencilComp]
        Pass[_StencilOp]
        ReadMask[_StencilReadMask]
        WriteMask[_StencilWriteMask]
    }

        Cull Off
        Lighting Off
        ZWrite Off
        ZTest[unity_GUIZTestMode]
        Blend SrcAlpha OneMinusSrcAlpha
        ColorMask[_ColorMask]

        Pass
    {
        Name "Default"
        CGPROGRAM
        #pragma vertex vert
        #pragma fragment frag
        #pragma target 2.0

        #include "UnityCG.cginc"
        #include "UnityUI.cginc"

        #pragma multi_compile __ UNITY_UI_ALPHACLIP
        #define PI 3.1415926

        struct appdata_t
    {
        float4 vertex : POSITION;
        float4 color : COLOR;
        float2 texcoord : TEXCOORD0;
        UNITY_VERTEX_INPUT_INSTANCE_ID
    };

    struct v2f
    {
        float4 vertex : SV_POSITION;
        fixed4 color : COLOR;
        float2 texcoord : TEXCOORD0;
        float4 worldPosition : TEXCOORD1;
        UNITY_VERTEX_OUTPUT_STEREO
    };

    fixed4 _Color;
    fixed4 _TextureSampleAdd;
    float4 _ClipRect;
    float _Radius;

    v2f vert(appdata_t IN)
    {
        v2f OUT;
        UNITY_SETUP_INSTANCE_ID(IN);
        UNITY_INITIALIZE_VERTEX_OUTPUT_STEREO(OUT);
        OUT.worldPosition = IN.vertex;
        OUT.vertex = UnityObjectToClipPos(OUT.worldPosition);

        OUT.texcoord = IN.texcoord;

        OUT.color = IN.color * _Color;
        return OUT;
    }

    sampler2D _MainTex;

    fixed4 frag(v2f IN) : SV_Target
    {
float2 uv = IN.texcoord.xy;
        float4 col = IN.color;

        float2 nor =float2(0.5,0.5)-uv;
        if (length(nor)>_Radius)
            col.a = 0;
        
clip(col.w-0.01);
        half4 color = (tex2D(_MainTex,uv) + _TextureSampleAdd) * col;
        color.a *= UnityGet2DClipping(IN.worldPosition.xy, _ClipRect);

#ifdef UNITY_UI_ALPHACLIP
         clip(color.a - 0.001);
#endif

         return color;
     }
         ENDCG
     }
    }
}

              

免责声明:文章转载自《[Shader]Unity裁剪四方形Image为圆形》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇Django Admin Cookbook-9如何启用对计算字段的排序QAC报告中的STCYC下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

记录一款Unity VR视频播放器插件的开发

效果图## 先上一个效果图: 背景 公司最近在做VR直播平台,VR开发我们用到了Unity,而在Unity中播放视频就需要一款视频插件,我们调研了几个视频插件,记录两个,如下: Unity视频插件调研 网上搜了搜,最流行的有以下两款Unity插件: AVPro 这个在Unity商店售价150$,最新release版本为1.6.15,功能包括: Power...

在Unity中实现画图/字帖功能

转载:https://blog.csdn.net/Patrick_Boom/article/details/107180717 前段时间总是加班,也没啥心情和精力去研究新东西,总结一下自己之前做的字帖的功能 先上效果图: 文章分为几部分: (一) 画图板实现原理 (二) 画图具体实现过程中的核心点 (三) 在画图板的基础上 演变为字帖的思路 · 画...

Unity3d之音效播放和调用手机震动

http://blog.csdn.net/sunshine_1984/article/details/12943979 今天研究了下Unity3d音效播放相关内容,整理下实现细节。 1,添加音效文件到Assets/Resources目录,我这里添加到Assets/Resources/audio目录了。 2,新建C# Script命名为audio 3,编写a...

【Unity】Shader Forge插件入门教程

【Unity】Shader Forge插件入门教程 说明:现在Unity2018都提供了官方的ShaderGraph,建议学新不学旧,学官方不学第三方。——2018.6.21 一.安装说明 ~下载 Unity Asset Store购买并下载https://www.assetstore.unity3d.com/en/#!/content/14147 其...

《unity项目》打包安卓APK时Build Setting中的三种Build System

Internal(Default):Unity内置,仅需Android SDK支持。不能导出工程,适用于仅适用Unity开发的工程 apk。 Gradle(New):使用Gradle进行构建,需要Android SDK与Gradle支持,可以导出Android Studio工程 apk ; 选这个才能勾选下面的Export Project,适用于Uni...

Unity3d—GUI能量条

1、打开Unity编辑器。2、在脚本文件夹中添加C#脚本,我的是添加了skill_01这个脚本。(要自己设置文件夹,方便管理,不然文件添乱不方便管理) 3、注意,脚本的名字一旦确定就不要去改动,因为一个脚本的名字就是一个类名,改动会容易出现程序的不正确。4、编写对应的脚本代码1 usingSystem.Collections; 2 usingSystem....