유니티에서의 이동 - Translate, Movetowards

Published: Dec 31, 2020 by BeatChoi

유니티에서의 객체 이동 :: Translate

유니티에서 기본적인 객체의 이동을 구현하기 위한 Translate 함수를 알아봅니다.

유니티3D 에디터에서

Translate 함수

프로젝트창에서 Move스크립트를 생성합니다.


<01. Move 스크립트 생성>

Move 스크립트를 열어서 다음과 같이 작성합니다. 스크립트에 생성되어 있는 Start함수는 제거합니다.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
using System.Collections;
using System.Collections.Generic;
using UnityEngine;

public class Move : MonoBehaviour
{
    public float speed;

    // Update is called once per frame
    void Update()
    {
        transform.Translate(Vector3.forward*speed);
    }
}
  • Translate 함수는 transform클래스에서 불러옵니다. 즉 물체의 위치값을 기반으로 작동한다는 의미입니다.
  • Translate 함수의 인자에 값을 넣는 방법은 여러가지가 있지만 기본적으로 Vector3값이 들어가야 합니다.
  • Vector3.forward값을 넣어서 물체의 z의 양의 방향으로 이동하도록 합니다.

오브젝트 설정

에디터로 돌아와서 Move스크립트를 Sphere오브젝트에 인스턴스화를 시킵니다.
스크립트에서 선언한 Speed항목을 0.1로 설정합니다.


<02. Move 스크립트 인스턴스화>

테스트

에디터 상단 플레이버튼을 눌러서 확인을 해봅니다.
Sphere 오브젝트가 이동하는 것을 확인합니다.


<03. Sphere 이동 확인>

위에서 확인하셨듯이 Translate함수를 활용하면 오브젝트를 원하는 방향으로 이동시킬 수 있습니다.

유니티에서의 객체 이동 :: Movetowards

유니티에서 기본적인 객체의 이동을 구현하기 위한 Movetowards 함수를 알아봅니다.

유니티3D 에디터에서

Movetowards 함수

Move 스크립트를 열어서 다음과 같이 수정합니다. 기존의 Translate 함수는 주석처리 하겠습니다.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
using System.Collections;
using System.Collections.Generic;
using UnityEngine;

public class Move : MonoBehaviour
{
    public float speed;

    // Update is called once per frame
    void Update()
    {
        //transform.Translate(Vector3.forward*speed);
        transform.position = Vector3.MoveTowards(transform.position, new Vector3(0, 10.85f, 0), Time.deltaTime * speed);
    }
}

  • MoveTowards함수는 Vector3에 속해있는 정적함수입니다.
  • MoveTowards함수의 인자들은 각각 현재위치, 목표위치, 거리차(maxDistanceDelta) 입니다.
  • 다시 말하면 현재위치에서 목표위치가지 maxDistanceDelta의 거리 만큼 이동한 위치값을 나타냅니다.
  • 따라서 new Vector3(x, y, z)의 x y z 에는 여러분이 원하는 적정 목표 위치값을 넣으시면 됩니다.

오브젝트 설정

에디터로 돌아와서 Move스크립트를 Sphere오브젝트에 인스턴스화를 시킵니다.
스크립트에서 선언한 Speed항목을 10로 설정합니다.


<02. Move 스크립트 인스턴스화>

테스트

에디터 상단 플레이버튼을 눌러서 확인을 해봅니다.
Sphere 오브젝트가 이동하는 것을 확인합니다.


<03. Sphere 이동 확인>

위에서 확인하셨듯이 MoveTowards메소드를 활용하면 오브젝트를 원하는 위치로 이동시킬 수 있습니다.

비교

기본적으로 객체의 위치값을 이용하여 이동시키는 함수들 두가지를 알아보았습니다.
Translate방향이라는 인자값을 받아서 그 방향대로 계속 이동시키는 역할을 합니다.
1인칭 캐릭터의 이동이나 총알 발사 같은 예를 생각하면 되겠네요.
MoveTowards는 자신의 현재위치에서 목표점을 향하여 이동하는 역할을 합니다.
3인칭 탑 뷰 캐릭터의 마우스 클릭 이동이나 유도탄 등을 생각하면 편하겠습니다.
물론 위 두가지 이동만을 활용하여 모든 콘텐츠의 이동을 구현하기는 어렵습니다.
물리적 충돌은 고려되지 않고 단순한 위치값을 이용한 이동이기 때문입니다.
하지만 활용하기 쉬운만큼 간단한 객체의 이동을 구현하는데 활용하기에는 안성맞춤입니다.

Latest Posts

콘텐츠 개발 기법 - URP 환경에서 Bloom 및 Volume 포함한 화면 캡처
콘텐츠 개발 기법 - URP 환경에서 Bloom 및 Volume 포함한 화면 캡처

화면 캡처 :: Screen Capture

일반적으로 URP환경에서 Bloom 등의 Volume 이펙트들이 함께 캡처되지 않는 현상이 일어납니다.
두가지 원인이 있는데 첫번째는 저장할 Texture 및 Texture2D의 크기가 작아 모든 텍스쳐를 저장할 수 없는 경우와
두번째는 Linear color space의 픽셀을 텍스쳐에 저장 할 수 없는 경우가 있습니다.
이번 포스팅에서는 URP 환경에서 해당 이펙트들을 함께 캡쳐하는 방법을 알아봅니다.

콘텐츠 개발 기법 - UI 안나오게 화면 캡처(Screen Capture without UI)
콘텐츠 개발 기법 - UI 안나오게 화면 캡처(Screen Capture without UI)

화면 캡처 :: Screen Capture

UI 없이 화면을 캡쳐하는 방법을 알아봅니다.
해당 방법을 통해 사진 앱에서 사진을 찍거나 게임 내에서 UI를 제거한 스크린샷을 구현할 수 있습니다.

유니티3D 에디터에서

스크립트 작성

LightshipAR SDK 활용하기 - LightshipAR VPS의 활용
LightshipAR SDK 활용하기 - LightshipAR VPS의 활용

LightshipAR SDK

이번 강좌에서는 Visual Positioning System (VPS) 기능을 활용하여 콘텐츠를 개발해 봅니다.
VPS는 GPS정보와 타겟 매핑 정보를 정합하여 해당 타겟을 인식하는 기능입니다.
따라서 객체나 환경의 변화 및 이동이 잦지 않은 타겟이 스캔 대상이 됩니다.
주로 동상, 건물 입구, 가로등 등 위치의 변경이 없는 타겟들이 좋은 타겟입니다.

해당 타겟들을 인식시키고 주변에 가상의 오브젝트들을 배치하고 해당 위치를 저장하는 방법을 알아봅니다.

공간 매핑

Niantic Wayfarer

공간을 인식시키기 위해서 먼저 공간을 매핑해야 합니다.
이 과정은 IOS 어플리케이션으로 진행을 할 수 있는데 아래 링크에서

  1. Testflight
  2. Wayfarer

어플리케이션을 다운로드 및 설치합니다.

링크 : https://testflight.apple.com/join/VXu1F2jf