1、简单并用程序验证

  • 游戏对象运动的本质是什么?

    本质上是游戏对象坐标的变换

  • 使用三种方法实现物体的抛物线运动

    1. Vector3.MoveTowards

      private float step = Time.deltaTime;// Update is called once per frame
      void Update () {float step = Time.deltaTime;if (flag) {if (origin - 100 * Time.deltaTime < 0.00001) {Vector3 target = transform.position + Vector3.right * Time.deltaTime + Vector3.down * Time.deltaTime;transform.position = Vector3.MoveTowards(transform.position, target, step);} else if (origin - 200 * Time.deltaTime < 0.00001) {Vector3 target = transform.position + Vector3.right * Time.deltaTime + Vector3.up * Time.deltaTime;transform.position = Vector3.MoveTowards(transform.position, target, step);} else {flag = false;}origin += Time.deltaTime;} else { /*backward*/ }
      }
      
    2. Vector3.Lerp

      void Update {if (flag) {if (origin - 100 * Time.deltaTime < 0.00001) {Vector3 target = transform.position + Vector3.right * Time.deltaTime + Vector3.down * Time.deltaTime;transform.position = Vector3.Lerp(transform.position, target, 1);} else if (origin - 200 * Time.deltaTime < 0.00001) {Vector3 target = transform.position + Vector3.right * Time.deltaTime + Vector3.up * Time.deltaTime;transform.position = Vector3.Lerp(transform.position, target, 1);} else {flag = false;}origin += Time.deltaTime;} else { /*backward*/ }
      }
      
    3. 利用transform属性

      private float origin = Time.deltaTime;
      private bool flag = true;// Update is called once per frame
      void Update () {if (flag) {if (origin - 100 * Time.deltaTime < 0.00001) {transform.position += Vector3.down * Time.deltaTime;transform.position += Vector3.right * Time.deltaTime;} else if (origin - 200 * Time.deltaTime < 0.00001) {transform.position += Vector3.up * Time.deltaTime;transform.position += Vector3.right * Time.deltaTime;} else {flag = false;}origin += Time.deltaTime;} else {if (origin - 100 * Time.deltaTime > 0.00001) { transform.position += Vector3.down * Time.deltaTime;transform.position += Vector3.left * Time.deltaTime;} else if (origin > 0.00001) {transform.position += Vector3.up * Time.deltaTime;transform.position += Vector3.left * Time.deltaTime;} else {flag = true;}origin -= Time.deltaTime;}
      }
      
  • 写一个程序,实现一个完整的太阳系, 其他星球围绕太阳的转速必须不一样,且不在一个法平面上。

    实现太阳系,使用RotateRound函数即可,第一个参数是选择旋转的中心,第二个参数是选择旋转围绕的方向,为了使每个星球在不同法平面旋转,需要适当调整这个值。具体代码如下:

    move.cs

    using System.Collections;
    using System.Collections.Generic;
    using UnityEngine;public class move : MonoBehaviour
    {public Texture2D img;public Transform sun;public Transform waterplanet;public Transform earth;//public Transform moon;public Transform goldplanet;public Transform mars;public Transform woodplanet;public Transform mudplanet;public Transform tianwang;public Transform haiwang;// Start is called before the first frame updateprivate void OnGUI(){//GUIStyle bg = new GUIStyle();//bg.normal.background = img;//GUI.Label(new Rect(0, 0, 1024, 781), "", bg);}// Update is called once per framevoid Update(){sun.Rotate(Vector3.up * 3 * Time.deltaTime);waterplanet.RotateAround(sun.position, new Vector3(0,1,1), 200 * Time.deltaTime);goldplanet.RotateAround(sun.position, new Vector3(0, 2, 1), 100 * Time.deltaTime);earth.RotateAround(sun.position, Vector3.up, 50 * Time.deltaTime);//moon.RotateAround(earth.position, new Vector3(0,0.1f,0.1f), 100 * Time.deltaTime);mars.RotateAround(sun.position, new Vector3(0, 2, 2), 40 * Time.deltaTime);woodplanet.RotateAround(sun.position, new Vector3(0, 1, 2), 30 * Time.deltaTime);mudplanet.RotateAround(sun.position, new Vector3(0, 3, 2), 20 * Time.deltaTime);tianwang.RotateAround(sun.position, new Vector3(0, 3, 1), 10 * Time.deltaTime);haiwang.RotateAround(sun.position, new Vector3(0, 2, 4), 5 * Time.deltaTime);}
    }

    earth_moon.cs

    地月是一个子系统,需要单独来写。

    using System.Collections;
    using System.Collections.Generic;
    using UnityEngine;public class earth_moon : MonoBehaviour
    {public Transform earth;public Transform moon;// Start is called before the first frame updatevoid Start(){}// Update is called once per framevoid Update(){moon.RotateAround(earth.position, Vector3.up, 100 * Time.deltaTime);}
    }

    最后运行截图如下:

