如何不绑定脚本且不继承MonoBehaviour做U3D的开发

2024-02-11 17:38

本文主要是介绍如何不绑定脚本且不继承MonoBehaviour做U3D的开发,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

要点:我们把脚本绑在对象上为什么不把对象抓到脚本里殴打呢?

问题:那不继承Mono的话,协同以及实例化,以及每帧运算该怎么去做呢?

最近看到一个做技能冷却的话题,所以也想去尝试一下。

1.这是界面2D和3D摄像机

2.这是对象排布

3.代码

(1)主要负责UI的界面

[C#] 纯文本查看 复制代码
?
01
02
03
04
05
06
07
08
09
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
<font style= "color:rgb(51, 51, 51)" > using Assets.Classes.com.system;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using UnityEngine;
namespace Assets.Classes.com.view.ui
{
     enum SKILLTYPE
     {
         Q_SKILL = 10, //→_→代表该技能的冷却时间
         W_SKILL = 20,
         E_SKILL = 30,
         R_SKILL = 100
     }
     class SkillsMenu_UI
     {
         private SKILLTYPE skillType; //技能类型
         private bool isSkill = false ; //是否正在释放技能
         private bool isCooling = false ; //是否正在冷却
         private float coolingTime; //冷却时间
         private GameObject currentObj;
         public SkillsMenu_UI(GameObject skillsObj)
         {
         //    GameObject go = (GameObject)GameObject.Instantiate(skillsObj);
          //   new PanelHandler().RootHandler(skillsObj);
             HandlerListener( "Q_Skill" , skillsObj);
             HandlerListener( "W_Skill" , skillsObj);
             HandlerListener( "E_Skill" , skillsObj);
             HandlerListener( "R_Skill" , skillsObj);
         }
         private void HandlerListener( string skillName, GameObject go)
         {
             Transform Skill = go.transform.FindChild(skillName);
             UIEventListener.Get(Skill.gameObject).onClick = OnClick;
         }
         private void OnClick(GameObject go)
         {          
             Debug.Log( "点击了技能按钮 : " + go.name);
             switch (go.name)
             {
                 case "Q_Skill" : skillType = SKILLTYPE.Q_SKILL; HandlerSkill(skillType, go); break ;
                 case "W_Skill" : skillType = SKILLTYPE.W_SKILL; HandlerSkill(skillType, go); break ;
                 case "E_Skill" : skillType = SKILLTYPE.E_SKILL; HandlerSkill(skillType, go); break ;
                 case "R_Skill" : skillType = SKILLTYPE.R_SKILL; HandlerSkill(skillType, go); break ;
             }
         }
         private void HandlerSkill(SKILLTYPE type, GameObject go)
         {
             if (!isCooling || !isSkill) //是否冷却或者是否有技能没有释放
             {
                 currentObj = go;
                 skillType = type;
                 isSkill = true ;
                 isCooling = true ;
                 HandlerCoolingTimer(type);
                 Debug.Log( "可以释放该技能了" );
             }
             else
             {
                 Debug.Log( "不可释放技能" );
             }
         }
         private void HandlerCoolingTimer(SKILLTYPE type)
         {
             coolingTime = ( float )type;
             currentObj.transform.FindChild( "Fore" ).gameObject.GetComponent<UISprite>().fillAmount = 1;
             GameController.getInstance().addInterval(TimerCutting);
             Debug.Log( "开始倒计时" );
         }
         private void TimerCutting( float t)
         {           
             currentObj.transform.FindChild( "Fore" ).gameObject.GetComponent<UISprite>().fillAmount -= (1.0f / coolingTime) * Time.deltaTime;
             float tempTime = currentObj.transform.FindChild( "Fore" ).gameObject.GetComponent<UISprite>().fillAmount;
             Debug.Log( "------------coolingTime : " + tempTime);
             if (tempTime <= 0.01f)
             {
                 isSkill = false ;
                 isCooling = false ;
                 GameController.getInstance().removedInterval(TimerCutting); 
             }
         }
     }
}</font>

设计思想:外界需要处理这个界面的时候,只需要声明对象new 这个类的有参构造函数即可,然后默认进行一系列初始化动作。


这个是替代自带的OnClick()事件,采用事件事件监听机制。

其他略。

(2)

如果我需要每帧去计算的要求我该怎么办?

那就写一个可以控制全局的每帧运算。

      

[C#]  纯文本查看  复制代码
?
01
02
03
04
05
06
07
08
09
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
/*
        * 游戏主循环
        */
      private static GameController m_instance;
       List<Action< float >> intervalCallFuns;
       public void mainLoop()
       {
           interval(Time.deltaTime);
       }
       public void interval( float t)
       {
           List<Action< float >> tempIntervalCallFuns = intervalCallFuns;
           foreach (Action< float > intervalCallFun in tempIntervalCallFuns)
           {
               intervalCallFun(t);
           }
           tempIntervalCallFuns = null ;
       }
       /*
        *  添加每帧回调
        *        @param:需要回调的函数
        */
       public void addInterval(Action< float > callFun)
       {
           if (!intervalCallFuns.Equals(callFun))
           {
               intervalCallFuns.Add(callFun);
           } else
           {
               Debug.LogWarning( "add interval already exists!" );
           }
       }
       /*
        *  移除每帧回调函数
        *        @param:需要移除的回调函数
        */
       public void removedInterval(Action< float > callFun)
       {
           List<Action< float >> tempIntervalCallFuns = new List<Action< float >>();
           foreach (Action< float > tempFun in intervalCallFuns)
           {
               if (tempFun != callFun) tempIntervalCallFuns.Add(tempFun);
           }
           intervalCallFuns = tempIntervalCallFuns;
           tempIntervalCallFuns = null ;
       }

设计思想:这个类用字典去存储需要进行每帧运算的函数,然后默认去每帧遍历,并带有从字典中移除函数的功能。

(3)启动程序,启动游戏主循环。

Main类挂在一个GameObject上,负责游戏启动,只负责游戏的主循环,不管其他的操作。

[C#] 纯文本查看 复制代码
?
01
02
03
04
05
06
07
08
09
10
11
12
13
14
<font style= "color:rgb(51, 51, 51)" > using UnityEngine;
public class Main : MonoBehaviour
{
     void Start()
     {
         
     }
     void Update()
     {
         GameController.getInstance().mainLoop();
     }
}</font>

test.cs在他需要的时候去new SkillsMenu_UI(Skills对象)。

new SkillsMenu_UI(gameObject.transform.FindChild("Skills").gameObject);



整个程序就可完美启动起来。


总结,这样的设计多用于解耦和模块的划分。

不用频繁绑定脚本,给public对象绑定对象,一些都在代码中完成。


转载请注明出处。
作者: 大帅纷纭

邮箱:bandit_empire@163.com



文字转载自 如何不绑定脚本且不继承MonoBehaviour做U3D的开发,感谢 大帅纷纭提供好文章



这篇关于如何不绑定脚本且不继承MonoBehaviour做U3D的开发的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/700415

相关文章

C++11委托构造函数和继承构造函数的实现

《C++11委托构造函数和继承构造函数的实现》C++引入了委托构造函数和继承构造函数这两个重要的特性,本文主要介绍了C++11委托构造函数和继承构造函数的实现,具有一定的参考价值,感兴趣的可以了解一下... 目录引言一、委托构造函数1.1 委托构造函数的定义与作用1.2 委托构造函数的语法1.3 委托构造函

Java 继承和多态的作用及好处

《Java继承和多态的作用及好处》文章讲解Java继承与多态的概念、语法及应用,继承通过extends复用父类成员,减少冗余;多态实现方法重写与向上转型,提升灵活性与代码复用性,动态绑定降低圈复杂度... 目录1. 继承1.1 什么是继承1.2 继承的作用和好处1.3 继承的语法1.4 子类访问父类里面的成

SpringBoot开发中十大常见陷阱深度解析与避坑指南

《SpringBoot开发中十大常见陷阱深度解析与避坑指南》在SpringBoot的开发过程中,即使是经验丰富的开发者也难免会遇到各种棘手的问题,本文将针对SpringBoot开发中十大常见的“坑... 目录引言一、配置总出错?是不是同时用了.properties和.yml?二、换个位置配置就失效?搞清楚加

利用Python脚本实现批量将图片转换为WebP格式

《利用Python脚本实现批量将图片转换为WebP格式》Python语言的简洁语法和库支持使其成为图像处理的理想选择,本文将介绍如何利用Python实现批量将图片转换为WebP格式的脚本,WebP作为... 目录简介1. python在图像处理中的应用2. WebP格式的原理和优势2.1 WebP格式与传统

Java继承映射的三种使用方法示例

《Java继承映射的三种使用方法示例》继承在Java中扮演着重要的角色,它允许我们创建一个类(子类),该类继承另一个类(父类)的所有属性和方法,:本文主要介绍Java继承映射的三种使用方法示例,需... 目录前言一、单表继承(Single Table Inheritance)1-1、原理1-2、使用方法1-

Python中对FFmpeg封装开发库FFmpy详解

《Python中对FFmpeg封装开发库FFmpy详解》:本文主要介绍Python中对FFmpeg封装开发库FFmpy,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、FFmpy简介与安装1.1 FFmpy概述1.2 安装方法二、FFmpy核心类与方法2.1 FF

基于Python开发Windows屏幕控制工具

《基于Python开发Windows屏幕控制工具》在数字化办公时代,屏幕管理已成为提升工作效率和保护眼睛健康的重要环节,本文将分享一个基于Python和PySide6开发的Windows屏幕控制工具,... 目录概述功能亮点界面展示实现步骤详解1. 环境准备2. 亮度控制模块3. 息屏功能实现4. 息屏时间

Linux脚本(shell)的使用方式

《Linux脚本(shell)的使用方式》:本文主要介绍Linux脚本(shell)的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录概述语法详解数学运算表达式Shell变量变量分类环境变量Shell内部变量自定义变量:定义、赋值自定义变量:引用、修改、删

Python实例题之pygame开发打飞机游戏实例代码

《Python实例题之pygame开发打飞机游戏实例代码》对于python的学习者,能够写出一个飞机大战的程序代码,是不是感觉到非常的开心,:本文主要介绍Python实例题之pygame开发打飞机... 目录题目pygame-aircraft-game使用 Pygame 开发的打飞机游戏脚本代码解释初始化部

使用Python开发一个现代化屏幕取色器

《使用Python开发一个现代化屏幕取色器》在UI设计、网页开发等场景中,颜色拾取是高频需求,:本文主要介绍如何使用Python开发一个现代化屏幕取色器,有需要的小伙伴可以参考一下... 目录一、项目概述二、核心功能解析2.1 实时颜色追踪2.2 智能颜色显示三、效果展示四、实现步骤详解4.1 环境配置4.