Unity经典游戏教程之:是男人就下100层

版权声明:

  • 本文原创发布于博客园"优梦创客"的博客空间(网址:http://www.cnblogs.com/raymondking123/)以及微信公众号"优梦创客"(微信号:unitymaker)
  • 您可以自由转载,但必须加入完整的版权声明!

是男人就下一百层

一、游戏介绍

是男人就下100层这是一个很受欢迎的小游戏。设计者所取的游戏名称以及它特有的挑战性令几乎所有的男同胞们都一如既往的去暴机,这个游戏同样也吸引了广大的女性,相当有挑战性。

  • 中文名 是男人就下100层
  • 原版名称 man down
  • 游戏类型 休闲游戏

使用方向键左右控制小人,要防止被托上去挤死,防止掉下去摔死以及防止踩到陷阱。

二、场景搭建

  • 导入游戏资源,确保Sprites文件夹里的资源的Texture Type为Sprite

1

  • 打开Sprite Mode的Sprite Editor,对图片进行切割,点击Apply进行保存。

image

image

  • 将云彩(cloud、darkcloud)、背景图(game background)拖进场景,其中背景图为背景(Background),其他作为前景(Foreground)。

image

image

image

三、主角设置

1.拖入主角

将主角拖入场景之中并将其命名为Player,将主角Player设置在Foreground前景层。
image

2.主角动画

打开动画控制器,创建主角的动画walk动画和Idel动画。把主角图片拖到时间轴上其中walk动画每0.01秒一张。Idel动画只需要拖一张。
image

image

3.主角移动的实现

  • 给主角添加刚体(Rigidbody 2D)、添加碰撞器(box Collider 2D)

image

  • 给主角添加脚本Player。给角色设置一个最大速度maxSpeed。设置一个力量force。保存Rigidbody 2D
    通过Horizontal取得水平上的按键0=什么也没按。1=右键。2=左键.

    public float MaxSpeed = 4;
    public float Force = 4;
    public Rigidbody2D mybody;
    
     void PlayerMove(){var x = Input.GetAxis("Horizontal");var xforce = 0.0f;if(x > 0) {xforce = Force*x;myAnimator.SetBool("walk", true);this.gameObject.transform.localScale = new Vector3(1, 1, 1);}else if(x < 0) {xforce = Force*x;myAnimator.SetBool("walk", true);this.gameObject.transform.localScale = new Vector3(-1, 1, 1);}else {xforce = 0;myAnimator.SetBool("walk", false);}var xspeed = mybody.velocity.x;if(Mathf.Abs(xspeed) >= MaxSpeed) {if(xforce * xspeed > 0) {xforce = 0;}}mybody.AddForce(new Vector2(xforce, 0)); }

四、云彩设置

1.将云彩拖入场景

将云彩拖入场景之中并将其命名为cloud和darkcloud将云彩cloud和darkcloud设置在Background背景层。
image

2.设置云彩的生成

给云彩添加碰撞体Box Collider 2D,添加脚本CloudSpawn,建立cloud预制体和主角预制体player_0。将预制体Cloud和player_0拖入,Cloud 、player中。确保min x、max x、Distance Y、LastCloud Y的值。

image

 void CreateClouds(){var worldSize = Camera.main.ScreenToWorldPoint(new Vector3(Screen.width, Screen.height, 0));var worldSize2 = Camera.main.ScreenToWorldPoint(new Vector3(0, 0, 0));minX = worldSize2.x + 1f;maxX = worldSize.x - 1f;lastCloudY = 0;for (var i = 0; i < clouds.Count; i++){var cloud = clouds [i];Vector3 pos;float x = 0;if (controlCloud == 0){x = Random.Range(0, maxX);controlCloud = 1;}else if (controlCloud == 1){x = Random.Range(minX, 0);controlCloud = 2;}else if (controlCloud == 2){x = Random.Range(1, maxX);controlCloud = 3;} else if (controlCloud == 3){x = Random.Range(minX, -1);controlCloud = 0;}pos = new Vector3(x, lastCloudY, 0);cloud.transform.localPosition = pos;lastCloudY -= distanceY;}}

3.设置云彩的特殊功能

设置游戏角色player碰到darkCloud就会死亡

image

五、设置背景的滚动

游戏背景需要不断滚动,先把游戏背景图片再复制两份再把复制的背景拼接好注意不要留缝隙,再给图片添加碰撞体(Box Collider 2D)和脚本BG Scaler

image

image

void Start () {SpriteRenderer sp = this.gameObject.GetComponent<SpriteRenderer>();float width = sp.bounds.size.x;float swidth = Screen.width;float sheight = Screen.height;Debug.Log(swidth+" : "+sheight);float sz = Camera.main.orthographicSize;float sc = sheight/swidth;float cameraHeight = sz*2;float cameraWidth = cameraHeight/(sc);float spriteScale = cameraWidth/width;this.transform.localScale = new Vector3(spriteScale, 2, 0);}

五、角色死亡

设置游戏角色player碰到darkcloud就死亡和碰到游戏上下bound死亡。

    if (other.gameObject.tag == "darkCloud") {var cs = Camera.main.GetComponent<CameraScript> ();cs.enabled = false;transform.localPosition = new Vector3 (1000, 1000, 0);//GameController.Instance.ShowGameOver (score, CoinCount);AudioSource.PlayClipAtPoint(dealSound, transform.position);LifeCount--;GameManager.Instance.CheckGameState (LifeCount, CoinCount, score);}else if (other.gameObject.tag == "bound"){var cs = Camera.main.GetComponent<CameraScript>();cs.enabled = false;transform.localPosition = new Vector3(1000, 1000, 0);//GameController.Instance.ShowGameOver(score, CoinCount);AudioSource.PlayClipAtPoint(dealSound, transform.position);LifeCount--;GameManager.Instance.CheckGameState(LifeCount, CoinCount, score);}

六、背景音乐

先新建一个空节点命名为Music,在文件夹中找到音乐天空之城将其拉入Music选择循环播放(Loop),适当选择音量(Volime)。

image

image

七、扩展方向

  • 增加血量扣血
  • 增加道具吃道具加分
  • 添加敌人
  • 当层数越来越多时候速度越来越快

转载于:https://www.cnblogs.com/raymondking123/p/8424652.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/369646.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Html和websocket初识

一、web框架 众所周知&#xff0c;对于所有的Web应用&#xff0c;本质上其实就是一个socket服务端&#xff0c;用户的浏览器其实就是一个socket客户端。 import socketdef handle_request(client):buf client.recv(1024)client.send(b"HTTP/1.1 200 OK\r\n\r\n")cli…

java lombok 视频_Java开发神器Lombok使用详解

最近正在写SpringBoot系列文章和录制视频教程&#xff0c;每次都要重复写一些Getter/Setter、构造器方法、字符串输出的ToString方法和Equals/HashCode方法等。甚是浪费时间&#xff0c;也影响代码的可读性。因此&#xff0c;今天就给大家推荐一款Java开发神器——Lombok&#…

11-[函数进阶]-闭包

1.什么是闭包&#xff1f; 内部函数对外部函数作用域里变量的引用&#xff08;非全局变量&#xff09;&#xff0c;则称内部函数为闭包。 def outer():n 10def inner():print("inner:", n)return innerval outer() print(val) val() 闭包的意义&#xff1a;返回的…

CSS实现单行、多行文本溢出显示省略号(…)

如果实现单行文本的溢出显示省略号同学们应该都知道用text-overflow:ellipsis属性来&#xff0c;当然还需要加宽度width属来兼容部分浏览。 实现方法&#xff1a; overflow: hidden; text-overflow:ellipsis; white-space: nowrap; 效果如图&#xff1a; 但是这个属性只支持单行…

显示日历的指令:cal

1.显示日历的指令&#xff1a;cal &#xff08;1&#xff09;参数&#xff1a; &#xff08;2&#xff09;实例&#xff1a; 转载于:https://www.cnblogs.com/yfacesclub/p/8434449.html

简单好用的计算器:bc

1.简单好用的计算器&#xff1a;bc &#xff08;1&#xff09;参数&#xff1a; &#xff08;2&#xff09;实例&#xff1a; 执行浮点运算和一些高级函数 设定小数精度&#xff08;数值范围&#xff09; 进制转换 执行结果为&#xff1a;11000000&#xff0c;这是用bc将十进制…

block,inline,inline-block的区别

最近正在复习&#xff0c;紧张地准备几天后的笔试&#xff0c;然后刚好看到这个地方。 block&#xff1a;块级元素&#xff0c;会换行&#xff0c;如div,p,h1~h6,table这些&#xff0c;可以设置宽高&#xff1b; inline:行内元素&#xff0c;不换行&#xff0c;挤在一行显示&am…

anyproxy抓取移动http、https请求

windows下安装AnyProxy抓取移动App Http请求AnyProxy是阿里巴巴基于 Node.js 开发的一款开源代理服务器。做为中间代理服务器&#xff0c;它可以收集所有经过它的http请求流量&#xff08;包括https明文内容&#xff09;&#xff1b;它提供了友好的web界面&#xff0c;便于直观…

Windows 10 IoT Core 17101 for Insider 版本更新

除夕夜&#xff0c;微软发布了Windows 10 IoT Core 17101 for Insider 版本更新&#xff0c;本次更新只修正了一些Bug&#xff0c;没有发布新的特性。已知的问题: F5 driver deployment from Visual Studio does not work on IoT Core.F5 application deployment of headed f…

Spring Batch中的块处理

大数据集的处理是软件世界中最重要的问题之一。 Spring Batch是一个轻量级且强大的批处理框架&#xff0c;用于处理数据集。 Spring Batch Framework提供了“面向TaskletStep”和“面向块”的处理风格。 在本文中&#xff0c;将解释面向块的处理模型。 此外&#xff0c;绝对建…

type=file文件上传H5新特性

1、语法 <input name"myFile" type"file"> 2、属性&#xff08;以下三个仅 HTML5支持&#xff0c;因此存在兼容性问题&#xff09;&#xff08;1&#xff09;multiple &#xff1a;表示用户是否可以选择多个值。multiple只能用于typefile和typeemail…

epoll学习

一、epoll_create #include <sys/epoll.h>int epoll_create(int size); int epoll_create1(int flags); 返回&#xff1a;成功非负文件描述符&#xff0c;-1出错size:内核监听数目一共多大 创建一个epoll接口&#xff0c;size参数和select不同&#xff0c;不是fd1&#x…

background使用

background-position 有两个参数&#xff0c;定义背景图片起始位置可选值有&#xff1a; center top left right bottom px % background-size 可以用 px % 设定其宽高 值 cover 完全覆盖背景区域 contain 适应背景区域 background-origin 背景图片可以放置于 content-bo…

java牛客排序算法题_《剑指offer》面试题28:字符串的排列(牛客网版本) java...

输入一个字符串,按字典序打印出该字符串中字符的所有排列。例如输入字符串abc,则打印出由字符a,b,c所能排列出来的所有字符串abc,acb,bac,bca,cab和cba。输入描述: 输入一个字符串,长度不超过9(可能有字符重复),字符只包括大小写字母。这里尤其需要注意2点&#xff1a;1.所有组…

前端之bootstrap模态框

简介&#xff1a;模态框&#xff08;Modal&#xff09;是覆盖在父窗体上的子窗体。通常&#xff0c;目的是显示来自一个单独的源的内容&#xff0c;可以在不离开父窗体的情况下有一些互动。子窗体可提供信息、交互等。 Modal简介Modal实现弹出表单Modal实现删除提示框其他用法…

js方式调用php_举例说明JS调用PHP和PHP调用JS的方法

举例说明JS调用PHP和PHP调用JS的方法在学习任何一门编程语言&#xff0c;我们都会听到调用这个词&#xff0c;那么&#xff0c;在javascript中是如何调用php的呢&#xff1f;在php中也可以调用js吗&#xff1f;下面就让我们一起来看看吧。1、JS方式调用PHP文件并取得PHP中的值举…

如何在Hexo中实现自适应响应式相册功能

用最清晰简洁的方法整合一个响应式相册效果 技术选型 由于我选用的主题使用了fancyBox作为图片弹出展示的框架&#xff0c;查看后表示很不错&#xff0c;能满足需要http://fancyapps.com/fancybox/3/图片加载可能会太慢&#xff0c;所以还需要一个图片延迟加载插件 Lazyload想使…

适用于MongoDB和Mongometer的SpiderMonkey至V8

通过10gen将MongoDB 2.3 / 2.4的默认JavaScript引擎从SpiderMonkey切换到V8&#xff0c;我想我将借此机会使用mongometer比较这些发行版的相对性能。 作为安全专家&#xff0c;我真的应该首先研究“ 其他身份验证功能” ……嘿。 我将记录比较过程中所采取的步骤&#xff08;包…

百度联盟广告如何理解按父容器宽度

创建百度联盟广告位的时候&#xff0c;选择按父容器宽度展示&#xff0c;但是在加入之后&#xff0c;查看代码发现广告的宽度为页面的宽度&#xff0c;并不是希望的父级的宽度&#xff0c; 如图在这里查看&#xff1a; 解析&#xff1a;百度联盟广告自动生成的div按父级的div宽…