基于DOTween插件实现金币飞行到指定位置功能

文章目录

  • 前言
  • 一、DOTween是什么?
  • 二、使用步骤
    • 1.导入DOTween插件
      • 在Unity官方插件商店找到`DOTween`插件
      • 导入DOTween插件
      • 启用DOTween插件
    • 2.代码逻辑
      • 金币飞行代码
      • 控制飞行效果代码
    • 3.物体配置
      • 1.物体上装配CoinEffect脚本
      • 2.在金币预制体上装配FlyControl脚本
  • 三、效果展示
  • 总结


前言

通过使用 DOTween 插件实现金币两段飞行效果,第一段在物体周围随机生成指定数量的金币,第二段将金币移动到指定位置。


一、DOTween是什么?

DoTween 是Unity的一款插件,主要用于控制物体的移动和变换。

二、使用步骤

1.导入DOTween插件

在Unity官方插件商店找到DOTween插件

https://assetstore.unity.com/packages/tools/animation/dotween-hotween-v2-27676
在这里插入图片描述

导入DOTween插件

在这里插入图片描述

启用DOTween插件

请添加图片描述

2.代码逻辑

金币飞行代码

    public class FlyControl : MonoBehaviour {
        private Vector3 endPos;
        private Vector3 startPos;

        private Vector3 vec1;
        private Vector3 vec2;
        [NonSerialized]public bool fly = true;
        public GameObject coin;

        //第一段位移 控制随机出现在父物体周围
        public void FlyCoinOne() {
            startPos = transform.position;
            float randomX = Random.Range(-50, 50);
            float randomY = Random.Range(-50, 50);
            vec1 = startPos + new Vector3(randomX, randomY, 0);
            coin.transform.DOMove(vec1, 0.3f).SetTarget(this);
        }

        //第二段位移 移动到指定位置
        public void FlyCoinTwo(Transform targetPos) {
            endPos = targetPos.position;
            vec2 = endPos;
            coin.transform.DOMove(vec2, 0.6f).SetTarget(this);
            float timer1 = 0;
            DOTween.To(() => timer1, x => timer1 = x, 1, 0.3f)
                .OnStepComplete(() => { this.gameObject.GetComponent<Image>().DOFade(0, 0.3f).SetTarget(this); });
            float timer = 0;
            DOTween.To(() => timer, x => timer = x, 1, 0.61f)
                .OnStepComplete(() => {
                    fly = false;
                    //Destroy(this.gameObject);
                });
        }
    }

控制飞行效果代码

 public class CoinEffect : MonoBehaviour{
        [LabelText("金币预制体")] public GameObject prefab;
        public Transform parent;
        [LabelText("金币数量")] public int num;
        [LabelText("最终目的地")] public Transform targetPos;
        [LabelText("金币飞行速度")] public float time = 1;
        private int childNum = 0;
        public bool isEnd = false;

        private List<FlyControl> ts = new List<FlyControl>();

        public void StartEffect(){
            for (int i = 0; i < num; i++){
                GameObject go = Instantiate(prefab, parent, false);
                go.transform.position = gameObject.transform.position;
                FlyControl cc = go.GetComponent<FlyControl>();
                if (cc != null){
                    cc.gameObject.SetActive(true);
                    ts.Add(cc);
                    childNum++;
                }

                ts[i].FlyCoinOne();
            }
        }

        IEnumerator StartEffect1(){
            yield return new WaitForSeconds(0.6f);
            for (int i = 0; i <= ts.Count; i++){
                this.DOKill();
                yield return new WaitForSeconds(0.1f);
                var rm = Random.Range(0, ts.Count);
                yield return new WaitForSeconds(0.01f);
                ts[rm].FlyCoinTwo(targetPos);
                // ts.Remove(ts[rm]);
                Debug.Log(rm);
                i = 0;
            }

            MyLogger.PrintLog("飞行结束");
        }

        /// <summary>
        /// 金币飞行效果,在Update里面调用
        /// </summary>
        public void CoinEffectShow(){
            //第一次飞行
            StartEffect();
            //第二次飞行
            StartCoroutine(StartEffect1());
        }

        private void Update(){
            if (childNum == 0){
                return;
            }

            foreach (var control in ts){
                if (control.fly){
                    return;
                }
            }


            isEnd = true;
            if (Input.GetKeyDown(KeyCode.R)){
                CoinEffectShow();
            }
        }
    }

