'유니티'에 해당되는 글 227건

  1. 2014.01.26 Unity3D 스프라이트 렌더러 색 변경
  2. 2014.01.26 Unity2D 스프라이트 렌더러 동적할당
  3. 2014.01.26 유니티 코루틴 관련 함수(대화 관련)
  4. 2014.01.26 블로그 변경.
  5. 2014.01.14 [런게임] 유니티 3D로 러너 게임 만들기 - 완성본
  6. 2014.01.14 [런게임] 유니티 3D로 러너 게임 만들기 - 파티클 이펙트
  7. 2014.01.14 [런게임] 유니티 3D로 러너 게임 만들기 - GUI 설정
  8. 2014.01.14 [런게임] 유니티 3D로 러너 게임 만들기 - 파워업!
  9. 2014.01.14 [런게임] 유니티 3D로 러너 게임 만들기 - 이벤트 사용하기
  10. 2014.01.13 [런게임] 유니티 3D로 러너 게임 만들기 - 게임오버

Unity3D 스프라이트 렌더러 색 변경

|

private SpriteRenderer renderer;


renderer  = mole.GetComponent<SpriteRenderer> ();

renderer.color = new Color(0f, 0f, 0f, 1f); // Set to opaque black

Trackback 0 And Comment 0

Unity2D 스프라이트 렌더러 동적할당

|

Resource에서 Sprite 로딩.

SpriteRenderer spr = GetComponent<SpriteRenderer>();
spr.sprite = Resources.Load<Sprite>("path/name");


Trackback 0 And Comment 0

유니티 코루틴 관련 함수(대화 관련)

|
출처 : http://www.unitystudy.net/bbs/board.php?bo_table=writings&wr_id=43


코루틴용 데이터

엔진이 수행하는 기능

yield return null

다음 프레임까지 대기

yield return new WaitForSeconds(float)

지정된 초 만큼 대기

yield return new WaitForFixedUpdate()

다음 물리 프레임까지 대기

yield return new WaitForEndOfFrame()

모든 렌더링작업이 끝날 때까지 대기

yield return StartCoRoutine(string)

다른 코루틴이 끝날 때까지 대기

yield return new WWW(string)

웹 통신 작업이 끝날 때까지 대기

yield return new AsyncOperation

비동기 작업이 끝날 때까지 대기 ( 씬로딩 )



순차적 수행 가능







public class DialogExample : MonoBehaviour {

   

    bool showDialog = false;

    string answer = "";

   

    IEnumerator Start()

    {

        yield return StartCoroutine("ShowDialog"); //다른 코루틴이 끝날 때까지 대기

        yield return StartCoroutine(answer);

    }

   //answer 에 값이 들어가기 전까지는 코루틴이 끝나지 않음

    IEnumerator ShowDialog()

    {

        showDialog = true;

        do

        {

            yield return null;

        } while(answer == "");

       

        showDialog = false;

    }

   

    IEnumerator ActionA()

    {

        Debug.Log ("Action A");

        yield return new WaitForSeconds(1f);

    }

 

    IEnumerator ActionB()

    {

        Debug.Log ("Action B");

        yield return new WaitForSeconds(2f);

    }

   

    void OnGUI()

    {

        if(showDialog)

        {

            if(GUI.Button(new Rect(10f, 10f, 100f, 20f), "A"))

            {

                answer = "ActionA";  

            } else if(GUI.Button(new Rect(10f, 50f, 100f, 20f), "B")) {

                answer = "ActionB";

            }

        }

    }

   

}




Trackback 0 And Comment 0

블로그 변경.

|

블로그 주소 변경 및 디자인 전체적으로 전부 다 변경.

전부 Unity3D 관련 자료들을 다룰 예정임.

참고 사이트 및 스크립트 관련 기능 위주로 포스팅 할 예정



Trackback 0 And Comment 0

[런게임] 유니티 3D로 러너 게임 만들기 - 완성본

|

Trackback 0 And Comment 0

[런게임] 유니티 3D로 러너 게임 만들기 - 파티클 이펙트

|

파티클 이펙트

