[Unity] 制作游戏 赛车小游戏

14 篇文章 3 订阅
6 篇文章 0 订阅

模拟赛车小游戏

效果展示

请添加图片描述
做一款模拟赛车的小游戏demo,方向键控制、有刹车、重玩,还有漂移和查看车型的功能
可以看到,还有翻车的效果哈哈哈!有兴趣的小伙伴来看看吧!

资源准备

  1. 从网上下载赛车模型和桥梁路的模型
  2. 项目下载链接在文章末尾

赛车模型如下:请添加图片描述
然后将桥和路摆放入游戏场景
请添加图片描述
再把车放入适当的位置,加入刚体(将刚体mess调节到1000)和车轮碰撞器,层级结构如下:
请添加图片描述
车轮碰撞器如下操作,在车内部中新建空节点,然后再建四个空节点,给每个这四个空节点都加上Wheel Collider车轮碰撞器,然后将这四个车轮节点的位置逐个摆放到车子车轮对应的位置,最后稍微调节一下车轮的Friction参数即可。
在这里插入图片描述

最后再添加几个button在ui上,层级如下:
请添加图片描述
请添加图片描述

代码阶段

然后将车挂上脚本lanBoCar.cs
首先写入要在编辑器中配置的所有public变量

using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.UI;
using UnityEngine.SceneManagement;

public class lanBoCar : MonoBehaviour
{
    public float angleSpeed;
    public float moveSpeed;
    public WheelCollider[] wheels;
    public Transform[] modelTrs;
    public Button[] contrKeyPad;
    public GameObject camera;
    public Button reset;
    public GameObject objbody;
    public GameObject cam;
    public Button LOOK;
    ...

请添加图片描述
然后写相机镜头锁定车的脚本
camera.cs

using System.Collections;
using System.Collections.Generic;
using UnityEngine;

public class camera : MonoBehaviour
{
    public GameObject pos;
    private Vector3 offset;
    public GameObject playerCar;
    public GameObject ca;

    private int lookid = 0;

    public int canRot = 1;
    void Start()
    {
        offset = transform.position - playerCar.transform.position;

        transform.position = ca.transform.position;
        transform.localEulerAngles = ca.transform.localEulerAngles;
    }

    void Update()
    {
        if (lookid == 1)
        {   
            Vector3 pPos = playerCar.transform.position;
            pPos.z -= 4f;
            pPos.y += 1.5f;
            transform.position = pPos;
            transform.localEulerAngles = ca.transform.localEulerAngles;
        }
        else
        {
            transform.position = ca.transform.position;
            float y = playerCar.transform.localEulerAngles.y;
            float z = playerCar.transform.localEulerAngles.z;
            if (canRot == 0)
            {
                transform.localEulerAngles = new Vector3(transform.localEulerAngles.x, y, z);
            }
            else
            {
                transform.localEulerAngles = new Vector3(transform.localEulerAngles.x, y + (Time.deltaTime * 10), z);
            }
        }
    }

    void changeRot(string v)
    {
        if (v == "stop")
        {
            canRot = 0;
        }
        if (v == "begin")
        {
            canRot = 1;
        }
    }

    void look(int ids)
    {
        lookid = ids;
    }

}

再写上操作方向键的上下左右button的脚本
button.cs

using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.EventSystems;

public class button : MonoBehaviour,IPointerDownHandler,IPointerUpHandler
{   
    public float[] vh;
    public GameObject car;

    public void OnPointerDown(PointerEventData ed)
    {
        string chec = "";

        if (vh.Length == 1 && vh[0] == 2)
        {   
            int idx = 1;
            car.SendMessage("checkTail", idx);
            return;
        }
        if (vh[0] == 1)
        {
            chec = "up";
        }
        if(vh[0] == -1){
            chec = "down";
        }
        if (vh[1] == -1)
        {
            chec = "left";
        }
        if (vh[1] == 1)
        {
            chec = "right";
        }
        car.SendMessage("checkEvent", chec);
    }

    public void OnPointerUp(PointerEventData ed)
    {
        string chec = "";

        if (vh.Length == 1 && vh[0] == 2)
        {
            int idx = 0;
            car.SendMessage("checkTail", idx);
            return;
        }
        if (vh[0] == 1)
        {
            chec = "uSTOP";
        }
        if (vh[0] == -1)
        {
            chec = "dSTOP";
        }
        if (vh[1] == -1)
        {
            chec = "lSTOP";
        }
        if (vh[1] == 1)
        {
            chec = "rSTOP";
        }
        car.SendMessage("checkEvent", chec);
    }

}

然后把这个button.cs挂到每个方向键的组件上

最后写入车的脚本
lanBoCar.cs

using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.UI;
using UnityEngine.SceneManagement;

public class lanBoCar : MonoBehaviour
{
    public float angleSpeed;
    public float moveSpeed;

