반응형

멀티플레이 로비관련 작업을 하던 중, UI요소 사이에 파티클을 넣어보았다.

작업을 어느정도 마친 뒤, 마지막으로 batch 확인을 했는데 파티클을 겨우 10개 사용했는데 다른 UI와 섞여 batch 수치가 SetPassCall과 함께 폭발하고 있었다.

 

 

일단 파티클을 사용한 UI 요소의 구성은 다음과 같다.

Room(Empty object)의 자식으로 파티클, 스프라이트, 텍스트로 들어가있다.

 

 

위의 게임오브젝트가 10개로 불어난다면 다음과 같은 현상이 일어난다.

 

이걸 10개만 불려도 각각 SetPassCall과 Batch가 18로 불어난다.

UGUI 구조상 Canvas안에서는 계층에 따라 레이어 순서가 정해지니, Render queue나 파티클의 Order in layer를 건드려도 아무 개선이 되지 않는다.

 

 

결국 구조를 바꾸는 수 밖에 없었다.

 

위와 같이 파티클들을 전부 빼서 따로 모아두게되면 막무가내로 했던 구성보다 Batch 수치가 6배 차이가 난다.

이걸로 해결! 이면 좋겠지만, UI를 저거 10개만 쓰고 마무리할것도 아니고 다른 UI요소도 고려해야한다.

 

일단 전제 조건은 다른 UI요소들의 이미지들이 같은 아틀라스에 패킹되어있는것으로 한다.

같은 아틀라스에 패킹되어 있는 이미지를 가진 UI요소들은 어디가 어디위에 겹치던 Batch가 1일것이다.

문제는 파티클이다. Paticles 게임오브젝트 위의 계층에 다른 UI요소가 들어가있으면, 즉 파티클을 다른 UI요소들 사이에 샌드위치로 끼워버리는 순간 문제는 발생한다.

 

위와 같은 상황에서 Frame Debugger를 돌려보면 (새로만든 UI요소) - (Paticles) - (Rooms) 순으로 그려지는것이다!!

 

그렇기 때문에 Particles 게임오브젝트의 배치는 계층 위쪽에 배치하려면 Particles 위의 계층에 아무것도 없어야하고, 그렇지 않으면 제일 밑으로 내려야한다!

 

 

필자의 경우엔 Paticles 위쪽 계층에 UI요소가 많이 있어서 최하단으로 배치했다.

 

 

최하단으로 옮기게 되면 Batch 문제에 탈줄은 했지만, UGUI 계층 문제로 파티클이 파란색 박스를 덮게된다.

 

이건 우리가 원하는 바가 아니므로, 장치를 하나더 추가한다.

Canvas에는 Sort Order를 지정할 수 있다. 이것을 사용해서 해결해보자.

 

 

부모 Canvas에는 Sort Order를 1로, Particles에는 Canvas를 추가해서 Sort Order를 0으로 사용해주면 된다. (Sort Order 수치는 부모 Canvas가 Paticles Canvas보다 높으면 아무거나 상관없다.)

 

이렇게 세팅을 해주면 다른 UI요소를 신경 쓸 필요도 없고, 파티클이 파란 박스를 덮지 않고, 처음에 파티클만 빼서 배치했던 경우와 똑같은 수치의 Batch와 SetPassCall을 확인할 수 있다!!

 

추가로 Canvas를 이용해서 SortOrder를 설정 해주게되면 UI 계층 순서는 신경 쓰지 않아도 된다.

 

마지막으로, 이런 세팅은 위와 같은 경우에만 의미가 있는 세팅이기 때문에 UI요소 한두개에 이펙트 터뜨리는거에 위와 같은 세팅을 해버리면.. 배보다 배꼽이 더 커지는 현상이 발생하므로 잘 선택하여 사용하자.

반응형
반응형
  • 기본 슬롯 단축키

(왼쪽부터)

1. Select : S or Ctrl or Ctrl + Drag

2. Move : M

3. Brush : B

4. Fill box : U

5. Picker : I

6. Eraser : D or Shift or Shift + Drag

7. Fill : G

 

  • 기타 단축키

(블럭 선택 후)

1. 시계방향 회전 : ]

