Unity实现俄罗斯方块(二)

时间:2021-05-20

本文实例为大家分享了Unity实现俄罗斯方块第2部分,供大家参考,具体内容如下

代码部分

1. 实现物体自由降落(在有关于物体的脚本中编写)

1)、使用循环调用方法实现

public float speed = 0.3f;//物体下落 // Start is called before the first frame update void Start() { InvokeRepeating("Move", 0, speed); } void Move() { transform.position += new Vector3(0, -1, 0); }

2)、使用时间差进行自由降落(在这里使用的该方法)

float lastFail=0;else if (Input.GetKeyDown(KeyCode.DownArrow)||Time.time-lastFail>=1){ transform.position += new Vector3(0, -1, 0); lastFail = Time.time;}

2. 处理碰边界问题

逻辑部分:

1)、得到游戏区域的宽度和高度,分析宽度和高度能放多少个格子,用一个二维数组来保存信息。如果占据了这个格子将其设置为非空。
2)、编写格子的脚本,处理格子的逻辑。

代码部分:

//设置变量public static int width = 10;//游戏窗口的宽度public static int height = 20;//游戏窗口的高度public static Transform[,] grid=new Transform[width,height];//*注:变量应设置成static 否则无法引用

3. 处理物体是否还能下降问题(物体脚本)

逻辑部分:

1)、在一个格子刚产生的时候,就要判断是否能继续下落,如果还可以继续下落,说明游戏仍可进行,如果不能继续下落,说明游戏结束。

2)、所以判断能都继续下落的重要条件依据就是下方的格子是否被占据。也可以先移动位置,判断移动后的位置是否有效,如果有效,物体进行移动,否则不移动。

3)、编写是否组成物体的格子是否在边界内,防止超出边界(游戏区域格子脚本),每一个格子的x要大于左边界且小于右边界,y要大于下边界。

4)、当其在uodate不能下落时,应该产生一个新的物体,并且将当前的物体的脚本进行关闭,避免脚本还发生作用。
代码部分:

格子脚本:

public static Vector2 roundVec2(Vector2 v) { return new Vector2(Mathf.Round(v.x), Mathf.Round(v.y)); } public static bool insideBorder(Vector2 pos) { //注宽是小于否则会出边界 if ((int)pos.x >= 0 && (int)pos.x <width && (int)pos.y >= 0) return true; else return false; }

物体脚本:

void Start() { if (!isValidGridPos())//刚产生就无效 { Debug.Log("GAME OVER"); } } float lastFail=0; // Update is called once per frame void Update() { //控制物体向左移 if (Input.GetKeyDown(KeyCode.LeftArrow)) { transform.position += new Vector3(-1, 0, 0); if (isValidGridPos()) { } else { transform.position += new Vector3(1, 0, 0); } } //控制物体右移 else if (Input.GetKeyDown(KeyCode.RightArrow)) { transform.position += new Vector3(1, 0, 0); if (isValidGridPos()) { } else { transform.position += new Vector3(-1, 0, 0); } } //控制物体旋转 else if (Input.GetKeyDown(KeyCode.UpArrow)) { //可在unity编辑器中通过旋转可得是对z轴进行旋转 transform.Rotate(0, 0, -90); if (isValidGridPos()) { } else { transform.Rotate(0, 0, 90); } } else if (Input.GetKeyDown(KeyCode.DownArrow)||Time.time-lastFail>=1) { transform.position += new Vector3(0, -1, 0); if (isValidGridPos()) { } else { transform.position += new Vector3(0, 1, 0); FindObjectOfType<Spawner>().spawnNext(); enabled = false; } lastFail = Time.time; } } bool isValidGridPos()//判断是否有效 { foreach (Transform child in transform) { Vector2 v=Grid.roundVec2(child.position); //判断是否在边界之间 if (!Grid.insideBorder(v)) return false; if (Grid.grid[(int)v.x, (int)v.y] != null) return false; } return true; }

更多俄罗斯方块精彩文章请点击专题:俄罗斯方块游戏集合 进行学习。

更多有趣的经典小游戏实现专题,分享给大家:

C++经典小游戏汇总

python经典小游戏汇总

python俄罗斯方块游戏集合

JavaScript经典游戏 玩不停

javascript经典小游戏汇总

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章