    public WheelCollider[] wheels;
    public Transform[] modelTrs;
    public Button[] contrKeyPad;

    public GameObject camera;
    public Button reset;

    private float h = 0f;
    private float v = 0f;

    private float addSpeed = 0f;
    public GameObject objbody;

    public GameObject cam;

    public Button LOOK;
    private bool lookF = false;

    void Start()
    {
        reset.onClick.AddListener(() =>
        {
            SceneManager.LoadScene(0);
        });

        LOOK.onClick.AddListener(() =>
        {
            lookF = !lookF;
            int ids;
            if (lookF)
            {
                ids = 1;
            }
            else
            {
                ids = 0;
            }
            cam.SendMessage("look",ids);
        });
    }

    void FixedUpdate()
    {   
        WheelControl();
    }

    void OnMouseDrag()
    {
        if (lookF)
        {
            wheels[2].brakeTorque = 1000f;
            wheels[3].brakeTorque = 1000f;
            transform.Rotate(0f, 40f * Time.deltaTime, 0f);
        }
    }

    void WheelControl(){

        if (lookF)
        {
            return;
        }
        //h = Input.GetAxis("Horizontal");
        //v = Input.GetAxis("Vertical");

        if (addSpeed == 1f)
        {
            Debug.Log("stop");
            wheels[2].brakeTorque = 1200f;
            wheels[3].brakeTorque = 1200f;
        }
        else
        {
            wheels[2].brakeTorque = 0f;
            wheels[3].brakeTorque = 0f;            
        }

        wheels[0].steerAngle = h * angleSpeed ;
        wheels[1].steerAngle = h * angleSpeed ;

        wheels[2].motorTorque = v * moveSpeed ;
        wheels[3].motorTorque = v * moveSpeed ;

        for (int i = 0; i < 4; i++)
        {
            ModelWheelShow(modelTrs[i],wheels[i]);
        }
    }

    void ModelWheelShow(Transform trans,WheelCollider wheel){
        Vector3 pos;
        Quaternion rot;
        wheel.GetWorldPose(out pos, out rot);
        trans.rotation = rot;
    }

    void checkEvent(string move)
    {
        Debug.Log(move);
        switch (move)
        {
            case "up":
                v = 1;
                break;
            case "down":
                v = -1;
                break;
            case "left":
                h = -1;
                cam.SendMessage("changeRot", "stop");
                break;
            case "right":
                cam.SendMessage("changeRot", "stop");
                h = 1;
                break;
            case "uSTOP":
            case "dSTOP":
                v = 0;
                break;
            case "lSTOP":
            case "rSTOP":
                cam.SendMessage("changeRot", "begin");
                h = 0;
                break;
        }
    }

    void checkTail(int id)
    {
        if (id == 1)
        {
            addSpeed = 1f;
        }
        if (id == 0)
        {
            addSpeed = 0f;
        }
    }

}

游戏结果

请添加图片描述
请添加图片描述

项目下载

最后项目下载链接:
https://download.csdn.net/download/qq_25755645/86265905

  • 6
    点赞
  • 53
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
设计一个好的游戏界面和用户体验对于经营养成冒险游戏至关重要,以下是一些关于Unity模拟经营养成冒险游戏界面和用户体验设计的建议: 1. 游戏界面设计 游戏界面应该尽可能简洁明了,避免让玩家感到混乱。以下是一些游戏界面设计的要点: - 显示游戏元素:在游戏中显示所有必要的元素,例如资源,建筑物和角色等。这有助于玩家了解他们的进度和游戏目标。 - 可定制的界面:提供给玩家调整或自定义游戏界面的选项,例如改变按钮大小或界面颜色等。 - 良好的排版:在界面上排列游戏元素时,遵循一致的布局和设计原则。这将使玩家更容易理解和使用游戏界面。 2. 用户体验设计 用户体验是关于玩家如何与游戏互动和体验游戏的设计。以下是一些用户体验设计的要点: - 易于上手:游戏应该易于理解和学习,尤其是对于新手玩家。提供有针对性的游戏教程和指南,以及适当的反馈和帮助,以确保玩家可以轻松上手。 - 游戏进程:玩家需要感到游戏是公平和有意义的。游戏应该是有意思和富有挑战性的,而且要让玩家感到有进步,否则玩家很快就会失去兴趣。 - 反馈机制:游戏应该提供及时和有用的反馈,帮助玩家了解他们的进度和做出下一步行动的决策。例如,通过在屏幕上显示角色的状态栏或增加数字来显示资源的数量等。 总之,Unity模拟经营养成冒险游戏需要一个直观和清晰的游戏界面,以及易于上手和有趣的用户体验设计。在设计过程中,始终关注玩家的需求和期望,以确保游戏能够吸引并留住玩家。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值