Unity鼠标悬停实现图片的浮动效果

效果如下图所示:

Unity鼠标悬停实现图片的浮动效果_第1张图片

实现步骤:


Unity鼠标悬停实现图片的浮动效果_第2张图片         Unity鼠标悬停实现图片的浮动效果_第3张图片Unity鼠标悬停实现图片的浮动效果_第4张图片


Unity鼠标悬停实现图片的浮动效果_第5张图片  Unity鼠标悬停实现图片的浮动效果_第6张图片


Unity鼠标悬停实现图片的浮动效果_第7张图片Unity鼠标悬停实现图片的浮动效果_第8张图片Unity鼠标悬停实现图片的浮动效果_第9张图片Unity鼠标悬停实现图片的浮动效果_第10张图片Unity鼠标悬停实现图片的浮动效果_第11张图片


Unity鼠标悬停实现图片的浮动效果_第12张图片        

  Unity鼠标悬停实现图片的浮动效果_第13张图片 Unity鼠标悬停实现图片的浮动效果_第14张图片

上图的Preferred Width和Preferred Height同sprite的Width、Height一样


Items.cs

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

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

//缩放时间
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);
}
}


EventTriggerListener.cs    这是给5个sprite的

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();
if (listener == null)
{
listener = obj.AddComponent();
}


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().preferredWidth, this.GetComponent().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().preferredWidth = currentSize.x;
this.GetComponent().preferredHeight = currentSize.y;
}
}

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

Unity鼠标悬停实现图片的浮动效果_第15张图片



你可能感兴趣的:(工作,游戏开发)