时隔3年,我又开始继续写这个系列的帖子了,也不知道是会写完全系列,还是再次夭折。

废话不多。直接开始主题了

主要实现的功能点包含这些内容:通过摇杆控制角色进行八方位移动,并按照各方位播放对应移动动画

效果图如下:



本次案例其实都是拼凑网上别人的一些现成代码,然后进行整合梳理

涉及到的相关内容如下:

参考代码如下:

1.Cocos Creator 地图滚动&摄像机人物跟随

地址:https://www.bilibili.com/video/BV1et411J7iC

2.joystick摇杆控件

代码地址:https://github.com/YunYouJun/cocos-creator-joystick

在线演示:https://www.yunyoujun.cn/cocos-creator-joystick/

3. Animation动画创建

教程地址:http://www.cocoachina.com/bbs/read.php?tid-458312.html

我其实也只是代码的搬运工,通过对以上三部分的整合,最终就实现了我想要的效果。

开始介绍项目

场景结构



场景中分别包含了以下控件:

  • MainCamera 负责绘制UI
  • RoleCamera 负责绘制角色(之后的遥感其实也是控制这个摄像头的坐标移动)
  • MapView 地图(里面包含了一些地图相关的内容,在参考代码里面的视频有做解释,我这里不做详细介绍了)
  • Role 主角,主要的控件,相关的控制代码都挂在主角上面
  • joystick 摇杆控件,该部分代码可以直接通过参考代码2去下载,然后直接使用即可。

代码结构



其实需要讲解的代码也就两部分:joystick.js 与Role.JS

Joystick组件

属性(Properties)

  • dot :摇杆操纵点
  • ring :摇杆背景节点
  • joystickType :触摸类型(跟随,固定两种)
  • directionType :方向类型(4方向,8方向,全方位)
  • _stickPos :摇杆所在位置
  • _touchLocation :触摸位置

函数(Functions)

  • _initTouchEvent : 初始化
  • _onChangeJoystickType : 更改触摸类型
  • _touchStartEvent : 当手指按下时触发,判断触摸类型,并根据触摸类型执行相应动作
  • _touchMoveEvent : 当手指按住摇杆控件时持续触发,先判断按下的位置是否相同,如果相同,则不做处理。
  • _touchEndEvent : 当手指抬起时触发,结束相关动作

Role组件

主要函数(Functions)

  • _updateCameraPosition :更新摄像机位置
  • _getTilePos : 计算摇杆角度
  • onTouchMove : 按住摇杆时持续触发

  • getCalculaAngle : 将摇杆移动的坐标进行角度转换,转换之后用来判断朝哪个方向移动了

  • getfwinfo : 根据角度判断角色应该朝哪个方向

  • move : 移动摄像头

  • update :

主要逻辑顺序

当用户按住摇杆时触发onTouchMove 事件,判断移动方向,切换角色动画。

最后就是贴代码了

链接:https://share.weiyun.com/8WRBYpR5 密码:jny2wj

