Unity3D实现扭动挤压浏览效果

最近的项目中,想做到一种能够吸引眼球的一种角色选择浏览效果

Demo源码:点击打开链接

最终实现了下按如下图这么一种浏览效果:

效果图一

效果图二

可能要实现这么一种效果用动画插件会很快,但总感觉有点大材小用
这里我向大家分享一个极简方式来实现这么一种效果

目录结构如下

其中Items有4个Image子节点

在父节点Items下添加如下图横向布局组件

在其4个Image子节点下添加如下图布局元素组件

完成这些步骤后接下来就是代码实现了
在Items添加如下脚本组件

using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.UI;

public class Items : MonoBehaviour
{
 public List<GameObject> items = new List<GameObject>();

 //缩放时间
 public float time = 1.3f;

 //原先大小
 public Vector2 oldSize;

 //放大缩小速度
 public float speed;

 private void Start()
 {
 for (int i = 0; i < items.Count; i++)
 {
 EventTriggerListener.GetComponent(items[i]).onEnter = OnMouseEnter;
 EventTriggerListener.GetComponent(items[i]).onExit = OnMouseExit;
 }
 }

 void OnMouseEnter(GameObject go)
 {
 EventTriggerListener.GetComponent(go).UpdateSize(oldSize * time, speed);
 }

 void OnMouseExit(GameObject go)
 {
 EventTriggerListener.GetComponent(go).UpdateSize(oldSize, speed);
 }
}

在其4个子节点下添加如下脚本组件

using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.EventSystems;
using UnityEngine.UI;

[RequireComponent(typeof(LayoutElement))]
public class EventTriggerListener : EventTrigger
{
 public delegate void VoidDelegate(GameObject obj);
 //点击
 public VoidDelegate onClick;
 //鼠标按下
 public VoidDelegate onDown;
 //鼠标抬起
 public VoidDelegate onUp;
 //鼠标移入
 public VoidDelegate onEnter;
 //鼠标移出
 public VoidDelegate onExit;

 private Vector2 currentSize;
 private Vector2 targetSize;
 private float speed = 4.0f;

 public static EventTriggerListener GetComponent(GameObject obj)
 {
 EventTriggerListener listener = obj.GetComponent<EventTriggerListener>();
 if (listener == null)
 {
 listener = obj.AddComponent<EventTriggerListener>();
 }

 return listener;
 }

 public override void OnPointerClick(PointerEventData eventData)
 {
 if (onClick != null)
 {
 onClick(gameObject);
 }
 }
 public override void OnPointerDown(PointerEventData eventData)
 {
 if (onDown != null) onDown(gameObject);
 }
 public override void OnPointerUp(PointerEventData eventData)
 {
 if (onUp != null) onUp(gameObject);
 }
 public override void OnPointerEnter(PointerEventData eventData)
 {
 if (onEnter != null) onEnter(gameObject);
 }
 public override void OnPointerExit(PointerEventData eventData)
 {
 if (onExit != null) onExit(gameObject);
 }

 private void Start()
 {
 targetSize = currentSize = new Vector2(this.GetComponent<LayoutElement>().preferredWidth, this.GetComponent<LayoutElement>().preferredHeight);
 }

 private void Update()
 {
 if (currentSize != targetSize)
 {
 currentSize = Vector2.Lerp(currentSize, targetSize, Time.deltaTime * speed);
 if (Vector2.Distance(currentSize, targetSize) <= 0.01)
 {
 currentSize = targetSize;
 }

 this.GetComponent<LayoutElement>().preferredWidth = currentSize.x;
 this.GetComponent<LayoutElement>().preferredHeight = currentSize.y;
 }
 }

 public void UpdateSize(Vector2 size,float speed)
 {
 this.targetSize = size;
 this.speed = speed;
 }
}

脚本挂载上去后,在Item下按如下图方式设值