지금 까지 우리는 게임의 기능적인 면을 만들었다. 하지만 Scene 공간에 텅 빈 느낌을 채워주고 싶다. 이것을 파티클 이펙트로 채울 생각이다.


 particle system을 생성하자. (GameObject / Create Other / Particle System) 이름은 Dust Emitter로 짓자. Runner의 자식으로 두고 위치는 (25, 0, 0)로 설정하고 rotation은 reset해준다, 이렇게 하면 항상 카메라를 따라다닌다.

Set Start Lifetime 를 Random Between Two Constants 으로 설정하고 값을 6과 10으로 설정해준다. 그리고 Start Speed 는 0으로 설정해준다. 이것을 사용하면 입자의 크기가 일정하게 시작된다. 또한 Simulation Space는 World로 변경해준다. 이것은 Runner에 의해서 파티클이 움직이지 않게 해준다. Start Size는 Random Between Two Constants으로 설정해주고 값은 0.2 와 0.8로 맞춰준다.

shape 는 box로 설정하고 with 수치는 (1, 30, 10)로 설정해주고 Emission 는 20으로 설정한다.

Velocity Over Lifetime은, world space로 설정하고 random range between two constants로 설정해준다 값은  (-1, -1, 0) 그리고 (-4, 1, 0)로 설정한다. 이것은 파티클 각각의 움직임을 나타내어준다.

마지막으로 Color over Lifetime 의 그라디언트를 처음에는 0 그리고 나중에는 100%로 맞춰주자. 이것은 페이드인 효과가 나타난다.

그다음 particle system을 복제하고, Runner의 자식으로 둔다, position을 reset 하고 이름은 Trail Emitter로 짓는다. 이것은 러너의 흔적을 나타낼 파티클입니다.

Shape를 Mesh로 변경하고 and cube로 설정해준다. 그리고 Velocity over Lifetime을 해제한다.

Start Lifetime을   1 과 2 로 Start Size 는 0.2 와 0.4로 설정한다.

dust trail scene
Particle systems.

우리는 게임중일때 파티클을 생성할때는 매니저 클래스를 만들어서 생성할수 있습니다. ParticleSystemManager라는 C# script를 만들고  Managers 폴더에 넣습니다. 또한 이 스크립트를 넣을 빈 오브젝트도 생서해줍시다.

 ParticleSystemManager 에서는 오직 파티클의 보이고 안보이고 만 해줍니다. 우리는  particleSystems 배열을 사용해서 관리합니다. 

using UnityEngine;

public class ParticleSystemManager : MonoBehaviour {

	public ParticleSystem[] particleSystems;

	void Start () {
		GameEventManager.GameStart += GameStart;
		GameEventManager.GameOver += GameOver;
		GameOver();
	}

	private void GameStart () {
		for(int i = 0; i < particleSystems.Length; i++){
			particleSystems[i].Clear();
			particleSystems[i].enableEmission = true;
		}
	}

	private void GameOver () {
		for(int i = 0; i < particleSystems.Length; i++){
			particleSystems[i].enableEmission = false;
		}
	}
}
managergame
Particles in action.
모든 게임을 완성했습니다! 점프가 가능하며, 흔적도 남고 파워업아이템도 만들었고! 점수또한 보입니다.! 그리고 배경또한 스크롤 됩니다. 이것은 좋은 프로토타입이고 당신은 이것을 통해서 멋진 게임을 만들수도 있습니다! 수고하셨습니다.







패키지 파일


runner.unitypackage



Trackback 0 And Comment 0

[런게임] 유니티 3D로 러너 게임 만들기 - GUI 설정

|

 GUI 설정

부스터 아이템 작업을 완료 했습니다. 하지만 부스터 아이템을 몇개 가지고 있는지 알수있는 방법은 플레이어가 그것을 기억하는수 밖에 없습니다. 이 방법을 개선하려면 GUI를 통해서 화면에 표시하는 방법이 있습니다. 아이템 개수 뿐만아니라 얼마나 이동했는지 또한 표시할수있씁니다.

GUIText를 생성하고  GUI의 자식으로 둡니다. 위치는 (0.01, 0.99, 0), Anchor 는 upper left, font size 20 그리고 normal style로 설정하니다. 이름은 Boosts Text입니다..

 Distance Text도 생성합니다. 위치는 (0.5, 0.99, 0), font size 30 그리고 bold style.Anchor 는upper center.

 GUIManager 에 두개의 변수를 선언하고 할당합니다.

	public GUIText boostsText, distanceText, gameOverText, instructionsText, runnerText;
