unity3d UGUI教程之-UGUI 實現刮刮卡橡皮擦
有個朋友問我怎麼在Unity中使用 UGUI 實現刮刮卡功能,之前確實沒有做過,但我想了下,應該使用 Shader 可以達到。於是花了點時間實現了下改功能。看下最終效果圖
下面說下實現方式。
這裡我主要使用到一個指令碼和一個Shader。
Shader "Unlit/Transparent Colored Eraser"
{
Properties
{
_MainTex ("Base (RGB), Alpha (A)", 2D) = "white" {}
_RendTex ("Base (RGB), Alpha (A)", 2D) = "white" {}
}
SubShader
{
LOD 200
Tags
{
"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 AmbientAndDiffuse
CGPROGRAM
#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 = mul(UNITY_MATRIX_MVP, 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;
using System.Collections;
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);
}
}
自己PS一張遮擋圖吧,我隨便P的。
新建一個材質球,給他選擇上面的Shader,可以不需給它預設紋理,等下在指令碼里賦予。 掛在UGUI的Image上,指令碼也掛在Image上面,RawImage和Image隨便吧,我沒試過。大家可以試下。
相關文章
- STM32 + RTThread + UGUIthreadUGUI
- 將Particle轉成UGUIUGUI
- [Unity] UGUI優化 - 知識點UnityUGUI優化
- UGUI_關卡選項介面UGUI
- UGUI原始碼解析(Toggle和ToggleGroup)UGUI原始碼
- 使用Shader進行UGUI的優化UGUI優化
- 【Unity】UGUI模擬NGUI的UISprite-->LImageUnityUGUINGUI
- NGUI和UGUI改變字型顏色的寫法NGUIUGUI
- Unity 之 UGUI Scroll Rect滾動矩形元件詳解UnityUGUI元件
- [ToneTuneToolkit][023]UGUI的去色,使UI元素變為灰色UGUI
- 在Unity中用UGUI製作可輸入下拉框UnityUGUI
- 【UGUI原始碼分析】Unity遮罩之Mask詳細解讀UGUI原始碼Unity遮罩
- 【unity小技巧】實現FPS武器的瞄準放大效果(UGUI實現反向遮罩,全屏遮擋,區域性鏤空效果)UnityUGUI遮罩
- 如何基於專案人力和管線方案選擇FGUI和UGUIUGUI
- 【UGUI原始碼分析】Unity遮罩之RectMask2D詳細解讀UGUI原始碼Unity遮罩
- 【Unity】【UGUI】對映3D座標到UI上(血條、人物狀態)UnityUGUI3D
- ugui 縮放圖片使圖片的四個角和四邊保持原樣UGUI
- Html5實現移動端、PC端 刮刮卡效果HTML
- 基於canvas剪輯區域功能實現橡皮擦效果Canvas
- H5活動刮刮卡功能的實現與注意事項H5
- 原生實現C#和Lua相互呼叫-Unity3D可用C#Unity3D
- Unity3D開發入門教程(四)——用Lua實現元件Unity3D元件
- Spring Security系列教程之實現CAS單點登入上篇-概述Spring
- 前端教程之Intro.js輕鬆實現新手引導效果前端JS
- kafka實戰教學Kafka
- 基於刮刮卡Vue元件釋出一個NPM包Vue元件NPM
- 手把手教系列之移動平均濾波器實現
- CCleaner for Windows的命令列引數, 隱私橡皮擦PrivacyEraser.exe命令列提供了一個命令列介面,讓您在沒有通常的隱私橡皮擦圖形使用者介面的情況下使用隱私橡皮擦的功能。Windows命令列
- 好程式設計師web前端教程之JS繼承實現方式解析程式設計師Web前端JS繼承
- Java培訓教程之使用Jsoup實現簡單的爬蟲技術JavaJS爬蟲
- 長沙Java培訓系列教程之實現CAS單點登入上篇Java
- Unity3d 初探Unity3D
- unity3d碰撞Unity3D
- unity3d sqliteUnity3DSQLite
- MO_or掰泡饃式教學實現多資料來源
- 微信小程式教學第二章(含視訊):小程式中級實戰教程之預備篇 – 提取util公用方法微信小程式
- unity3D進階Unity3D
- 線上教育平臺開發中,教學白板是如何實現的
- Unity3D熱更新之LuaFramework篇[06]--Lua中是怎麼實現指令碼生命週期的Unity3DFramework指令碼