需要一个Shader和一个CS脚本:

// Upgrade NOTE: replaced 'mul(UNITY_MATRIX_MVP,*)' with 'UnityObjectToClipPos(*)'Shader "Custom/Transparent Colored Eraser"
{
Properties
{
_MainTex ("Base (RGB), Alpha (A)", 2D) = "white" {}
_RendTex ("Base (RGB), Alpha (A)", 2D) = "white" {}
}SubShader
{
LOD 200Tags
{
"Queue" = "Transparent"
"IgnoreProjector" = "True"
"RenderType" = "Transparent"
}Pass
{
Cull Off
Lighting Off
ZWrite Off
Fog { Mode Off }
Offset -1, -1
ColorMask RGB
AlphaTest Greater .01
Blend SrcAlpha OneMinusSrcAlpha
ColorMaterial AmbientAndDiffuseCGPROGRAM
#pragma vertex vert
#pragma fragment frag
#include "UnityCG.cginc"sampler2D _MainTex;
float4 _MainTex_ST;
sampler2D _RendTex;struct appdata_t
{
float4 vertex : POSITION;
half4 color : COLOR;
float2 texcoord : TEXCOORD0;
};struct v2f
{
float4 vertex : POSITION;
half4 color : COLOR;
float2 texcoord : TEXCOORD0;
};v2f vert (appdata_t v)
{
v2f o;
o.vertex = UnityObjectToClipPos(v.vertex);
o.color = v.color;
o.texcoord = v.texcoord;
return o;
}half4 frag (v2f IN) : COLOR
{
// Sample the texture
half4 col = tex2D(_MainTex, IN.texcoord) * IN.color;
half4 rnd = tex2D(_RendTex, IN.texcoord) * IN.color;
col.a =  rnd.a;
return col;
}
ENDCG
}
}
}
using UnityEngine;
using UnityEngine.UI;
using UnityEngine.EventSystems;public class UIEraserTexture : MonoBehaviour, IPointerDownHandler, IPointerUpHandler
{public RawImage image;public int brushScale = 4;Texture2D texRender;RectTransform mRectTransform;Canvas canvas;void Awake(){mRectTransform = GetComponent<RectTransform>();canvas = GameObject.Find("Canvas").GetComponent<Canvas>();}void Start(){texRender = new Texture2D(image.mainTexture.width, image.mainTexture.height, TextureFormat.ARGB32, true);Reset();}bool isMove = false;public void OnPointerDown(PointerEventData data){//Debug.Log("OnPointerDown..." + data.position);start = ConvertSceneToUI(data.position);isMove = true;}public void OnPointerUp(PointerEventData data){isMove = false;//Debug.Log("OnPointerUp..." + data.position);OnMouseMove(data.position);start = Vector2.zero;}void Update(){if (isMove){OnMouseMove(Input.mousePosition);}}Vector2 start = Vector2.zero;Vector2 end = Vector2.zero;Vector2 ConvertSceneToUI(Vector3 posi){Vector2 postion;if (RectTransformUtility.ScreenPointToLocalPointInRectangle(mRectTransform, posi, canvas.worldCamera, out postion)){return postion;}return Vector2.zero;}void OnMouseMove(Vector2 position){end = ConvertSceneToUI(position);Draw(new Rect(end.x + texRender.width / 2, end.y + texRender.height / 2, brushScale, brushScale));if (start.Equals(Vector2.zero)){return;}Rect disract = new Rect((start + end).x / 2 + texRender.width / 2, (start + end).y / 2 + texRender.height / 2, Mathf.Abs(end.x - start.x), Mathf.Abs(end.y - start.y));for (int x = (int)disract.xMin; x < (int)disract.xMax; x++){for (int y = (int)disract.yMin; y < (int)disract.yMax; y++){Draw(new Rect(x, y, brushScale, brushScale));}}start = end;}void Reset(){for (int i = 0; i < texRender.width; i++){for (int j = 0; j < texRender.height; j++){Color color = texRender.GetPixel(i, j);color.a = 1;texRender.SetPixel(i, j, color);}}texRender.Apply();image.material.SetTexture("_RendTex", texRender);}void Draw(Rect rect){for (int x = (int)rect.xMin; x < (int)rect.xMax; x++){for (int y = (int)rect.yMin; y < (int)rect.yMax; y++){if (x < 0 || x > texRender.width || y < 0 || y > texRender.height){return;}Color color = texRender.GetPixel(x, y);color.a = 0;texRender.SetPixel(x, y, color);}}texRender.Apply();image.material.SetTexture("_RendTex", texRender);}
}

Unity中实现刮奖效果相关推荐

  1. canvas刮奖效果

    上次写刮奖效果都一年前了,那时候还是百度找的源码给改的,自己其实也是迷迷糊糊的,这次因为让妹子写,然后想着自己也重新整理下. <!DOCTYPE html> <html> &l ...

  2. HTML5实现刮奖效果

    原文:HTML5实现刮奖效果 要实现刮奖效果,最重要的是要找到一种方法:当刮开上层的涂层是就能看到下层的结果.而HTML5的canvas API中有一个属性globalCompositeOperati ...

  3. 刮刮奖效果的简单实现

    刮刮奖效果的简单实现 无意中看到个刮刮奖的效果,觉得很有意思.就想自己也做一个,怎样用html5及javascript实现呢,回忆以前 做报表的时候,用过html5 canvas元素.心里就有思路了. ...

  4. html5刮奖效果,HTML5 Canvas实战之刮奖效果

    近年来由于移动设备对HTML5的较好支持,经常有活动用刮奖的效果,最近也在看H5方面的内容,就自己实现了一个,现分享出来跟大家交流. 1.效果 2.原理 原理很简单,就是在刮奖区添加两个canvas, ...

  5. Android刮奖效果

    背景知识 使用Xfermode中的PorterDuffXfermode实现我们的刮奖效果 PorterDuffXfermode 这是一个非常强大的转换模式,使用它,可以使用图像合成的16条Porter ...

  6. 入门canvas - 通过刮奖效果来学习

    一 .前言 一直在做PC端的前端开发,从互联网到行业软件.最近发现移动端已经成为前端必备技能了,真是不能停止学习.HTML5新增的一些东西,canvas是用的比较多也比较复杂的一个,简单的入门了一下, ...

  7. 简单入门canvas - 通过刮奖效果来学习

    一 .前言 一直在做PC端的前端开发,从互联网到行业软件.最近发现移动端已经成为前端必备技能了,真是不能停止学习.HTML5新增的一些东西,canvas是用的比较多也比较复杂的一个,简单的入门了一下, ...

  8. android实现一个橡皮檫效果的自定义View,实现刮奖效果

    最近学习自定义View然后做了这么个东西,感觉挺有趣. 简单的就不写了就是一个Activity然后在其中使用,就像TextView一样,只需要设置宽高就行了wrap_content和match_par ...

  9. html5刮奖效果,HTML5+Canvas实战之刮奖效果

    项目描述 HTML5+Canvas实战之刮奖效果,实现网页上刮奖,可以用作验证码: 可以在移动设备上和PC端网页(浏览器要支持canvas)上运行 ##使用说明 var lottery = new L ...

最新文章

  1. SUID和SGID位简介
  2. mysql中存储过程另存为_转: MySQL中的存储过程
  3. 为什么可能导致睡眠的函数都不能在中断上下文中使用呢?【转】
  4. wxPython各个布局的简单案例
  5. MVP:界面与业务逻辑分离在Winform中的应用
  6. 介绍Java中的内存泄漏
  7. java 类 加载 初始化_java类的加载与初始化
  8. Linux——Vi/Vim如何消除搜索后的关键字高亮
  9. Win2003远程桌面报错:RPC错误 解决办法
  10. Android Studio打包Android Library为jar方案
  11. python pyecharts map不显示_pyecharts 地图不显示问题
  12. DB2 SQL性能调优秘笈
  13. hdu 6088 Rikka with Rock-paper-scissors (2017 多校第五场 1004) 【组合数学 + 数论 + 模意义下的FFT】...
  14. Linux 之 NTP 服务 服务器
  15. 用虚表和虚表指针实现动态绑定
  16. 武大计算机专硕和学硕,专硕与学硕,到底有什么区别?
  17. 替罪羊树[Scapegoat Tree]
  18. eclipse安装red5插件,创建red5项目
  19. 多模光纤与单模光纤熔接及用哪种光模块的问题。
  20. Phaser3 点击事件

热门文章

  1. Swift 页面跳转
  2. 国内AI绘画软件“数画”的相机溯源码功能太强大,彻底消灭盗图
  3. seo软文广告文章怎么写(如何写高质量软文广告文章)
  4. Outlook如何将相同讨论的邮件放到一起
  5. DLookup使用详解
  6. 自己制作“EleksTubeIPS创意复古RGB拟辉光管时钟”分享《二》---(持续更新2021-12-22)
  7. 【Ubuntu】Ubuntu查找文件的命令
  8. 百度云下载神器 速盘SpeedPan v1.9.7
  9. [数据结构]栈、队列和散列表
  10. android新的信息提示框,信息提示框Toast