boosts distance 
gui manager
Boosts and distance.
Runner 에서 GUIManager 를 수정할수 있게 스테틱 변수와 함수들을 만듭니다. 아래와 같이 스테틱 함수를 만들면 어디서든 접근이 가능합니다. 
	private static GUIManager instance;

	void Start () {
		instance = this;
		GameEventManager.GameStart += GameStart;
		GameEventManager.GameOver += GameOver;
		gameOverText.enabled = false;
	}

	public static void SetBoosts(int boosts){
		instance.boostsText.text = boosts.ToString();
	}

	public static void SetDistance(float distance){
		instance.distanceText.text = distance.ToString("f0");
	}
 Runner 에서 위에 함수를 호출해서 값들을 변경해줍니다.
	void Update () {
		if(Input.GetButtonDown("Jump")){
			if(touchingPlatform){
				rigidbody.AddForce(jumpVelocity, ForceMode.VelocityChange);
				touchingPlatform = false;
			}
			else if(boosts > 0){
				rigidbody.AddForce(boostVelocity, ForceMode.VelocityChange);
				boosts -= 1;
				GUIManager.SetBoosts(boosts);
			}
		}
		distanceTraveled = transform.localPosition.x;
		GUIManager.SetDistance(distanceTraveled);

		if(transform.localPosition.y < gameOverY){
			GameEventManager.TriggerGameOver();
		}
	}

	private void GameStart () {
		boosts = 0;
		GUIManager.SetBoosts(boosts);
		distanceTraveled = 0f;
		GUIManager.SetDistance(distanceTraveled);
		transform.localPosition = startPosition;
		renderer.enabled = true;
		rigidbody.isKinematic = false;
		enabled = true;
	}

	public static void AddBoost(){
		boosts += 1;
		GUIManager.SetBoosts(boosts);
	}
Complete GUI.


Trackback 0 And Comment 0

[런게임] 유니티 3D로 러너 게임 만들기 - 파워업!

|

파워업

공중 부스터를 가능하게하는 파워업 아이템을 만들어보자. 우리는 랜덤하게 회전하는 큐브를 길 위에 생성할수 있습니다. 우리는 한가지의 부스터 큐브를 사용할것이며 이것은 재사용 됩니다.

  Booster 폴더를 만듭니다Booster Mat 이름의 material 생성합니다 . 우리는 메트리얼 쉐이더를 Specular shader 로 설정하고, Main Color은 녹색 (0, 255, 0) 으로 설정합니다 그리고 specular color 색상은 하얀색으로 설정합니다.

cube를 생성하고, 이름은Booster로 그리고 scale은 각각 0.5로 설정합니다. 충돌하기 쉽게 콜라이더의 크기는 1.5로 설정합니다.

콜라이더의 Is Trigger field에 체크합니다. 왜냐하면 Runner이 충돌에 영향을 받지 않아야 되기 때문입니다.(IS Trigger 체크시 통과됨)

Booster cube.
Booster라는 C# script 를 생성하고  in the Booster 폴더에 집어넣고 Booster 큐브에 집어넣습니다. 우리는 4개의 변수를 만들것입니다. 첫째 우리는 길 중안에 부스터 아이템을 놔두기 위해서 좌표가 필요합니다 이 좌표를 (0, 2.5, 0)로 설정합니다. 둘째 우리는 회전을 하기위해서 회전 값을 설정합니다. 이값은 (45, 90, 1)로 설정합니다. 셋째 우리는 재활용 하는 위치를 설정해 줘야 됩니다. 이것은 Runner이 파워업 아이템을 놓쳣을때 사용합니다 우리는 이 값을 20으로 설정합니다. 넷째, 우리는 부스터 아이템을 생성할수 있도록 25퍼 센트 확률 정도로 설정할것입니다
using UnityEngine;

public class Booster : MonoBehaviour {