CocosCreator游戏开发(四)实现摇杆控制角色功能的更多相关文章

  1. CocosCreator游戏开发---菜鸟学习之路(一)

    PS(废话): 辞职后在家好久好久了,久到经济不允许了,接着就准备再次出去找工作了,然而工作哪有那么好找,特别是像我这种菜鸟.而且我还准备转行,准备去做游戏,技能等级接近于0,那工作就更难找了.既然如 ...

  2. 喵的Unity游戏开发之路 - 玩家控制下的球的滑动

  3. CocosCreator游戏开发(五)实现技能按钮

    在上一篇中,已经顺利的实现了通过摇杆控件来控制角色移动的例子 这一篇内容中,主要来实现通过摇杆来操作技能施法位置的功能 代码效果如下: 在最初的想法中,我是想将摇杆与技能施法范围以及施法位置做成一个组 ...

  4. Unity3D 游戏开发构架篇 ——输入控制

    临近毕业之初.进入Unity3D这个行业,是一家小工作室.老板人非常不错,公司氛围也非常单纯.近期公司开发一款小游戏,初次上手,颇多周折,记录下自己的开发心得.主要涉及一些设计理念,互相交流. 先说下 ...

  5. CocosCreator游戏开发---菜鸟学习之路(二)SocketIO简易教程

    请先参考教程司令部-SocketIO教程进行相关操作 开发完成后部分用户会出现持续输出 a userConnected的BUG 如下图所示 经过一段时间的BUG检查终于发现了问题所在.每个人碰到的情况 ...

  6. CocosCreator游戏开发---菜鸟学习之路(三)如何在CocosCreator中使用Pomelo

    PS(废话): 这段时间都在研究网易的Pomelo框架,作为新手小白,自然遇到了不少坑爹的事情.(当然也有可能是因为自己技术不过关的原因所以导致在很多基础的问题上纠结了很久.)网上也搜索了好久,但是基 ...

  7. [Unity3D]Unity3D圣骑士模仿游戏开发传仙灵达到当局岛

    大家好,我是秦培.欢迎关注我的博客.我的博客地址blog.csdn.net/qinyuanpei. 在前面的文章中.我们分别实现了一个自己定义的角色控制器<[Unity3D]Unity3D游戏开 ...

  8. 整理了一下浅墨大神的Visual C++/DirectX 9.0c的游戏开发手记

    还是非常棒的博客,只是没有一个文件夹.所以自己做了一个山寨文件夹在这里.便于随时查找. 前面31期从略. [Visual C++]游戏开发笔记三十二 浅墨DirectX提高班之中的一个 DirectX ...

  9. [Android游戏开发]游戏框架的搭建

    通常情况下,游戏开发的基本框架中,一般包括以下模块: 窗口管理(Window management):该模块负责在Android平台上创建.运行.暂停.恢复游戏界面等功能. 输入模块(Input):该 ...

随机推荐

  1. Python JSON的基本使用

    Python JSON的基本使用 一.json格式介绍 JSON(JavaScript Object Notation) 通用的数据类型,易于人阅读和编写. 跟字典有些类似,形式也是key-value ...

  2. 无法安装 VMware Tools。尝试访问安装 VMware Tools 所需的图像文件“/usr/lib/vmware/isoimages/linuxPreGlibc25.iso”时出错: 2 (No such file or directory)。请参考产品文档或知识库文章 2129825,了解关于如何获取该客户机操作系统的 VMware Tools 软件包的详细信息。

    无法安装 VMware Tools.尝试访问安装 VMware Tools 所需的图像文件"/usr/lib/vmware/isoimages/linuxPreGlibc25.iso&quo ...

  3. Python网络编程基础 PDF 完整超清版|网盘链接内附提取码下载|

    点此获取下载地址提取码:y9u5 Python网络编程最好新手入门书籍!175个详细案例,事实胜于雄辩,Sockets.DNS.Web Service.FTP.Email.SMTP.POP.IMAP. ...

  4. CSS两列布局的N种实现

    一.什么是两列布局 两列布局分为两种,一种是左侧定宽.右侧自适应,另一种是两列都自适应(即左侧宽度由子元素决定,右侧补齐剩余空间).在CSS面试题里面属于常考题,也是一个前端开发工程师必须掌握的技能, ...

  5. Python math 模块、cmath 模块

    Python math 模块.cmath 模块 Python 中数学运算常用的函数基本都在 math 模块.cmath 模块中.高佣联盟 www.cgewang.com Python math 模块提 ...

  6. CF R 632 div2 1333D Challenges in school №41

    LINK:Challenges in school №41 考试的时候读错题了+代码UB了 所以wa到自闭 然后放弃治疗. 赛后发现UB的原因是 scanf读int类型的时候 宏定义里面是lld的类型 ...

  7. MySQL主从同步-原理&实践篇

    来源:Onegoleya 简栈文化 什么是mysql的主从复制? MySQL 主从复制是指数据可以从一个MySQL数据库服务器主节点复制到一个或多个从节点.MySQL 默认采用异步复制方式,这样从节点 ...

  8. 迷之自信的Single_User Mode

    Alter database Set Single_User 对于任何DBA来说,恐怕都不陌生.在我们需要获取数据库独占访问权来做一些数据库紧急维护的时候,这可能是大多数DBA的首选,但它真的可以实现 ...

  9. JAVA程序设计环境

    JDK ,Java Development Kit(Java开发工具包) JRE ,Java Runtime Environment(Java运行时环境) SE   ,Standard Edition ...

  10. Git本地仓库基本操作

    目录 设置姓名和邮箱 创建仓库 提交本地代码 .gitignore git add git commit git status git diff 查看提交记录 撤销未提交的修改 版本回退 设置姓名和邮 ...