# 문제점
Horizontal이나 Vertical Layout Group을 사용하고,
텍스트들을 중앙정렬하고 싶어서 텍스트들에 각각 SIzeFitter(+Prefered width)를 붙여주면
종종 아래와 같이 겹쳐져 버리는 경우가 발생한다.
내가 원하는건 이런식으로 배열되게 하는 것이었는데...
의외로 해결방법은 간단하다. 위와같은 상황에서는 굳이 ContentSizeFitter를 사용하지말 것.
가급적 LayoutGroup과 SizeFitter는 같이 사용하지말아라!
하위에 있던 fitter를 전부 삭제하고, Horizontal LayoutGroup에서 Control ChildSize의 Width를 체크하자.
# SizeFitter를 꼭 써야하는 경우엔?
하지만 위와 같은 상황이 아니라 Fitter를 꼭 사용해야하는 경우
해당 Layout Group을 레퍼런스잡아서 아래의 코드를 실행하면 강제 업데이트 된다.
LayoutRebuilder.ForceRebuildLayoutImmediate((RectTransform)HorizontalGrp.transform);
# 추가 2
다른 초기화 방법.
horizLayoutGroup.CalculateLayoutInputHorizontal();
horizLayoutGroup.CalculateLayoutInputVertical();
horizLayoutGroup.SetLayoutHorizontal();
horizLayoutGroup.SetLayoutVertical();
# 추가 3
그냥 모든 텍스트들을 다 세팅한 다음 해당 게임오브젝트의 Enable을 껏다가 켜면 대부분 해결된다.
'🌍 Unity > UI & TMP' 카테고리의 다른 글
UI Unmask (0) | 2020.04.07 |
---|---|
유니티 버튼을 눌렀을 때 다른버튼이 반응하게 하기 (0) | 2020.04.04 |
유니티 TextMeshPro 한글 폰트 생성 설정 정리 (0) | 2020.03.30 |
Unity UI Button onClick.AddListener 활용하기 (0) | 2020.02.24 |
Raycaster로 버튼 누르기 (2) | 2019.12.17 |