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

学习游戏制作记录(克隆技能)7.25

1.实现冲刺后在原角色位置留下克隆体的功能

我们需要在玩家进入冲刺状态时创建一个对象,这可以使用预制体来实现

首先创建一个玩家的预制体,并给它装载动画控制器,拖入待机和攻击动画,最后把整个拖入你的预制体文件夹。

修改Player脚本:


public SkillManage skill {  get; private set; }

skill = SkillManage.instance;//简化代码,后面只需要写skill.即可

创建Clone_Skill_Control脚本:

    private SpriteRenderer sr;

    [SerializeField] private float CloneTimer;//克隆计时器
[SerializeField] private float colorloosingSpeed;//克隆体消失的速度


    private void Awake()
{
sr = GetComponent<SpriteRenderer>();
}

    private void Update()
{
CloneTimer -= Time.deltaTime;

        if(CloneTimer < 0 )
{
sr.color=new Color(1,1,1,sr.color.a-Time.deltaTime*colorloosingSpeed);//更改透明度
}

                if(sr.color.a<=0 )
{
Destroy(gameObject);//透明度消失则删除克隆体
}
}

    public void SetupClone(Transform newtransform,float clonduration)
{
transform.position = newtransform.position;//更改克隆体的位置,确保在玩家的位置
CloneTimer = clonduration;
}

创建Clone_Skill脚本并在SkillManage脚本中初始化:

    [Header("Clone info")]
[SerializeField] private GameObject ClonePrefab;//预制体
[SerializeField] private float cloneDuration;//克隆持续时间

    public void  CreatClone(Transform newtransform)
{
GameObject newclone= GameObject.Instantiate(ClonePrefab);//创建预制体对象

        newclone.GetComponent<Clone_Skill_Control>().SetupClone(newtransform, cloneDuration);//更改位置和冷却时间
}

PlayerDashState脚本:

Enter中:

_Player.skill.clone.CreatClone(_Player.transform);//进入时调用创建预制体函数

演示:

 

2.实现克隆体的攻击功能

首先创建动画参数AttackNumber,大于0时进入空状态,等于1,2,3时分别播放攻击动画123

Clone_Skill脚本:

[SerializeField] private bool canAttack;//克隆体是否可以攻击

 newclone.GetComponent<Clone_Skill_Control>().SetupClone(newtransform, cloneDuration, canAttack);//传入上面参数

Clone_Skill_Control脚本:

private Animator anim;//动画组件

 [SerializeField] private Transform attackCheck;//克隆体的攻击检测,需要自行修改预制体,添加攻击检测的子对象
[SerializeField] private float attackCheckRadius = .8f;

 private Transform closestEnemy;//检测最近的敌人

  private void AnimationTrigger()//攻击动画结束时调用的函数,克隆体删除
{
CloneTimer = -1f;
}

  private void AttackTrigger()//攻击动画中的一帧调用的函数
{
Collider2D[] collider2Ds = Physics2D.OverlapCircleAll(attackCheck.position, attackCheckRadius);

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

  private void FacingClosestEnemy()//克隆体转向的函数,在SetupClone()中调用
{
Collider2D[] collider2Ds = Physics2D.OverlapCircleAll(transform.position,25);
float closestEnemyDistance = Mathf.Infinity;//设置最小距离
foreach (var hit in collider2Ds)
{

if (hit.GetComponent<Enemy>() != null)
{
float distanceToEnemy=Vector2.Distance(transform.position,hit.transform.position);//计算与每个敌人的距离

              if(distanceToEnemy < closestEnemyDistance) 

closestEnemyDistance = distanceToEnemy;//更新最小距离
closestEnemy = hit.transform;//记录最近的敌人的组件
}
}
}
if(closestEnemy!=null)
{
if(transform.position.x>closestEnemy.position.x)//实现翻转
{
transform.Rotate(0, 180, 0);
}

      }
}

演示:

http://www.dtcms.com/a/298003.html

相关文章:

  • 踩坑记录:因版本不匹配导致 Boost 1.85 编译失败的完整解决过程
  • 二层隧道协议(PPP、PPTP、L2TP)
  • STM32的WI-FI通讯(HAL库)
  • 2025-07-25设置使用权限N次内
  • 《计算机组成原理与汇编语言程序设计》实验报告一 基本数字逻辑及汉字显示
  • OpenGLRender开发记录(二): 阴影(shadowMap,PCF,PCSS)
  • 升级目标API级别到35,以Android15为目标平台(三 View绑定篇)
  • Fluent自动化仿真(TUI命令脚本教程)
  • SQL Server数据库
  • 破局与重构:King’s LIMS 引领电子行业实验室智能化转型
  • 从kHz到GHz:晶振频率范围如何决定其应用场景
  • 打破渠道壁垒:SEO+ASO协同作战实现用户获取量翻倍
  • Spring Cloud Gateway 服务网关
  • Docker 实战大纲
  • HC32 睡眠
  • SpringBoot整合Liquibase提升数据库变更的可控性、安全性、自动化程度(最详细)
  • Claude Code 基于 VUE + KonvaJS 实现海报生成器(附源码)
  • 基于springboot的候鸟监测管理系统
  • 杂谈:前端开发中的常见问题
  • App拉起:唤醒即达,告别繁琐操作
  • C++实战:数据标准化高效实现
  • 自动化测试学习?
  • 零基础学Triton(1) Triton还需要学习吗?
  • Tailwind CSS 自定义工具类与主题配置指南
  • U盘提示格式化怎么取出里面的文件
  • 如何解决pip安装报错ModuleNotFoundError: No module named ‘streamlit’问题
  • OpenTelemetry学习笔记(十二):在APM系统中,属性的命名空间处理遵循规则
  • React框架的Ant Design漫游组件的使用
  • AKS部署.Net Shopping
  • 关于网络模型