当前位置: 首页 > news >正文

学习游戏制作记录(实现克隆攻击的克隆复制和水晶代替克隆)8.3

1.实现克隆攻击的克隆复制

Clone_Skill脚本:

    [Header("Can Duplicate Clone")]
[SerializeField]private bool canDuplicateClone;//是否可以进行复制
[SerializeField] private float chanceToDuplicateClone;//克隆的概率

    public void  CreatClone(Transform newtransform,Vector3 offset)
{
GameObject newclone= GameObject.Instantiate(ClonePrefab,newtransform.position,Quaternion.identity);

        newclone.GetComponent<Clone_Skill_Control>().SetupClone(newtransform, cloneDuration, canAttack,offset,FindClosetEnemy(newclone.transform),canDuplicateClone,chanceToDuplicateClone);
}

//传入参数到Clone_Skill_Control脚本中

Clone_Skill_Control脚本:

    private bool canDuplicateClone;
private float chanceToDuplicateClone;

    private float facingDir=1;//朝向

    private void FacingClosestEnemy()
{

        if(closestEnemy!=null)
{
if(transform.position.x>closestEnemy.position.x)
{
facingDir = -1;//翻转时克隆朝向为-1
transform.Rotate(0, 180, 0);

}

        }
}

    private void AttackTrigger()
{
Collider2D[] collider2Ds = Physics2D.OverlapCircleAll(attackCheck.position, attackCheckRadius);

        foreach (var hit in collider2Ds)
{
if (hit.GetComponent<Enemy>() != null)
{
hit.GetComponent<Enemy>().Damage();


                if(canDuplicateClone)//如果可以复制
{
if(Random.Range(0,100)<chanceToDuplicateClone)
{
SkillManage.instance.clone.CreatClone(hit.transform,new Vector3(.5f*facingDir,0));//在克隆的朝向偏移位置处重新生成克隆
}
}
}
}
}

这样可以形成一种两面夹击的效果

2.实现水晶代替克隆

Crystal_Skill脚本:

    public void CreateCrystal()//创建水晶的函数,从已有代码中提取出来
{
currentCrystal = Instantiate(crystalPrefab, player.transform.position, Quaternion.identity);

        Crystal_Skill_Control newcrystalScript = currentCrystal.GetComponent<Crystal_Skill_Control>();

        newcrystalScript.SetupCrystal(crystalDuration, canExplode, canMoveToEnemy, moveSpeed, FindClosetEnemy(currentCrystal.transform));
}

Clone_Skill脚本:

  [Header("Crystal Instead Clone")]
[SerializeField] private bool canCrystalInsteadClone;

    public void  CreatClone(Transform newtransform,Vector3 offset)
{
if(canCrystalInsteadClone)//如果可以替换则只执行创建水晶的功能
{
SkillManage.instance.crystal.CreateCrystal();
return;
}


        GameObject newclone= GameObject.Instantiate(ClonePrefab,newtransform.position,Quaternion.identity);

        newclone.GetComponent<Clone_Skill_Control>().SetupClone(newtransform, cloneDuration, canAttack,offset,FindClosetEnemy(newclone.transform),canDuplicateClone,chanceToDuplicateClone);
}

3.实现黑洞技能里克隆水晶并向随机敌人射击

Blackhole_Skill_Control脚本:

    public float GetBlackholeRedius()//返回水晶的检测范围,与黑洞半径保持一致
{
return maxSize / 2;
}

Crystal_Skill_Control脚本:

   [SerializeField] private LayerMask WhatIsEnemy;//敌人图层

    public void ChooseRandomEnemy()
{
float radius = SkillManage.instance.blackhole.GetBlackholeRedius();//检测范围内敌人
Collider2D[] collider2Ds = Physics2D.OverlapCircleAll(transform.position,radius,WhatIsEnemy);


        if(collider2Ds.Length > 0 )
{
closestTarget = collider2Ds[Random.Range(0,collider2Ds.Length)].transform;//随机选取

        }
}

Crystal_Skill脚本:

 public void CurrentCystalChooseRandomEnemy() => currentCrystal.GetComponent<Crystal_Skill_Control>().ChooseRandomEnemy();//其它技能中可以调用的函数

Blackhole_Skill_Control脚本:
if(SkillManage.instance.clone.canCrystalInsteadClone)//SetupBlackhole()函数中
{
playerCanDisper = false;//设置发射水晶时玩家不消失
}

            if (SkillManage.instance.clone.canCrystalInsteadClone)//AttackLogic()函数中
{
SkillManage.instance.crystal.CreateCrystal();
SkillManage.instance.crystal.CurrentCystalChooseRandomEnemy();//创建水晶并选取随机敌人
}
else
{

            SkillManage.instance.clone.CreatClone(EnemyTarget[randomIndex], new Vector3(xoffest, 0));

            }

http://www.lryc.cn/news/609124.html

相关文章:

  • 【gradle】插件那些事
  • 7.28-8.3周报
  • C的数据类型与变量
  • 高质量数据集|从武汉光谷《面向科技情报大模型的高质量数据集建设》招标项目谈起
  • Matlab算法编程示例4:数值解法求解常微分方程的代码实例
  • deep research|从搜索引擎到搜索助手的实践(一)
  • Android 之 MVC架构
  • TVS二极管数据手册解读
  • kraft的设计与实现
  • 【数据结构】队列的顺序存储与链式存储(C语言版)
  • 深度学习中的模型知识蒸馏
  • 【Bluetooth】【Transport层篇】第三章 基础的串口(UART)通信
  • 文本换行问题
  • Jetson Orin NX/NANO+ubuntu22.04+humble+MAVROS2安装教程
  • 【从零开始学习Redis】初识Redis
  • [Oracle] DUAL数据表
  • CAP 理论笔记
  • 推荐系统学习笔记(九)曝光过滤 Bloom Filter
  • 【领域热点】【Vue】Vue 与 WebAssembly:前端性能优化的黄金搭档
  • 自动驾驶中的传感器技术18——Camera(9)
  • Connection refused: no further information: localhost/127.0.0.1:2375
  • docker 可用镜像列表(长期免费)
  • Azure DevOps — Kubernetes 上的自托管代理 — 第 4 部分
  • Docker环境离线安卓安装指南
  • centos9 安装docker engine
  • C++ : 反向迭代器的模拟实现
  • Java基本技术讲解
  • 深入解析C++函数重载:从原理到实践
  • 【1】WPF界面开发入门—— 图书馆程序:登录界面设计
  • K8S部署ELK(五):集成Kibana实现日志可视化