返回顶部
首页 > 资讯 > 精选 >如何解决Unity自定义组件之序列帧播放组件问题
  • 113
分享到

如何解决Unity自定义组件之序列帧播放组件问题

2023-06-22 08:06:14 113人浏览 独家记忆
摘要

这篇文章主要为大家展示了“如何解决Unity自定义组件之序列帧播放组件问题”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何解决Unity自定义组件之序列帧播放组件问题”这篇文章吧。  我们知道

这篇文章主要为大家展示了“如何解决Unity自定义组件之序列帧播放组件问题”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何解决Unity自定义组件之序列帧播放组件问题”这篇文章吧。

  我们知道在unity中播放序列帧动画有两种方式,第一种是利用Unity自带的animation组件来播放,我们只需要在工程目录中全选选中所有我们需要播放的图片,将其拖动到Hiercarchy上,Unity就会帮我们自动创建一个animation片段,我们就可以用animation组件来控制我们的动画,不过这种方式创建的图片Sprite Renderer类型的。第二种方式就是创建一个Image组件,利用代码创建一个sprite,写一段代码利用Update函数来逐帧替换Image的sprite来实现动画的播放。这种的话可能会麻烦点,不过自由度高一点,可根据自己的需求来进行编写代码控制

  由于最近的项目中需要用到大量的序列帧动画以及逻辑处理,本来想用Unity自带的Animation组件来实现的,但由于甲方需求一再变更,需要处理的逻辑太多,为了方便修改和拓展,所以就根据自己项目的需求自定义了一个序列帧播放组件来辅助开发。先贴上图片看看效果,如下图就是这个ImageAnimation脚本组件,我们只需要创建一个Image,然后挂载上这个脚本,将需要播放的图片赋给脚本上的Sprite数组,根据自己需求可在编辑面板设定图片的循环播放方式、播放速度、以及是否自动播放,还可根据自己的需求添加回调函数。很方便。

如何解决Unity自定义组件之序列帧播放组件问题

  好了,废话不多说了,上代码,脚本开放出来了播放Play()、暂停Pause()、停止Stop()、重播Replay() 4个公共方法,以及一个回调函数,根据自己的需求直接调用这4个方法和回调来控制自己的图片播放控制就好。脚本不是很复杂,主要是希望给大家提供一种思路,在项目开发中可以根据自己的需求封装一些功能出来来辅助自己开发,以提高效率。这次分享就到这里了,大家有什么问题和意见都可以和我交流、探讨,一起学习进步。