2、编程实践

  • 阅读以下游戏脚本

Priests and Devils

Priests and Devils is a puzzle game in which you will help the Priests and Devils to cross the river within the time limit. There are 3 priests and 3 devils at one side of the river. They all want to get to the other side of this river, but there is only one boat and this boat can only carry two persons each time. And there must be one person steering the boat from one side to the other side. In the flash game, you can click on them to move them and click the go button to move the boat to the other direction. If the priests are out numbered by the devils on either side of the river, they get killed and the game is over. You can try it in many > ways. Keep all priests alive! Good luck!

程序需要满足的要求:

  • play the game ( http://www.flash-game.net/game/2535/priests-and-devils.html )

  • 列出游戏中提及的事物(Objects)

    河流、小船、牧师、魔鬼、岸

  • 用表格列出玩家动作表(规则表),注意,动作越少越好

    牧师、魔鬼 上船、下船
    载着人物驶向对岸
  • 请将游戏中对象做成预制

  • 在 GenGameObjects 中创建 长方形、正方形、球 及其色彩代表游戏中的对象。
  • 使用 C# 集合类型 有效组织对象
  • 整个游戏仅 主摄像机 和 一个 Empty 对象, 其他对象必须代码动态生成!!! 。 整个游戏不许出现 Find 游戏对象, SendMessage 这类突破程序结构的 通讯耦合 语句。 违背本条准则,不给分
  • 请使用课件架构图编程,不接受非 MVC 结构程序
  • 注意细节,例如:船未靠岸,牧师与魔鬼上下船运动中,均不能接受用户事件

实现

使用MVC结构进行架构。

  • model

    • Boat
    • Character
    • Coast
    • River
  • View

    • UserGUI

      用于展示游戏界面,以及用户点击事件

  • Controller

    • BoatController

      控制船的移动,以及船上人的信息

    • Charactercontroller

      人物的动作:上下船

    • CoastController

      河岸承担了与船的交互,以及人员的增减

    • director

        public class Director : System.Object{private static Director _instance;public ISceneController CurrentSecnController { get; set; }public static Director GetInstance(){return _instance ?? (_instance = new Director());}}
    

    ​ 所有游戏只有一个实例,就是通过这个类来实例化的。

    • Interfaces

    • KernelController

      主要的控制器,控制了船的移动和游戏输赢的判定,它是一个Director类,控制着游戏的创建、加载等动作

    • Move

      所有对象移动的动作

项目地址
视频地址

3D-太阳系、牧师与恶魔小游戏相关推荐

  1. 牧师与恶魔过河游戏——智能提示

    前言 这次实现一个含提示功能的牧师与恶魔过河小游戏,主要在上一个版本的牧师与恶魔小游戏上进行更改,通过增加一个状态计算和改版了得寻路算法,实现向玩家提示如何胜利完成游戏.游戏主体实现思路见上一篇博客- ...

  2. Unity牧师与魔鬼小游戏(动作分离版)

    Unity牧师与魔鬼小游戏(动作分离版) 前言 这是中大计算机学院3D游戏编程课的一次作业,在这里分享一下设计思路. 主要代码上传到了gitee上,请按照后文的操作运行. 项目地址:https://g ...

  3. Unity牧师与魔鬼小游戏

    Unity牧师与魔鬼小游戏 前言 这是中大计算机学院3D游戏编程课的一次作业,在这里分享一下设计思路. 主要代码上传到了gitee上,请按照后文的操作运行. 项目地址:https://gitee.co ...

  4. Unity使用MVC架构制作牧师与魔鬼小游戏

    Unity使用MVC架构制作牧师与魔鬼小游戏 MVC架构简介 MVC概述 MVC全名是Model View Controller,是模型(model)-视图(view)-控制器(controller) ...

  5. 3D游戏编程与设计 PD(牧师与恶魔)过河游戏智能帮助实现

    3D游戏编程与设计 P&D(牧师与恶魔) 过河游戏智能帮助实现 文章目录 3D游戏编程与设计 P&D(牧师与恶魔) 过河游戏智能帮助实现 一.作业与练习 二.设计简述 1. 状态图基础 ...

  6. 3D游戏编程与设计 HW 4.5 牧师与恶魔(动作分离版)

    3D游戏编程与设计 HW 4.5 牧师与恶魔(动作分离版) 文章目录 3D游戏编程与设计 HW 4.5 牧师与恶魔(动作分离版) 1.作业要求 2.游戏制作 ① 设计思路 ② 设计代码 一.Actio ...

  7. 牧师与恶魔——动作分离版

    Priests and Devils --动作分离版 完整工程文件在github(https://github.com/JennySRH/3DGame/tree/master/PriestsAndDe ...

  8. AR小游戏 牧师与恶魔

    AR小游戏 牧师与恶魔 前言 这是中山大学数据科学与计算机学院2019年3D游戏编程与设计的第十一次作业 所有项目与代码已上传至github当中,欢迎大家访问. github个人主页: https:/ ...

  9. 基于Unity3D开发的3D小游戏牧师与魔鬼

    3D小游戏牧师与魔鬼 作业要求 编程实践,3D小游戏:牧师与魔鬼 列出游戏中提及的事物(Objects) 用表格列出玩家动作表(规则表),注意,动作越少越好 请将游戏中对象做成预制,并在 GenGam ...

最新文章

  1. 在VS中建立一个易于管理的C++工程
  2. dash plotly
  3. Python学习笔记(三)——条件语句、循环语句
  4. 9 Unconstrained minimization
  5. 界面上下固定_【技术浅析】三通道机床自动上下料控制方法应用
  6. NYOJ最长公共子序列(dp)
  7. 为什么现在那么多人都想做电商?
  8. Linux环形缓冲区原理
  9. extjs 如何将局部的变量变为全局变量
  10. 《剑指offer》-统计整数二进制表示中1的个数
  11. python 用mysqldb方式操作数据库
  12. SWT FontFieldEditor使用
  13. 土地利用转移矩阵--更新中
  14. 29个用于石油和天然气等行业的最佳 GIS 软件
  15. 分享8个强大的黑帽子自学网站(附:最常用的9种工具)
  16. 从输入url到页面返回到底发生了什么
  17. [组合数学] NC13611树 (逆元的计算)
  18. 混沌的有关概念——1
  19. Word如何拆分单元格
  20. 大学计算机基础教学大纲,大学计算机基础教学大纲

热门文章

  1. 麒麟linux修改密码,麒麟堡垒机密码定期修改手册
  2. 抖音广告创意观察报告
  3. 安卓手机如何找回被误删的照片小技巧
  4. javac不是内部或外部命令,也不是可运行的程序怎么办?
  5. 考研、工作、出国?——给一位大二学生出的主意
  6. 杂谈云计算与网络革命
  7. 九月游戏公司面试总结
  8. 由于docker pull image失败,导致k8s pod卡在ContainerCreating状态
  9. 知识图谱这么火,本文带你揭秘它的前世今生!
  10. 谷歌浏览器快速恢复已经关闭的网页