连连看项目实战之二(礼盒动画)

2023-12-06 02:32

本文主要是介绍连连看项目实战之二(礼盒动画),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

推荐阅读:

  •  我的CSDN
  •  我的博客园
  •  QQ群:704621321

       距离上一次更新实战项目之连连看,已经过去近一周了,不要问我这一周经历了什么,做项目容易,不会就问大佬,百度总能解决的。但是,写文章这种事,真的太累了,不仅要考虑些什么,还要考虑怎么写,怎么才能看似通俗易懂但又不缺乏内涵。俗话说做项目一小时,讲解五小时,只有经历过才懂。

       最近忙自己项目真的是累惨了,都没有时间和朋友们撕逼了。今天终于解放了一下自己,继续来与大家分享干货,话不多说,就开干。

       在游戏中,礼盒非常重要,它直接决定了你的收益。但是它的动画和美术也直接决定了你是否回去点击,今天给大家分享礼盒来回移动动画制作。

       在Unity中,动画的制作用NGUI是相当方便的,由于我们项目使用的是UGUI,我们只能代码实现了,在scene场景中,拖动礼盒位置,找到它的至高点和最低点,并记录这两点的位置信息,这两个位置之间的空间是礼盒移动的空间(由于游戏是2D的,因此只会影响Y轴的坐标),如下图是至高点位置信息,y=900:

在这里插入图片描述

如下图是最低点位置信息,y=-450:
在这里插入图片描述
       首先我们来分析一下运动过程,在从上往下的过程中,当到底最低点时,应该改变移动方向,即从下往上移;在从下往上的过程中,当到底至高点时,应该改变移动方向,即从上往下移;如此反复。

       从上面的分析中我们发现,需要一个控制方向的布尔值,需要一个移动的速度,来控制移动的快慢,了解这些之后,我们就可以开始码代码了。

打开StartManager脚本,写下如下代码:

using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.SceneManagement;public class StartManager : MonoBehaviour {public GameObject gift;public float giftSpeed=10;private bool isMoveButton = true;// Use this for initializationvoid Start () {}// Update is called once per framevoid Update () {GiftMove();}private void GiftMove(){if (gift.transform.position.y <= -450 && isMoveButton){isMoveButton = false;}else if (gift.transform.position.y >900 && !isMoveButton){isMoveButton = true;}else{gift.transform.position += (isMoveButton ? Vector3.down : Vector3.up) * Time.deltaTime * giftSpeed;}}public void StartGame(){SceneManager.LoadScene(1);}}

       我们使用变量isMoveButton来控制它是否能往下移动,使用比那辆giftSpeed来控制移动速度,定义为public,时方便在引擎中修改,以调节速度。函数GiftMove()是移动的主要方法,其实就是上面文字分析的代码实现罢了。

这篇关于连连看项目实战之二(礼盒动画)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

网页解析 lxml 库--实战

lxml库使用流程 lxml 是 Python 的第三方解析库,完全使用 Python 语言编写,它对 XPath表达式提供了良好的支 持,因此能够了高效地解析 HTML/XML 文档。本节讲解如何通过 lxml 库解析 HTML 文档。 pip install lxml lxm| 库提供了一个 etree 模块,该模块专门用来解析 HTML/XML 文档,下面来介绍一下 lxml 库

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

如何用Docker运行Django项目

本章教程,介绍如何用Docker创建一个Django,并运行能够访问。 一、拉取镜像 这里我们使用python3.11版本的docker镜像 docker pull python:3.11 二、运行容器 这里我们将容器内部的8080端口,映射到宿主机的80端口上。 docker run -itd --name python311 -p

性能分析之MySQL索引实战案例

文章目录 一、前言二、准备三、MySQL索引优化四、MySQL 索引知识回顾五、总结 一、前言 在上一讲性能工具之 JProfiler 简单登录案例分析实战中已经发现SQL没有建立索引问题,本文将一起从代码层去分析为什么没有建立索引? 开源ERP项目地址:https://gitee.com/jishenghua/JSH_ERP 二、准备 打开IDEA找到登录请求资源路径位置

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount

在cscode中通过maven创建java项目

在cscode中创建java项目 可以通过博客完成maven的导入 建立maven项目 使用快捷键 Ctrl + Shift + P 建立一个 Maven 项目 1 Ctrl + Shift + P 打开输入框2 输入 "> java create"3 选择 maven4 选择 No Archetype5 输入 域名6 输入项目名称7 建立一个文件目录存放项目,文件名一般为项目名8 确定

滚雪球学Java(87):Java事务处理:JDBC的ACID属性与实战技巧!真有两下子!

咦咦咦,各位小可爱,我是你们的好伙伴——bug菌,今天又来给大家普及Java SE啦,别躲起来啊,听我讲干货还不快点赞,赞多了我就有动力讲得更嗨啦!所以呀,养成先点赞后阅读的好习惯,别被干货淹没了哦~ 🏆本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,助你一臂之力,带你早日登顶🚀,欢迎大家关注&&收藏!持续更新中,up!up!up!! 环境说明:Windows 10

Vue3项目开发——新闻发布管理系统(六)

文章目录 八、首页设计开发1、页面设计2、登录访问拦截实现3、用户基本信息显示①封装用户基本信息获取接口②用户基本信息存储③用户基本信息调用④用户基本信息动态渲染 4、退出功能实现①注册点击事件②添加退出功能③数据清理 5、代码下载 八、首页设计开发 登录成功后,系统就进入了首页。接下来,也就进行首页的开发了。 1、页面设计 系统页面主要分为三部分,左侧为系统的菜单栏,右侧

Flutter 进阶:绘制加载动画

绘制加载动画:由小圆组成的大圆 1. 定义 LoadingScreen 类2. 实现 _LoadingScreenState 类3. 定义 LoadingPainter 类4. 总结 实现加载动画 我们需要定义两个类:LoadingScreen 和 LoadingPainter。LoadingScreen 负责控制动画的状态,而 LoadingPainter 则负责绘制动画。