3.物体配置

1.物体上装配CoinEffect脚本

在这里插入图片描述

2.在金币预制体上装配FlyControl脚本

在这里插入图片描述

三、效果展示

请添加图片描述


总结

提示:这里对文章进行总结:
例如:以上就是今天要讲的内容,本文仅仅简单介绍了pandas的使用,而pandas提供了大量能使我们快速便捷地处理数据的函数和方法。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/160841.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

CTFHub | Cookie注入,UA注入,Refer注入,过滤空格(利用hackbar插件)

Cookie注入 Cookie 注入原理 Cookie 注入的原理也和其他注入一样&#xff0c;只不过是将提交的参数以 Cookie 方式提交&#xff0c;而一般的注入是使用 GET 或者 POST 方式提交&#xff0c;GET 方式提交就是直接在网址后面加上需要注入的语句&#xff0c;POST 方式则是通过表单…

【自用总结】正项级数审敛法的总结

注&#xff1a;收敛半径的求法就是lim n->∞ |an1/an| ρ&#xff0c;而ρ1/R&#xff0c;最基本的不能忘。 比较判别法&#xff1a;从某项起&#xff0c;该级数后面的项均小于等于另一级数&#xff0c;则敛散性可进行一定的比较 可以看到&#xff0c;比较判别法实际上比较…

解决k8s node节点报错: Failed to watch *v1.Secret: unknown

现象&#xff1a; 这个现象是发生在k8s集群证书过期&#xff0c;重新续签证书以后。 记得master节点的/etc/kubernetes/kubelet.conf文件已经复制到node节点了。 但是为什么还是报这个错&#xff0c;然后运行证书检查命令看一下&#xff1a; 看样子是差/etc/kubernetes/pki/…

【Python/C++ 递归】汉诺塔

汉诺塔&#xff08;Tower of Hanoi&#xff09;&#xff0c;又称河内塔&#xff0c;是一个源于印度古老传说的益智玩具。大梵天创造世界的时候做了三根金刚石柱子&#xff0c;在一根柱子上从下往上按照大小顺序摞着64片黄金圆盘。大梵天命令婆罗门把圆盘从下面开始按大小顺序重…

腾讯智影数字人工具

腾讯智影数字人工具 腾讯智影数字人的形象风格多样&#xff0c;包括写实、卡通等&#xff0c;可以满足不同年龄层观众的喜好。同时&#xff0c;腾讯智影数字人也提供了灵活的驱动方案&#xff0c;可以通过文本或配音直接生成视频&#xff0c;并支持数字人做出与视频一样的动作…

企业如何实现降本增效——数字化转型

说到企业数字化转型&#xff0c;不可避免要围绕企业降本增效。企业们都在积极寻找降本增效解决之道&#xff0c;以实现降本增效的目标。数字化转型也成为了很多企业降本增效的重要手段。通过引入云计算、大数据、人工智能等技术&#xff0c;企业们实现了业务流程的数字化和智能…

YOLOv8-seg改进:注意力系列篇 | 一种简单有效的可变形的自注意力模块DAT | CVPR 2022

🚀🚀🚀本文改进:Deformable Attention Transformer,一种简单有效的可变形的自注意力模块,增强sparse attention 的表征能⼒; 🚀🚀🚀DAT小目标分割&复杂场景首选,实现涨点 🚀🚀🚀YOLOv8-seg创新专栏:http://t.csdnimg.cn/KLSdv 学姐带你学习YOL…

企业视频数字人有哪些应用场景

来做个数字人吧&#xff0c;帮我干点活吧。 国内的一些数字人&#xff1a; 腾讯智影 腾讯智影数字人是一种基于人工智能技术的数字人物形象&#xff0c;具有逼真的外观、语音和行为表现&#xff0c;可以应用于各种场景&#xff0c;如新闻播报、文娱推介、营销、教育等。 幻…

GMS CTS测试命令汇总

目录 跑CTS之前的准备 样机环境要求 跑各模块版本要求 CTS 简介 复测上轮的失败项 多台设备测试 单跑指定模块和测试用例 GTS VTS STS GSI 获取fingerprint 跑CTS之前的准备 样机环境要求 1、打开stay wake&#xff08;保持屏幕常亮&#xff09;、OEM unlocking、…

