Unity는 Apple이 제공하는 표준 게임 컨트롤러 입력 API를 스탠다드 Unity 입력 API의 일부로 지원합니다.
Input.GetJoystickNames
를 호출하면 연결된 모든 컨트롤러의 이름이 열거됩니다. 이름은 [$profile_type,$connection_type] joystick $number by $model
패턴을 따릅니다. $profile_type은 “basic” 또는 “extended” 중 하나일 수 있고, $connection_type은 “wired” 또는 “wireless” 중 하나입니다. 이를 사용하여 연결된 컨트롤러의 종류를 인식할 수 있습니다. 컨트롤러가 연결 또는 분리되었는지 인식하기 위해 리스트를 몇 초마다 다시 확인하는 것이 좋습니다. 다음은 C#의 예제입니다.
private bool connected = false;
IEnumerator CheckForControllers() {
while (true) {
var controllers = Input.GetJoystickNames();
if (!connected && controllers.Length > 0) {
connected = true;
Debug.Log("Connected");
} else if (connected && controllers.Length == 0) {
connected = false;
Debug.Log("Disconnected");
}
yield return new WaitForSeconds(1f);
}
}
void Awake() {
StartCoroutine(CheckForControllers());
}
컨트롤러가 인식되면 온스크린 터치 컨트롤을 숨기거나, 컨트롤러 입력을 보완하도록 수정할 수 있습니다. 다음 작업은 게임 컨트롤러 입력을 확인하는 것입니다.
실제 입력 체계는 개발하는 게임의 타입에 크게 좌우됩니다. 하지만 축과 버튼 상태를 읽는 것이 중요합니다. 다음 2D 게임 스테이지를 간단한 예로 들어보겠습니다.
플레이어가 콩 캐릭터를 조종합니다. 캐릭터는 좌우로 이동하고, 점프하고, 적에게 발사할 수 있습니다. Unity 입력 “Horizontal” 축은 기본적으로 기본 프로파일 게임 컨트롤러 D패드와 확장 프로파일 컨트롤러의 왼쪽 아날로그 스틱에 매핑됩니다. 따라서 캐릭터를 앞뒤로 움직이는 코드는 다음과 같이 매우 간단합니다.
float h = Input.GetAxis("Horizontal");
if (h * rigidbody2D.velocity.x < maxSpeed)
rigidbody2D.AddForce(Vector2.right * h * moveForce);
점프 및 발사 액션은 Unity의 입력 설정에서 설정할 수 있습니다.
Unity 에디터 메뉴의 Edit > Project Settings 로 이동한 다음 Input 카테고리를 선택하여 해당 설정에 액세스할 수 있습니다.
조이스틱의 “A” 버튼을 “점프” 액션으로 선택하고 “X” 버튼을 “발사”로 선택합니다.
Unity의 Input 설정에서 다음 액션을 열고 “joystick button 14”를 “Jump”로 지정하고 “joystick button 15”를 “Fire”로 지정합니다.
그러면 코드 처리는 다음과 같습니다.
if (Input.GetButtonDown("Jump") && grounded) {
rigidbody2D.AddForce(new Vector2(0f, jumpForce));
}
if (Input.GetButtonDown("Fire")) {
Rigidbody2D bulletInstance = Instantiate(rocket, transform.position, Quaternion.Euler(new Vector3(0,0,0))) as Rigidbody2D;
bulletInstance.velocity = new Vector2(speed, 0);
}
다음 치트 시트는 Unity의 Input 설정에서 컨트롤러 입력을 매핑하는 데 유용합니다.
이름 | 키코드 | 축 |
---|---|---|
A | 조이스틱 버튼 14 | 조이스틱 축 14 |
B | 조이스틱 버튼 13 | 조이스틱 축 13 |
X | 조이스틱 버튼 15 | 조이스틱 축 15 |
Y | 조이스틱 버튼 12 | 조이스틱 축 12 |
Left Stick | 해당 없음 | 축 1(X) - 가로, 축 2(Y) - 세로 |
오른쪽 스틱 | 해당 없음 | 축 3 - 가로, 축 4 - 세로 |
D패드 위로 | 조이스틱 버튼 4 | 기본 프로파일에만 해당: 축 2(Y) |
D패드 오른쪽 | 조이스틱 버튼 5 | 기본 프로파일에만 해당: 축 1(X) |
D패드 아래로 | 조이스틱 버튼 6 | 기본 프로파일에만 해당: 축 2(Y) |
D패드 왼쪽 | 조이스틱 버튼 7 | 기본 프로파일에만 해당: 축 1(X) |
일시정지 | 조이스틱 버튼 0 | 해당 없음 |
L1/R1 | 조이스틱 버튼 8/조이스틱 버튼 9 | 조이스틱 축 8/조이스틱 축 9 |
L2/R2 | 조이스틱 버튼 10/조이스틱 버튼 11 | 조이스틱 축 10/조이스틱 축 11 |
Unity는 프로젝트의 스크립트에서 Input.GetJoystickNames
를 레퍼런스하는 경우에만 게임 컨트롤러 프레임워크를 프로젝트에 포함시킵니다. Unity iOS Runtime은 사용 가능한 프레임워크를 동적으로 로드합니다.
Apple 문서에는 컨트롤러 입력이 선택 사항이어야 하고 컨트롤러 없이도 게임을 플레이할 수 있어야 한다고 명시되어 있습니다.
Did you find this page useful? Please give it a rating:
Thanks for rating this page!
What kind of problem would you like to report?
Thanks for letting us know! This page has been marked for review based on your feedback.
If you have time, you can provide more information to help us fix the problem faster.
Provide more information
You've told us this page needs code samples. If you'd like to help us further, you could provide a code sample, or tell us about what kind of code sample you'd like to see:
You've told us there are code samples on this page which don't work. If you know how to fix it, or have something better we could use instead, please let us know:
You've told us there is information missing from this page. Please tell us more about what's missing:
You've told us there is incorrect information on this page. If you know what we should change to make it correct, please tell us:
You've told us this page has unclear or confusing information. Please tell us more about what you found unclear or confusing, or let us know how we could make it clearer:
You've told us there is a spelling or grammar error on this page. Please tell us what's wrong:
You've told us this page has a problem. Please tell us more about what's wrong:
Thank you for helping to make the Unity documentation better!
Your feedback has been submitted as a ticket for our documentation team to review.
We are not able to reply to every ticket submitted.