原理:实现两张图片的融合,即将其中一张图片的的像素点放到另外一张图片上。
1、需要两张图片,一张墙壁的图片,一张弹痕的图片,要实现用鼠标点击墙壁图片时,以点击的位置为中心点,将弹痕图片的像素点设置在墙壁图片上。
data:image/s3,"s3://crabby-images/3274b/3274b092127e5625263aff741fc0d11b74326b1d" alt=""
data:image/s3,"s3://crabby-images/49657/49657aa81fcf39bbfeb4c4d53e72416daf23b7ea" alt=""
2、创建Unity工程,这两张图片拖到工程后,做以下修改设置
①需要设置这两张图片的TextureType为Advanced;
②这两张图片都要勾选上Read/WriteEnable属性,允许图片进行像素编辑;
③设置弹痕图片的MaxSize为64,Format格式为:RGBA32 bit;
④设置wall图片的MaxSize为2048,Format格式为RGBA32 bit;
data:image/s3,"s3://crabby-images/93a92/93a92b525c2b6e25efea77a029b84281cacb8b78" alt=""
data:image/s3,"s3://crabby-images/fd885/fd8852fbd985a44e4e0b16b6538dce66b89fd796" alt=""
3、创建场景,直接将墙壁图片托放在Plane上即可
data:image/s3,"s3://crabby-images/94023/94023faaec1eeebb13dd08574a0666432154f1a9" alt=""
4、创建脚本PlaneScr,在脚本中实现使用鼠标点击墙壁时能够生成相应的弹痕,将脚本挂载在Plane上
1、在脚本中添加如下字段
data:image/s3,"s3://crabby-images/cd51c/cd51c8ac31384a14fb366ebf0650fed6aac8eb44" alt=""
2、在Start方法中初始化数据
data:image/s3,"s3://crabby-images/60b77/60b7715acfd32027b5557423ce65e56c5bcee197" alt=""
3、在Update方法中实现当鼠标点击时,出现弹痕
data:image/s3,"s3://crabby-images/d0437/d043788c00bd8b5201f0b8038d25cc2c6ceb89d5" alt=""
4、添加在3s后墙壁恢复成之前的状态
data:image/s3,"s3://crabby-images/d86a5/d86a539155c6b8b989553855769d67765fef1375" alt=""
注意:
1、鼠标点击出现弹痕是通过摄像机发射一条射线,射线产生的碰撞信息hit.textureCoord是uv坐标,该坐标是一个0~1的范围的值;
2、这里3s后弹痕消失,使用的原理是将之前保存的图片信息中的像素点信息取出后再次进行替换。
网友评论