	public Vector3 offset, rotationVelocity;
	public float recycleOffset, spawnChance;
}
Booster configuration.
부스터 아이템을 생성하는 방법중 하나는 길이 생성될때 부스터 아이템을 생성하는 방법이 있습니다. 그리고 이 로직은 부스터 스크립트에서 처리할것입니다. 우리는 이 SpawnIfAvailable 메서드를 Booster 에 추가합니다. 부스터 아이템을 배치하려면 길의 좌표가 필요합니다. 일단은 비워 두겠습니다.
	public void SpawnIfAvailable(Vector3 position){
	}
 PlatformManager 에 Booster를 할당할수 있도록 변수를 선언합니다.  Recycle 메서드에서 PlaceIfAvailable 메서드를 호출합니다.
	public Booster booster;

	private void Recycle () {
		Vector3 scale = new Vector3(
			Random.Range(minSize.x, maxSize.x),
			Random.Range(minSize.y, maxSize.y),
			Random.Range(minSize.z, maxSize.z));

		Vector3 position = nextPosition;
		position.x += scale.x * 0.5f;
		position.y += scale.y * 0.5f;
		booster.SpawnIfAvailable(position);

		Transform o = objectQueue.Dequeue();
		o.localScale = scale;
		o.localPosition = position;
		int materialIndex = Random.Range(0, materials.Length);
		o.renderer.material = materials[materialIndex];
		o.collider.material = physicMaterials[materialIndex];
		objectQueue.Enqueue(o);
		
		nextPosition += new Vector3(
			Random.Range(minGap.x, maxGap.x) + scale.x,
			Random.Range(minGap.y, maxGap.y),
			Random.Range(minGap.z, maxGap.z));

		if(nextPosition.y < minY){
			nextPosition.y = minY + maxGap.y;
		}
		else if(nextPosition.y > maxY){
			nextPosition.y = maxY - maxGap.y;
		}
	}
Platform manager knows about booster.
위 처럼 연결하고 나서, 우리는  SpawnIfAvailable 메서드에서 위치를 설정하고 활성화 시켜줍니다. 그리고 게임오버인 경우에는 비활성화 시켜주고 함수가 호출되기 전에도 비활성화를 시켜줍니다.
	void Start () {
		GameEventManager.GameOver += GameOver;
		gameObject.SetActive(false);
	}

	public void SpawnIfAvailable (Vector3 position) {
		if(gameObject.activeSelf || spawnChance <= Random.Range(0f, 100f)) {
			return;
		}
		transform.localPosition = position + offset;
		gameObject.SetActive(true);
	}

	private void GameOver () {
		gameObject.SetActive(false);
	}
 Update 메서드에서는 부스터 아이템을 회전 시키며, 일정 위치를 넘어갔을시에는 부스터 아이템을 비활성화 시켜줍니다.
	void Update () {
		if(transform.localPosition.x + recycleOffset < Runner.distanceTraveled){
			gameObject.SetActive(false);
			return;
		}
		transform.Rotate(rotationVelocity * Time.deltaTime);
	}
Rotating booster.
아직은 Runner이 부스터를 통과해도 아무일도 일어나지 않습니다. 이것을 변경하기 위해서 우리는 유니티 메서드인 OnTriggerEnter 을 Booster에 더합니다. 이 메서드는 콜라이더가 충돌될때 호출됩니다. 현재 부스터 아이템과 부딪힐수있는건 Runner밖에 없기 때문에 다른 처리는 해주지 않습니다.  Runner 에 스테틱 메서드인 AddBoost 을 만들어 주고 이것을 사용하겠습니다.
	void OnTriggerEnter () {
		Runner.AddBoost();
		gameObject.SetActive(false);
	}
 AddBoost 를 메서드를 만들어 줍니다.
	private static int boosts;

	private void GameStart () {
		boosts = 0;
		distanceTraveled = 0f;
		transform.localPosition = startPosition;
		renderer.enabled = true;
		rigidbody.isKinematic = false;
		enabled = true;
	}

	public static void AddBoost () {
		boosts += 1;
	}
실제로 공중에서 부스터를 사용할수 있도록 아래처럼 설정해줍니다. boost velocity 값은 적절하게 (10, 10, 0) 로 설정해 줍니다.
	public Vector3 boostVelocity, jumpVelocity;

	void Update () {
		if(Input.GetButtonDown("Jump")){
			if(touchingPlatform){
				rigidbody.AddForce(jumpVelocity, ForceMode.VelocityChange);
				touchingPlatform = false;
			}
			else if(boosts > 0){
				rigidbody.AddForce(boostVelocity, ForceMode.VelocityChange);
				boosts -= 1;
			}
		}
		distanceTraveled = transform.localPosition.x;

		if(transform.localPosition.y < gameOverY){
			GameEventManager.TriggerGameOver();
		}
	}
