Part 1 简答题
1.解释游戏对象(GameObjects)和资源(Assets)的区别与联系。
区别:游戏对象直接出现在场景中,,一般有玩家,敌人,环境和音乐等虚拟父类。这些父类本身没有实体,但他们的子类包含了游戏中会出现的对象。资源文件夹通常有对象、材质、场景、声音、预设、贴图、脚本、动作,在这些文件夹下可以继续划分。
联系:对象是资源整合的具体表现;资源可以被一个或多个对象使用,有些资源作为模板,可实例化成游戏中具体的对象。
2.下载几个游戏案例,分别总结资源、对象组织的结构(指资源的目录组织结构与游戏对象树的层次结构)
资源(Asset)下的结构:
如截图所示,字体,图片,脚本,场景的均在Asset目录下。
3.编写一个代码,使用 debug 语句来验证 MonoBehaviour 基本行为或事件触发的条件
代码:
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
public class test : MonoBehaviour {
// Use this for initialization
void Start () {
Debug.Log ("Starting...");
}
// Update is called once per frame
void Update () {
Debug.Log ("Updating...");
}
void Awake(){
Debug.Log("Awaking...");
}
void FixedUpdate(){
Debug.Log ("FixedUpdating...");
}
void LateUpdate(){
Debug.Log ("LateUpdating...");
}
void OnGUI() {
Debug.Log ("In OnGUI");
}
void OnDisable() {
Debug.Log ("In OnDisable");
}
void OnEnable() {
Debug.Log ("In OnEnable");
}
}
运行结果:
4.查找脚本手册,了解 GameObject,Transform,Component 对象
Description:
GameObject 游戏物体:继承自Object类,是Unity场景里所有实体的基类
Transform 变换:继承自Component,IEnumberable类,包括一个物体的位置、旋转和缩放。场景中的每一个物体都有一个Transform属性。用于储存并操控物体的位置、旋转和缩放。每一个Transform可以有一个父级,允许你分层次应用位置、旋转和缩放。可以在Hierarchy面板查看层次关系。他们也支持使用计数器,因此你可以使用循环遍历子物体。
Component 组件:继承自Object类,是一切和游戏物体有关类的基类。
描述table对象的属性:
Table是GameObject类的一个实例,第一个选择框是 activeSelf 属性。
Tag属性是游戏物体的标签,可用于查找游戏物体且效率较高,对应tag变量,第一个选择框对应CompareTag()方法。Layer属性是指游戏物体所在的层,Unity中默认已有8种Layer,一个层的范围是在[0…32]之间,对应layer变量。
table对象的Transform属性:
是Transform类的一个实例。
postion:在世界空间坐标中的相对位置,对应position变量,后面的xyz对应TransformPoint()方法。
rotation:物体变换的旋转角度,作为Quaternion储存,对应rotation变量,xyz对应Rotate()方法的三个参数。
scale:相对于父级物体的缩放,对应localScale变量。
table的部件:
Mesh Filter:网格过滤器,作为物体与Mesh的接口,输入窗口的作用是接入实例化的Mesh
Mesh
Renderer:网格渲染器,渲染网格。第一个窗口对应castShadows()方法,勾选框对应receiveShadows()方法,之后的窗口对应motionVectors()方法。Light
Probes是LightProbes的对象。Anchor Override找不到具体对应的api。
Box
Collider:盒碰撞器。第一个勾选框对应isTrigger变量,之后的选择框对应material变量,之后分别对应BoxCollider.center和BoxCollider.size
UML图:
5. 整理相关学习资料,编写简单代码验证以下技术的实现:
查找对象
通过调用GameObject.Find(string name)方法实现:
代码:
using UnityEngine;
using System.Collections;
public class Example : MonoBehaviour {
public GameObject hand;
void forExample() {
hand = GameObject.Find("Hand");
}
}
添加子对象
通过调用GameObject.CreatePrimitive(PrimitiveType _ttype)方法实现
代码:
using UnityEngine;
using System.Collections;
public class ExampleClass : MonoBehaviour {
void Start() {
GameObject cube = GameObject.CreatePrimitive(PrimitiveType.Cube);
}
}
遍历对象树
代码:
void Traversal(GameObject obj){
int i = 0;
while(i \< obj.transform.chilCount){
Transform p=obj.transform.GetChild(i);
//对p进行遍历要进行的动作
if(p.childCount \> 0) Traversal(p);
i++;
}
}
清除所有子对象
代码:
void DESTraversal(GameObject obj){
int i = 0;
while(i \< obj.transform.chilCount){
Transform p=obj.transform.GetChild(i);
if(p.childCount \> 0) Traversal(p);
Destroy(p.gameObject);
i++;
}
}
6.资源预设(Prefabs)与 对象克隆 (clone)
名词解释:
Prefabs(预设)是一种资源类型,可被重复使用的游戏对象。它可以被置入多个场景中,又或者能够在一个场景中被多次置入。
Clone(克隆)即创建一个该物体属性相同又不相关的新实例。
预设的好处:
预设可以看做游戏资源的模板。当在游戏场景中创建一个预设时即创建了一个他的实例。预设是相互关联的,当对预设进行更改时,这些更改将会作用于与之相连的所有实例。
预设与克隆的关系:
二者行为相似,但克隆对象不会随着被克隆对象的改变而改变。
将table实例化:
public class NewBehaviourScript : MonoBehaviour {
private string prePath = "prefabs/table";
private GameObject MyTable;
void Start () {
MyTable = (GameObject)Instantiate(Resource.Load(prePath), new Vector(4, 0, 0),Quaternion.identity) ;
}
}
7. 尝试解释组合模式(Composite Pattern / 一种设计模式)。使用BroadcastMessage() 方法向子对象发送消息
组合模式通过树形结构来表现部分与整体的层次。因为要求简单对象与复杂对象都要有同样的接口,所以能对对象进行一致处理。
父类对象方法:
void Start () {
this.BroadcastMessage("HelloSon");
}
子类对象方法:
Void HelloSon() {
Debug.Log("CallReceived");
}
Part2 编程实践:井字棋