2. 반시계 방향 회전 : [

3. 좌우 반전 : Shift + [

4. 상하 반전 : Shift + ]

반응형
반응형

  • 유니티 버전 2019.3.1f1(LTS)
  • 사용 패드 MOGA XP5-X+ (Xbox)
  • 문제가 있으면 기타 주의사항을 봐주세요.

 

 

  • Buttons
GamePad KeyCode
A button JoystickButton0 / Joystick1Button0
B button JoystickButton1 / Joystick1Button1
X button JoystickButton3 / Joystick1Button3
Y button JoystickButton4 / Joystick1Button4
LB button JoystickButton6 / Joystick1Button6
RB button JoystickButton7 / Joystick1Button7
LT button JoystickButton8 / Joystick1Button8
RT button JoystickButton9 / Joystick1Button9
View button JoystickButton10 / Joystick1Button10
Menu button JoystickButton11 / Joystick1Button11
XBox button JoystickButton12 / Joystick1Button12
AGL, AGR buttons -

  • Joystick, D-PAD

 - Precision stick과 D-PAD는 ProjectSettings - InputManager에서 설정을 한뒤 사용한다.

 - 받아와야하는 Axis와 설정은 다음과 같다.

 

 - D-PAD

 

 - Left precision stick

 

 - Right precision stick

 


  • 기타 주의사항

※ Precision stick의 값을 받아왔을 때, 값이 0이 아닌 소수점의 Positive값이 받아와지는 현상이 있었다.

 - InputManager에서 해당 Axis 옵션의 Dead값을 늘려주면 된다. (필자의 패드 기준으로 0.01로 설정해서 해결)

 

 

반응형
반응형

※※ 해당 글은 꾸준히 업데이트 하는 글입니다.

※※ 참조에 사용한 유니티 dll은 2020.3 LTS 버전 이상입니다.


 

  • 프로젝트

1. 프로젝트 생성 시, 템플릿은 클래스 라이브러리로 생성.

 - 일반 클래스 라이브러리가 아닌 클래스 라이브러리(.Net Framework)를 선택해야 한다.


  • 참조

1. UnityEngine.dll은 UnityEngine.CoreModule.dll로 참조한다.

 - UnityEngine.dll은 일부 클래스의 멤버에서 에러를 띄운다.

 

2. 유니티 dll의 경로는 유니티 설치 경로\유니티 버전\Editor\Data\Managed에 대부분 위치한다.

 - 잘 못찾겠으면 위 경로까지만 들어가서 원하는 dll 파일을 검색해서 찾도록 하자.


 

반응형
반응형

 

 

 유니티는 기본적으로 Handheld.Vibrate() 함수로 진동기능이 들어가있지만. 해당 함수로 실행되는 진동은 약 1초가량으로 생각보다 진동이 길다. (진동 시간 조절이 불가능)

 

게임을 제작하다보면 1초의 긴 진동보다 짧은 진동이 필요할때가 생각보다 많다. 따라서, 짧은 진동을 필요로 할때 Handheld.Vibrate()는 완전히 무쓸모다.

 

안드로이드의 경우 AndroidManifest권한 추가에 코드 몇줄만 넣어주면 되지만, 이놈의 iOS는 뭐가 이리 복잡한지.. 아이폰 유저도 아니라 방법 찾는데 생각보다 많이 헤맸다.

 

iOS의 경우 햅틱이라는 기능이 있는데, 6S모델부터 들어가있다고 한다.

 

UISelectionFeedbackGenerator을 통해 햅틱 기능을 사용할수 있는것 같은데, 개발하는 게임들의 최소 버전이 아이폰5 부터라 최대한 낮은 모델에서도 진동 사용이 가능해야했기에 AudioServicesPlaySystemSound를 사용하기로 했다.

 

AudioServicesPlaySystemSound를 사용하기 위해 일단 에디터에 Plugins/iOS 폴더에 Vibrate.mm파일을 만들어준다. 그리고 이어서 플러그인 파일에 코드 작성.

 

#import <UIKit/UIKit.h>
#import <AudioToolBox/AudioToolBox.h>

extern "C" void Vibrate(int _n)
{
    AudioServicesPlaySystemSound(_n);
}

 

그리고 이어서 스크립트를 생성 후, 다음과 같이 작성 후 사용하면 된다.

 

using System.Runtime.InteropServices;

[DllImport("__Internal")]
public static extern void Vibrate(int _n);

※ 참고로 플러그인 파일명과 함수명은 입맛대로 바꿔도 상관없다.

 

인수에 들어가는 int값은 밑에 값들 중 입맛대로 선택해서 넣으면 된다.

 

1519 // Actuate `Peek` feedback (weak boom)

1520 // Actuate `Pop` feedback (strong boom)

1521 // Actuate `Nope` feedback (series of three weak booms)

 

실행해보니 잘 된다. (물론 잘 되는건 6S부터다. 그 밑의 폰들은 당연히 안된다.)

 

 

반응형

+ Recent posts