Я знаю, это может звучать странно, но мне нужно сделать игру памяти, которая бы соответствовала разным изображениям, а не двум одинаковым изображениям, как, например, номер один и рука с поднятым указательным пальцем
Вот мойФактический код, который совпадает с двумя одинаковыми изображениями, клонирует карту, заставляя одно и то же изображение появляться дважды
Контроллер сцены ниже
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.SceneManagement;
public class SceneController : MonoBehaviour {
public const int gridRows = 2;
public const int gridCols = 5;
public const float offsetX = 4f;
public const float offsetY = 5f;
[SerializeField] private MainCard originalCard;
[SerializeField] private Sprite[] images;
private void Start()
{
Vector3 startPos = originalCard.transform.position; //The first position of the cards, all other cards are based on this one
int[] numbers = { 0, 0, 1, 1, 2, 2, 3, 3, 4, 4};
numbers = ShuffleArray(numbers);
for(int i = 0; i < gridCols; i++)
{
for(int j = 0; j < gridRows; j++)
{
MainCard card;
if(i == 0 && j == 0)
{
card = originalCard;
}
else
{
card = Instantiate(originalCard) as MainCard;
}
int index = j * gridCols + i;
int id = numbers[index];
card.ChangeSprite(id, images[id]);
float posX = (offsetX * i) + startPos.x;
float posY = (offsetY * j) + startPos.y;
card.transform.position = new Vector3(posX, posY, startPos.z);
}
}
}
private int[] ShuffleArray(int[] numbers)
{
int[] newArray = numbers.Clone() as int[];
for(int i = 0; i < newArray.Length; i++)
{
int tmp = newArray[i];
int r = Random.Range(i, newArray.Length);
newArray[i] = newArray[r];
newArray[r] = tmp;
}
return newArray;
}
//-------------------------------------------------------------------------------------------------------------------------------------------
private MainCard _firstRevealed;
private MainCard _secondRevealed;
private int _match = 5;
[SerializeField] private TextMesh matchLabel;
public bool canReveal
{
get { return _secondRevealed == null; }
}
public void CardRevealed(MainCard card)
{
if(_firstRevealed == null)
{
_firstRevealed = card;
}
else
{
_secondRevealed = card;
StartCoroutine(CheckMatch());
}
}
private IEnumerator CheckMatch()
{
if(_firstRevealed.id == _secondRevealed.id)
{
_match--;
matchLabel.text = "Pares Restantes: " + _match;
if(_match == 1){
matchLabel.text = "Somente " + _match + " Par Restante";
}
if(_match == 0){
SceneManager.LoadScene("Sucesso");
}
}
else
{
yield return new WaitForSeconds(0.5f);
_firstRevealed.Unreveal();
_secondRevealed.Unreveal();
}
_firstRevealed = null;
_secondRevealed = null;
}
public void Menu()
{
SceneManager.LoadScene("Menu");
}
public void Fases()
{
SceneManager.LoadScene("Fases");
}
public void Sair()
{
Application.Quit ();
}
public void Level1()
{
SceneManager.LoadScene("Level 1");
}
public void Sucesso()
{
SceneManager.LoadScene("Sucesso");
}
}
Класс основной карты ниже
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
public class MainCard : MonoBehaviour {
[SerializeField] private SceneController controller;
[SerializeField] private GameObject Card_Back;
public void OnMouseDown()
{
if(Card_Back.activeSelf && controller.canReveal)
{
Card_Back.SetActive(false);
controller.CardRevealed(this);
}
}
private int _id;
public int id
{
get { return _id; }
}
public void ChangeSprite(int id, Sprite image)
{
_id = id;
GetComponent<SpriteRenderer>().sprite = image; //Isso pega o Sprite Renderer e muda a propriedade do Sprite
}
public void Unreveal()
{
Card_Back.SetActive(true);
}
}
PS: простите за мой английский