物联网赋能:WIFI HaLow在无线连接中的优势

在探讨无线网络连接时&#xff0c;我们不难发现&#xff0c;WIFI已经成为我们日常生活中不可或缺的一部分&#xff0c;承载了半数以上的互联网流量&#xff0c;并在家庭、学校、娱乐场所等各种场合广泛应用。然而&#xff0c;尽管WIFI4、WIFI5和WIFI6等协议无处不在&#xff0c…

文心一言-情感关怀之旅

如何让LLM更有温度。 应用介绍

OpenAI 变天:Sam Altman 被踢出局,原 CTO 暂代临时 CEO

文章目录 灵魂人物 Sam Altman 离任 OpenAICEO 下台&#xff1a;OpenAI 也宫斗&#xff1f;个人简介 hello&#xff0c;大家好&#xff0c;我是 Lorin&#xff0c;一觉醒来科技圈发生了一件令人震惊的大事&#xff1a;Sam Altman 被踢出局&#xff0c;原 CTO 暂代临时 CEO。 灵…

基于蛾群算法优化概率神经网络PNN的分类预测 - 附代码

基于蛾群算法优化概率神经网络PNN的分类预测 - 附代码 文章目录 基于蛾群算法优化概率神经网络PNN的分类预测 - 附代码1.PNN网络概述2.变压器故障诊街系统相关背景2.1 模型建立 3.基于蛾群优化的PNN网络5.测试结果6.参考文献7.Matlab代码 摘要&#xff1a;针对PNN神经网络的光滑…

【Mysql】复合查询详解+实战操作(多表查询、自链接、子查询等)

&#x1f308;欢迎来到Python专栏 &#x1f64b;&#x1f3fe;‍♀️作者介绍&#xff1a;前PLA队员 目前是一名普通本科大三的软件工程专业学生 &#x1f30f;IP坐标&#xff1a;湖北武汉 &#x1f349; 目前技术栈&#xff1a;C/C、Linux系统编程、计算机网络、数据结构、Mys…

突发!“ChatGPT 之父”奥特曼被 OpenAI 开除!!乔布斯故事重演了?

重磅消息&#xff01; OpenAI刚刚官宣领导层换届&#xff0c;SamAltman辞任CEO并离开董事会&#xff0c;原CTO Mira Murati 任命为临时CEO&#xff0c;并正在进行寻找永久继任CE0。 大模型研究测试传送门 GPT-4传送门&#xff08;免墙&#xff0c;可直接测试&#xff0c;遇浏…

【快速解决】实验三 简单注册的实现《Android程序设计》实验报告

目录 前言 实验要求 实验三 简单注册的实现 实验目的&#xff1a; 实验内容&#xff1a; 实验提示&#xff1a; 无 三、遇到的问题总结&#xff08;如果有问题&#xff0c;请总结。如果没问题请写“无”&#xff09; 正文开始 第一步建立项目 第二步选择empty views a…

IDEA 中设置 File Header 以及自定义类、方法注释模板的方法

目录 1 设置 File Header2 自定义类、方法注释生成类注解模板生成方法注解模板 1 设置 File Header File -> Settings -> File and Code Templates -> Includes -> File Header -> 编辑 2 自定义类、方法注释 File -> Settings -> Live Templates -&g…

Reflect的作用,target,property,value,receiver代表啥

1.真的proxy let target {name:张三} let handler {get(target,property,receiver){console.log(1,target,2,property,3,receiver)return Reflect.get(target,property,receiver)},set(target,property,value,receiver){console.log(a,target,b,property,c,value,d,receiver)…

java每日一记 —— 谈谈反射

这应该是基础吧 1.先来说点前置知识&#xff1a;类的加载机制2.以自己的方式来谈反射的概念3.获取class的三种方式3.1.通过已知的类型获取class3.2.通过实例对象获取class3.3.通过Class.forName获取全路径指定类名的class 4.整理了一下API&#xff1a;坦言说&#x1faa1;累5.现…

利用X6 制作一个简单的流程图工具

介绍 项目模版使用 我自己基于 arco-design 封装的一个 B 端项目模版 。 地址&#xff1a;https://github.com/duKD/antv-x6-org 运用 antv/X6 &#xff1a; https://x6.antv.antgroup.com/ 来实现 一个简单的流程图工具 项目预览&#xff1a; 功能 支持框选 alt鼠标左键…