可以按自己喜好调整数值。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • Unity3D Ui利用shader添加效果

    本文实例为大家分享了Unity3D Ui利用shader添加效果的具体代码,供大家参考,具体内容如下 // Upgrade NOTE: replaced 'mul(UNITY_MATRIX_MVP,*)' with 'UnityObjectToClipPos(*)' Shader "UI/Unlit/Flowlight" { Properties { [PerRendererData] _MainTex("Sprite Texture", 2D) = "w

  • Unity实现旋转扭曲图像特效

    旋转扭曲特效是指在一个圆形区域内扭曲所渲染的图像,其他像素的旋转程度随着距离的变化而变化.具体可以通过修改Shader来实现. 原始图片 扭曲图片 /*==================================================== 屏幕扭曲特效Shader ======================================================*/ Shader "Hidden/TwirlEffects" { Properties { _M

  • Unity3D实现扭动挤压浏览效果

    最近的项目中,想做到一种能够吸引眼球的一种角色选择浏览效果 Demo源码:点击打开链接 最终实现了下按如下图这么一种浏览效果: 效果图一 效果图二 可能要实现这么一种效果用动画插件会很快,但总感觉有点大材小用 这里我向大家分享一个极简方式来实现这么一种效果 目录结构如下 其中Items有4个Image子节点 在父节点Items下添加如下图横向布局组件 在其4个Image子节点下添加如下图布局元素组件 完成这些步骤后接下来就是代码实现了 在Items添加如下脚本组件 using System.Co

  • Unity3D中shader 轮廓描边效果实现代码

    Unity3D中shader 轮廓描边效果 想利用Unity3D中shader这个功能实现描边轮廓边框效果该怎么做呢,相信有很多搞开发的人想知道,为此下面就给大家介绍下方法. Shade实现描边效果,如下图中的3D球效果图         Shade代码如下: Shader "Outlined/Silhouetted Diffuse" { Properties { _Color ("Main Color", Color) = (1,1,1,1) _OutlineCo

  • JavaScript仿百度图片浏览效果

    本文实例为大家分享了js图片浏览效果的具体代码,供大家参考,具体内容如下 在线地址:http://www.hui12.com/nbin/demo/imgskim/index.html https://nbin2008.github.io/demo/imgskim/index.html 效果图: index <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>仿

  • jquery仿百度经验滑动切换浏览效果

    jquery仿百度经验滑动切换浏览效果 $(function() { wordStrong(); $("#content ul").width($("#content ul li:first").width()*$("#content ul li").length); $("#header .top_right .vote").hover(function() { $(this).children(".hover-t

  • Android UI控件之Gallery实现拖动式图片浏览效果

    我们知道现在智能手机上都有这样一种功能,就是你在浏览图片的时候.不是硬性的点击按钮而是可以实现手指的拖动,划开效果.使用户具有更好的交互体验,不过这种效果是如何实现的呢? 在Android中是通过Gallery来实现拖动效果的. 通过Gallery可以实现各种各样的效果,此篇文章只是简要谈谈他的用法,至于后续的一些效果 有机会的时候做一个整理. 首先看看其简单实现吧!本次实例是通过选取图片实现类似设置背景的功能! 不过需要说明的是:图片不宜过大,否则容易内存溢出,android对大图片的支持不好

  • Unity3d实现跑马灯广播效果

    本文实例为大家分享了Unity3d实现跑马灯广播效果的具体代码,供大家参考,具体内容如下 废话不多说,直接上代码 using DG.Tweening; using System.Collections; using System.Collections.Generic; using UnityEngine; using UnityEngine.UI; using Utils; //挂在UI上面 public class BroadcastUI : MonoBehaviour {     priv

  • UIScrollView实现六棱柱图片浏览效果

    目录 一.效果展示 二.实现原理 三.代码 四.总结与思考 一.效果展示 废话开篇:利用 CATransform3D 图形变换及 UIScrollView 的一些方法实现一个六棱柱图片浏览效果 二.实现原理 1.在一个基础 View 上添加六棱柱的六个侧面视图. 2.调整六棱柱的各个侧面的旋转角度及z轴数值. 3.基础 View 放在 UIScrollView 上,通过监听 UIScrollView 的滑动来设置基础 View 的坐标x值与与y轴的旋转角度. 三.代码 创建 PhotoDrumB

  • UICollectionView 实现图片浏览效果

    目录 一.效果展示 二.实现思路 三.代码整理 1.PhotoBrowseViewLayout 2.PhotoBrowseCollectionViewCell 3.CollectPhotoBrowseView 四.总结与思考 一.效果展示 废话开篇:利用 UICollectionView 简单实现一个图片浏览效果. 二.实现思路 1.封装 UICollectionViewLayout ,实现内部 UICollectionViewCell 的布局. UICollectionViewLayout 在

  • Android实现TV端大图浏览效果的全过程

    目录 前言 1.BitmapRegionDecoder: 2.SubsamplingScaleImageView 3.Glide+SubsamplingScaleImageView混合加载渲染 4.自定义LongImageView,结合BitmapRegionDecoder使用 5.在MainActivity中的使用: 6.布局文件代码: 7.实现的效果如下: 总结 前言 最近TV开发需要加载的图片很长,大小也很大,并且还不允许压缩.比如显示:世界地图.清明上河图.微博长图.海报.活动照片等.

随机推荐