using System.Collections;using System.Collections.Generic;using UnityEngine;using UnityEngine.UI;using LjfLog;using UnityEngine.Events;namespace LJF{    //规范命名、添加注释、合理封装、限制访问权限、异常处理        public class ImageAnimation : MonoBehaviour    {        public enum State        {            idle,            playing,            pause        }        public enum State1        {            once,            loop        }               [Header("播放方式(循环、单次)")]//默认单次        public State1 condition=State1.once;        [Header("自动播放")]//默认不自动播放        public bool Play_Awake = false;        //播放状态(默认、播放中、暂停)        private  State play_state;        private Image manimg;        [Header("每秒播放的帧数(整数)")]        public float frame_number=30;        [Header("sprite数组")]        public Sprite[] sprit_arr;        //回调事件        public UnityEvent onCompleteEvent;        private int index;        private float tim;        private float waittim;        private bool isplay;        void Awake()        {            manimg = GetComponent<Image>();            tim = 0;            index = 0;            waittim = 1 / frame_number;            play_state = State.idle;            isplay = false;            if (manimg == null)            {                Debuger.LogWarning("Image为空,请添加Image组件!!!");                return;            }            if (sprit_arr.Length<1)            {                Debuger.LogWarning("sprite数组为0,请给sprite数组添加元素!!!");            }            manimg.sprite = sprit_arr[0];            if (Play_Awake)            {                Play();            }        }        void Update()        {            //测试            if (Input.GeTKEyDown(KeyCode.A))            {                Play();            }            if (Input.GetKeyDown(KeyCode.S))            {                Replay();            }            if (Input.GetKeyDown(KeyCode.D))            {                Stop();            }            if (Input.GetKeyDown(KeyCode.P))            {                Pause();            }            UpMove();                   }        private void UpMove()        {            //单播            if (condition == State1.once)            {                if (play_state == State.idle && isplay)                {                    play_state = State.playing;                    index = 0;                    tim = 0;                }                if (play_state == State.pause && isplay)                {                    play_state = State.playing;                    tim = 0;                }                if (play_state == State.playing && isplay)                {                    tim += Time.deltaTime;                    if (tim >= waittim)                    {                        tim = 0;                        index++;                        if (index >= sprit_arr.Length)                        {                            index = 0;                            manimg.sprite = sprit_arr[index];                            isplay = false;                            play_state = State.idle;                            //此处可添加结束回调函数                            if (onCompleteEvent != null)                            {                                onCompleteEvent.Invoke();                                return;                            }                        }                        manimg.sprite = sprit_arr[index];                    }                }            }            //循环播放            if (condition == State1.loop)            {                if (play_state == State.idle && isplay)                {                    play_state = State.playing;                    index = 0;                    tim = 0;                }                if (play_state == State.pause && isplay)                {                    play_state = State.playing;                    tim = 0;                }                if (play_state == State.playing && isplay)                {                    tim += Time.deltaTime;                    if (tim >= waittim)                    {                        tim = 0;                        index++;                        if (index >= sprit_arr.Length)                        {                            index = 0;                            //此处可添加结束回调函数                        }                        manimg.sprite = sprit_arr[index];                    }                }            }        }        /// <summary>        /// 播放        /// </summary>        public void Play()        {            isplay = true;        }        /// <summary>        /// 暂停        /// </summary>        public void Pause()        {            isplay = false;            play_state = State.pause;        }        /// <summary>        /// 停止        /// </summary>        public void Stop()        {            isplay = false;            play_state = State.idle;            index = 0;            tim = 0;            if (manimg == null)            {                Debuger.LogWarning("Image为空,请赋值");                return;            }            manimg.sprite = sprit_arr[index];        }        /// <summary>        /// 重播        /// </summary>        public void Replay()        {            isplay = true;            play_state = State.playing;            index = 0;            tim = 0;        }    }}

以上是“如何解决Unity自定义组件之序列帧播放组件问题”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网精选频道!

--结束END--

本文标题: 如何解决Unity自定义组件之序列帧播放组件问题

本文链接: https://lsjlt.com/news/303552.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 如何解决Unity自定义组件之序列帧播放组件问题
    这篇文章主要为大家展示了“如何解决Unity自定义组件之序列帧播放组件问题”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何解决Unity自定义组件之序列帧播放组件问题”这篇文章吧。  我们知道...
    99+
    2023-06-22
  • 聊聊Unity自定义组件之序列帧播放组件问题
      我们知道在unity中播放序列帧动画有两种方式,第一种是利用Unity自带的animation组件来播放,我们只需要在工程目录中全选选中所有我们需要播放的图片,将其拖动到Hier...
    99+
    2024-04-02
  • 小程序如何自定义轮播图圆点组件
    本篇内容介绍了“小程序如何自定义轮播图圆点组件”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!微信小程序自带的轮播图小点,是一个圆点且在图片上...
    99+
    2023-07-02
  • 小程序如何自定义组件
    本文小编为大家详细介绍“小程序如何自定义组件”,内容详细,步骤清晰,细节处理妥当,希望这篇“小程序如何自定义组件”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。一 小程序提供了很多api和基础组件,但为减少代码的复...
    99+
    2023-06-26
  • vue自定义keepalive组件的问题解析
    目录vue自定义keepalive组件为什么会出现这种情况呢如何解决这个问题呢问题知道了怎么解决呢思路有了撸代码如何使用主题说完了,整点其他的vue自定义keepalive组件 前一...
    99+
    2024-04-02
  • vue自定义组件@click点击失效问题及解决
    目录自定义组件@click点击失效问题描述原因分析问题解决@click不起作用,同时报错自定义组件@click点击失效 问题描述 自定义组件在使无法,无法绑定原vue文件内的原生cl...
    99+
    2024-04-02
  • 微信小程序自定义组件找不到如何解决
    如果在开发微信小程序时遇到自定义组件找不到的问题,可以按照以下步骤进行排查和解决:1. 确认自定义组件文件夹是否存在于小程序项目的正...
    99+
    2023-09-29
    微信小程序
  • vue自定义组件@click点击失效问题怎么解决
    这篇文章主要讲解了“vue自定义组件@click点击失效问题怎么解决”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“vue自定义组件@click点击失效问题怎么解决”吧!自定义组件@click...
    99+
    2023-06-30
  • 微信小程序如何自定义tabbar组件
    这篇文章主要讲解了“微信小程序如何自定义tabbar组件”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“微信小程序如何自定义tabbar组件”吧!由于项目需求,必须自己写组件:第一步:在App...
    99+
    2023-06-14
  • 微信小程序中如何自定义组件
    这篇文章将为大家详细讲解有关微信小程序中如何自定义组件,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。在微信小程序开发过程中,对于一些可能在多个页面都使用的页面模块,可以把它封装成一个组件,以提高开发效率。...
    99+
    2023-06-29
  • 如何实现小程序的自定义组件
    要实现小程序的自定义组件, 需要以下步骤: 创建一个自定义组件的文件夹,例如 components/myComponent。 ...
    99+
    2024-04-17
    小程序
  • uniapp小程序开发组件封装之自定义轮播图效果
    目录前言:正文1、首先了解swiper组件1.1、小小的demo示例:1.2、自定义轮播图效果展示说明2、完成自定义轮播图效果3、组件封装——自定义轮播图3....
    99+
    2023-02-06
    uniapp自定义轮播图 uniapp小程序开发 uniapp组件封装
  • 如何理解Vue中组件的自定义事件
    本篇文章为大家展示了如何理解Vue中组件的自定义事件,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。<template>  <div > ...
    99+
    2023-06-25
  • Go语言中如何处理并发自定义组件问题?
    Go语言是一门具有强大并发特性的编程语言,它提供了丰富的并发处理机制来解决并发问题。在Go语言中,处理并发自定义组件问题的方法有很多,包括使用协程、通道、互斥锁等。下面将介绍一些常用的方法,并给出具体的代码示例。使用协程协程是Go语言中非常...
    99+
    2023-10-22
    Go语言 (Go language) 并发处理 (concurrency) 自定义组件 (custom componen
  • windows播放文件时遇到问题如何解决
    在Windows播放文件时遇到问题时,你可以尝试以下解决方法:1. 确保媒体文件的格式与Windows支持的媒体文件格式兼容。如果文...
    99+
    2023-09-20
    windows
  • 小程序如何实现自定义通用toast组件
    这篇文章主要为大家展示了“小程序如何实现自定义通用toast组件”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“小程序如何实现自定义通用toast组件”这篇文章吧...
    99+
    2024-04-02
  • 微信小程序button组件如何自定义样式
    本篇内容主要讲解“微信小程序button组件如何自定义样式”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“微信小程序button组件如何自定义样式”吧!背景颜色wxml代码<button c...
    99+
    2023-06-26
  • 小程序如何自定义可清除的input组件
    这篇文章主要介绍“小程序如何自定义可清除的input组件 ”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“小程序如何自定义可清除的input组件 ”文章能帮助大家解决问题。首先,在目标目录下新建一个自...
    99+
    2023-06-26
  • Vue如何解决兄弟组件之间传值问题
    目录解决兄弟组件之间传值问题bus可以通过两种方式来实现各类组件间传值方法(父子、兄弟、页级)父子关系组件兄弟关系组件页级关系组件解决兄弟组件之间传值问题 vue中 父组件向子组件传...
    99+
    2024-04-02
  • 微信小程序如何实现自定义弹窗组件
    本篇内容主要讲解“微信小程序如何实现自定义弹窗组件”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“微信小程序如何实现自定义弹窗组件”吧!首先,放一下,最终的效果图:这是我们最后要实现的效果那么,首...
    99+
    2023-07-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作