В настоящее время я создаю игру в единстве, где я сделал так, чтобы фон и препятствия в игре постоянно «возрождались» и создавали цикл. Все работало нормально, пока я не добавил второй скрипт к препятствиям, чтобы они двигались вертикально. После добавления скрипта я получил ошибку: «Невозможно преобразовать тип источника в тип назначения».
Это скрипт для создания цикла объектов (Cs):
public class BgLooper : MonoBehaviour {
int numBGPanels = 10;
float cloudMax = 2.2f;
float cloudMin = -0.2f;
void Start() {
GameObject[] clouds = GameObject.FindGameObjectsWithTag ("Cloud");
foreach (GameObject cloud in clouds) {
Vector3 pos = cloud.transform.position;
pos.y = Random.Range(cloudMin, cloudMax);
cloud.transform.position = pos;
}
}
void OnTriggerEnter2D(Collider2D collider) {
Debug.Log ("Triggered: " + collider.name);
float widthOfBGobject = ((BoxCollider2D)collider).size.x;
Vector3 pos = collider.transform.position;
pos.x += widthOfBGobject * numBGPanels;
if (collider.tag == "Cloud") {
pos.y = Random.Range(cloudMin, cloudMax);
}
collider.transform.position = pos;
}
}
И это скрипт, чтобы заставить obsticales двигаться (Js):
var maxX = 6.1;
var minX = -6.1;
var maxY = 4.2;
var minY = -4.2;
var moveSpeed = 0.3;
private var tChange: float = 0; // force new direction in the first Update
private var randomX: float;
private var randomY: float;
function Update () {
// change to random direction at random intervals
if (Time.time >= tChange){
randomX = Random.Range(-2.0,2.0); // with float parameters, a random float
randomY = Random.Range(-2.0,2.0); // between -2.0 and 2.0 is returned
// set a random interval between 0.5 and 1.5
tChange = Time.time + Random.Range(0.5,1.5);
}
transform.Translate(Vector3(randomX,randomY,0) * (moveSpeed / 15) * Time.deltaTime);
// if object reached any border, revert the appropriate direction
if (transform.position.x >= maxX || transform.position.x <= minX) {
randomX = -randomX;
}
if (transform.position.y >= maxY || transform.position.y <= minY) {
randomY = -randomY;
}
// make sure the position is inside the borders
transform.position.x = Mathf.Clamp(transform.position.x, minX, maxX);
transform.position.y = Mathf.Clamp(transform.position.y, minY, maxY);
}