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

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 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);

}

}

在其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();

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;

}

}

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

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

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

unity3d模拟树叶飘动_Unity3D实现扭动挤压浏览效果相关推荐

  1. unity3d模拟树叶飘动_Unity3D独立游戏开发日记(一):动态生成树木

    目前写的独立游戏是一个沙盒类型的游戏.游戏DEMO视频如下: 提到沙盒类型的游戏,就有人给出了这样的定义: 游戏世界离现实世界越近,自由度.随机度越高才叫沙盒游戏.所谓自由度,就是你在游戏里想干啥就干 ...

  2. unity3d模拟树叶飘动_unity3d-地图制作之云彩飘动

    首先,我先声明,关于美工制作我是一点都不了解,甚至基本上没接触过,所以今天开始我就兼并这美工加程序来学习. 当然,我只是对unity中的美术比较感兴趣而已,仅此而已. 所以,如果我在文章中讲的不对的地 ...

  3. Unity3d实现扭动挤压浏览效果

    最近的项目中,想做到一种能够吸引眼球的一种角色选择浏览效果 Demo源码:点击打开链接 最终实现了下按如下图这么一种浏览效果: ·效果图一 ·效果图二 可能要实现这么一种效果用动画插件会很快,但总感觉 ...

  4. unity3d 模拟电脑实现_Unity3D实现3D立体游戏原理及过程

    下面的教程是我今天整理的资料,教大家一步步完成自己的3D立体游戏,并向大家介绍一些3D成像的原理. 理论上,每个普通的非立体3d游戏,都可以改为3D立体游戏,看完这篇帖子,你们都可以把自己之前做过的3 ...

  5. 基于VPSC模拟FCC金属等通道转角挤压(ECAE)工艺

    在之前的推文中我们使用粘塑性自洽多晶体塑性模型(Visco-plasitic Self Consistant,VPSC)计算了面心立方(fcc).体心立方(bcc)金属材料变形过程,实现了织构演变的模 ...

  6. html图片靠右浮动 文字左侧环绕,CSS实现模拟float: center文字左右环绕图片的效果...

    什么是文字左右环绕图片?就是下图的效果: 效果的CSS代码可以点击这里查看 在CSS中,并没有float: center这种设置,但是我们可以通过一些小技巧来模拟出类似的效果. 经常会有小伙伴问:有f ...

  7. Unity3D制作LED滚动字幕(跑马灯)效果

    Unity3D制作LED滚动字幕(跑马灯)效果 搭建场景 建立世界坐标的Canvas 新建LED模型 Text节点 Mask节点 查看效果 美化一下 编写代码 DOTween插件 设置属性 编写文字滚 ...

  8. html文字环绕居中图,CSS实现模拟float: center文字左右环绕图片的效果

    什么是文字左右环绕图片?就是下图的效果: 效果的CSS代码可以点击 这里 查看 在CSS中,并没有float: center这种设置,但是我们可以通过一些小技巧来模拟出类似的效果. 经常会有小伙伴问: ...

  9. unity3d 模拟电脑实现_基于Unity3D的机器人仿真实验系统

    龙源期刊网 http://www.qikan.com.cn 基于 Unity3D 的机器人仿真实验系统 作者:庄严 卢阿丽 杨庆 来源:<电子技术与软件工程> 2018 年第 03 期 摘 ...

最新文章

  1. 【CV】OpenCV(基于Python)学习笔记
  2. JavaScript 立即执行函数的两种写法
  3. 结对编程——四则运算过程
  4. ActionScript 3.0 Step By Step系列(三):学学流程控制,编编if-else switch while for
  5. ListModel QML类型
  6. 每日程序C语言26-直接选择排序
  7. ceres学习之平面拟合
  8. android 飞框动画,AndroidTV中实现飞框选中效果
  9. Qt经验积累:常见的驱动打包处理方法
  10. storm 出现一次运行结果,后续不在出现的原因
  11. 谁说不同品牌内存无法兼容-关键调整频率和内存时序
  12. 基于python的手机销售系统
  13. 51地图API接口的初次使用
  14. open用法 vba_open方法读写文件
  15. zabbix_sender安装和使用
  16. iOS开发常用代码片段:总有你用得上的功能
  17. win7 打开“计算机”慢,怎么解决win7开机慢|win7系统开机速度慢的三大解决方法...
  18. 苹果IPad客户端安装测试软件
  19. 实战五十一:基于python机器学习深度学习实现股市评论情感分析 (完整代码+数据集可直接运行)
  20. 通配符的使用方法(初学)

热门文章

  1. react实现一个简单的计算器
  2. c语言怎么存储输入法的爱心,如何在手机上面用c语言编写爱心图片
  3. 知识图谱 - 使用图数据库(记一次eno4j搭建分享)
  4. 支付场景化建设——拉卡拉支付
  5. cadence使用技巧(三)— 自定义virtuoso ciw菜单
  6. 软件测试中性能调优的过程解析
  7. js中websocket基本使用及数据量过大或推送频率过快等基本问题
  8. mysql 行级排它锁_Mysql的行级锁 -- 共享锁和排他锁
  9. vue中proxyTable配置方法
  10. LAMP介绍、Apache安装