Boost velocity


Trackback 0 And Comment 0

[런게임] 유니티 3D로 러너 게임 만들기 - 이벤트 사용하기

|

이벤트 사용하기

우리의 게임이벤트는 제대로 동작한다, 이제 Runner를 고려할 시간입니다..

우리는 Runner 가 게임 시작전에는 안보이길 원합니다. 그리고 중력의 영향을 받지 않길 원하니다. 우리는 Start 메서드에서 이벤트를 설정하고, 각각의 함수에서 값들을 조정합니다.

아래는 Runner 스크립트 입니다.

	private Vector3 startPosition;

	void Start () {
		GameEventManager.GameStart += GameStart;
		GameEventManager.GameOver += GameOver;
		startPosition = transform.localPosition;
		renderer.enabled = false;
		rigidbody.isKinematic = true;
		enabled = false;
	}

	private void GameStart () {
		distanceTraveled = 0f;
		transform.localPosition = startPosition;
		renderer.enabled = true;
		rigidbody.isKinematic = false;
		enabled = true;
	}
	
	private void GameOver () {
		renderer.enabled = false;
		rigidbody.isKinematic = true;
		enabled = false;
	}

PlatformManager 도 마찬가지로 수정합니다.

	void Start () {
		GameEventManager.GameStart += GameStart;
		GameEventManager.GameOver += GameOver;
		objectQueue = new Queue<Transform>(numberOfObjects);
		for (int i = 0; i < numberOfObjects; i++) {
			objectQueue.Enqueue((Transform)Instantiate(
				prefab, new Vector3(0f, 0f, -100f), Quaternion.identity));
		}
		enabled = false;
	}

	private void GameStart () {
		nextPosition = startPosition;
		for(int i = 0; i < numberOfObjects; i++){
			Recycle();
		}
		enabled = true;
	}

	private void GameOver () {
		enabled = false;
	}
 SkylineManager 도 마찬가지로 아래와 같이 수정합니다.
	void Start () {
		GameEventManager.GameStart += GameStart;
		GameEventManager.GameOver += GameOver;
		objectQueue = new Queue<Transform>(numberOfObjects);
		for(int i = 0; i < numberOfObjects; i++){
			objectQueue.Enqueue((Transform)Instantiate(
				prefab, new Vector3(0f, 0f, -100f), Quaternion.identity));
		}
		enabled = false;
	}

	private void GameStart () {
		nextPosition = startPosition;
		for(int i = 0; i < numberOfObjects; i++){
			Recycle();
		}
		enabled = true;
	}

	private void GameOver () {
		enabled = false;
	}
game start game over
Game start and game over.


Trackback 0 And Comment 0

[런게임] 유니티 3D로 러너 게임 만들기 - 게임오버

|

게임 오버

gui manager 스크립트에 game-over event도 더합니다. game start event를 더한것과 마찬가지로 더하시면 됩니다.
	void Start () {
		GameEventManager.GameStart += GameStart;
		GameEventManager.GameOver += GameOver;
		gameOverText.enabled = false;
	}

	private void GameOver () {
		gameOverText.enabled = true;
		instructionsText.enabled = true;
		enabled = true;
	}
게임오버 이벤트는 Runner가 떨어졌을때 발생합니다. 우리는 간단하게Game Over Y 변수를 Runner 에 추가하고 값을  -6으로 설정합니다,그리고 이것을 체크하여 그 밑으로 떨어지면 gameOver 이벤트를 발생하게 합니다.
	public float gameOverY;

	void Update () {
		if(touchingPlatform && Input.GetButtonDown("Jump")){
			rigidbody.AddForce(jumpVelocity, ForceMode.VelocityChange);
			touchingPlatform = false;
		}
		distanceTraveled = transform.localPosition.x;

		if(transform.localPosition.y < gameOverY){
			GameEventManager.TriggerGameOver();
		}
	}
Game over threshold.


Trackback 0 And Comment 0
prev | 1 | ··· | 19 | 20 | 21 | 22 | 23 | next