케이스에서 AutoLayout 배우기
소개
잘 알고 있는 Auto Layout iOS 반응형 디자인을 마스터 을 참고로 AutoLayout에서 배운 것을 기사로 해 가고 싶습니다. 이번에는 케이스에서 Autolayout을 배우고 싶습니다.
케이스 1 동일 폭의 오브젝트를 늘어놓는 케이스
다음과 같이 Button을 3개 균일하게 정렬
data:image/s3,"s3://crabby-images/0cbc7/0cbc7c31671cb304700a9b8ae4a775bb37b0bc9f" alt=""
거친 절차
1. ContainerView
배치
2. Button
를 3개 배치
3. 제약 추가
Button
를 그룹화하기 위해서 부모가 되는 ContainerView
( UIView
)를 작성해, 중첩한다.
data:image/s3,"s3://crabby-images/e27a0/e27a0b9e97df0b99a4946493e2125aa7f60182c4" alt=""
제약에 대해
수평 방향
ContainerView
1. ContainerView.leading = leading
2. trailing = ContainerView.trailing
Button
3. Button1.leading = leading + 5
4. Button2.leading = Button1.trailing + 5
5. trailing = Button3.trailing + 5
6. Button3.leading = Button2.trailing + 5
7. Button2.width = Button1.width
8. Button3.width = Button1.width
ContainerView
는 화면 폭에 고정되어 있어(1, 2) 폭은 결정하고 있으므로 3개의 버튼의 폭을 동일하게 해(7, 8), 수평 방향의 제약을 붙이는 것으로(3~6) , Button
의 너비가 결정됩니다.
수직 방향
ContainerView
1. ContainerView.centerY = centerY
Button
2. Button1.top = top
3. bottom = Button1.bottom
4. Button2.centerY = centerY
5. Button3.centerY = centerY
수직 방향의 제약은 이것만으로 좋다. 왜냐하면 Button
의 높이(폭)는 텍스트와 Font에 의해 결정되기 때문이다. 따라서 2, 3의 제약에 의해 자연과 부모의 ContainerView
의 높이도 결정한다. 1. 에 의해 수직 방향의 제약이 화면의 중앙에 설정되어 있으므로 여기서 수직 방향의 제약이 결정된다. ContainerView
의 높이가 결정되어 있으므로 (4, 5) 에 의해 Button2
, Button3
의 높이도 결정한다.
이것이 간과하기 쉽고 높이 제약을 여분으로 추가하는 경우가 많다. 여분의 제약은 버그의 온상이 된다. 의도적으로 Button
의 높이를 결정하고 싶은 경우는 ContainerView
의 높이를 결정하면 변경할 수 있다.
제약의 전체 이미지
data:image/s3,"s3://crabby-images/b6438/b64384cddcf0d8d8a32369f0df73afa77e899f71" alt=""
사례 2 등 간격으로 배열되는 객체
다음과 같이 Button을 3개 균일하게 나란히 하고 등간격으로 배치한다.
data:image/s3,"s3://crabby-images/04554/0455455c752905546aeb2a87e11cbfd95f750ac7" alt=""
거친 절차
1. ContainerView
배치
2. Button
를 3개 배치
3. 간격을 위해 사용 View
배치
4. 제약 추가
첫 번째와 절차는 대략 동일하지만 이번에는 등 간격으로 배치하기 위한 View를 준비한다. ( Space1
, Space2
)
data:image/s3,"s3://crabby-images/8982c/8982c189f28b28508b103942a5c94c4166fe94b1" alt=""
제약에 대해
수평 방향
ContainerView
1. ContainerView.leading = leading
2. trailing = ContainerView.trailing
Button
3. Button1.leading = leading + 5
4. Space1.leading = Button1.trailing
5. Button2.leading = Space1.trailing
6. Space2.leading = Button2.trailing
7. Button3.leading = Space2.trailing
8. trailing = Button3.trailing + 5
9. Space2.width = Space1.width
10. Button2.width = Button1.width
11. Button3.width = Button1.width
케이스 1과 거의 같지만 이번에는 4~7의 제약에 의해 Button 사이의 폭은 Space1
와 Space2
의 폭으로 하고 있다. 이 외에도 9의 제약 조건에서 Space1
와 Space2
를 같은 너비로 설정하여 가로 방향의 너비를 결정하는 등 간격 폭을 계산합니다.
수직 방향
ContainerView
1. ContainerView.centerY = centerY
Button
2. Button1.top = top
3. bottom = Button1.bottom
4. Button2.centerY = centerY
5. Button3.centerY = centerY
6. Space1.centerY = Button1.centerY
7. Space2.centerY = Button1.centerY
8. Space1.height = 1
9. Space2.height = 1
수직 방향 제약은 케이스 1과 거의 동일하다. 다른 부분은 7~9에 의해 Space의 수직 방향의 제약을 결정하고 있는 곳이다.Space1
와 Space2
는 간격을 결정하기 위한 보기이므로 색은 투명색을 설정한다. 그러나, 투명색을 설정하는 경우에는, 투과 처리가 들어가 묘화 퍼포먼스가 떨어지므로, 배경색이 정해져 있는 경우는 배경색을 설정하는 편이 좋다.
제약의 전체 이미지
Reference
이 문제에 관하여(케이스에서 AutoLayout 배우기), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다
https://qiita.com/shoheiyokoyama/items/1ff769564dab60767c67
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념
(Collection and Share based on the CC Protocol.)
다음과 같이 Button을 3개 균일하게 정렬
data:image/s3,"s3://crabby-images/0cbc7/0cbc7c31671cb304700a9b8ae4a775bb37b0bc9f" alt=""
거친 절차
1.
ContainerView
배치2.
Button
를 3개 배치3. 제약 추가
Button
를 그룹화하기 위해서 부모가 되는 ContainerView
( UIView
)를 작성해, 중첩한다.data:image/s3,"s3://crabby-images/e27a0/e27a0b9e97df0b99a4946493e2125aa7f60182c4" alt=""
제약에 대해
수평 방향
ContainerView
1.
ContainerView.leading = leading
2. trailing = ContainerView.trailing
Button
3.
Button1.leading = leading + 5
4. Button2.leading = Button1.trailing + 5
5. trailing = Button3.trailing + 5
6. Button3.leading = Button2.trailing + 5
7. Button2.width = Button1.width
8. Button3.width = Button1.width
ContainerView
는 화면 폭에 고정되어 있어(1, 2) 폭은 결정하고 있으므로 3개의 버튼의 폭을 동일하게 해(7, 8), 수평 방향의 제약을 붙이는 것으로(3~6) , Button
의 너비가 결정됩니다.수직 방향
ContainerView
1.
ContainerView.centerY = centerY
Button
2.
Button1.top = top
3. bottom = Button1.bottom
4. Button2.centerY = centerY
5. Button3.centerY = centerY
수직 방향의 제약은 이것만으로 좋다. 왜냐하면
Button
의 높이(폭)는 텍스트와 Font에 의해 결정되기 때문이다. 따라서 2, 3의 제약에 의해 자연과 부모의 ContainerView
의 높이도 결정한다. 1. 에 의해 수직 방향의 제약이 화면의 중앙에 설정되어 있으므로 여기서 수직 방향의 제약이 결정된다. ContainerView
의 높이가 결정되어 있으므로 (4, 5) 에 의해 Button2
, Button3
의 높이도 결정한다.이것이 간과하기 쉽고 높이 제약을 여분으로 추가하는 경우가 많다. 여분의 제약은 버그의 온상이 된다. 의도적으로
Button
의 높이를 결정하고 싶은 경우는 ContainerView
의 높이를 결정하면 변경할 수 있다.제약의 전체 이미지
data:image/s3,"s3://crabby-images/b6438/b64384cddcf0d8d8a32369f0df73afa77e899f71" alt=""
사례 2 등 간격으로 배열되는 객체
다음과 같이 Button을 3개 균일하게 나란히 하고 등간격으로 배치한다.
data:image/s3,"s3://crabby-images/04554/0455455c752905546aeb2a87e11cbfd95f750ac7" alt=""
거친 절차
1. ContainerView
배치
2. Button
를 3개 배치
3. 간격을 위해 사용 View
배치
4. 제약 추가
첫 번째와 절차는 대략 동일하지만 이번에는 등 간격으로 배치하기 위한 View를 준비한다. ( Space1
, Space2
)
data:image/s3,"s3://crabby-images/8982c/8982c189f28b28508b103942a5c94c4166fe94b1" alt=""
제약에 대해
수평 방향
ContainerView
1. ContainerView.leading = leading
2. trailing = ContainerView.trailing
Button
3. Button1.leading = leading + 5
4. Space1.leading = Button1.trailing
5. Button2.leading = Space1.trailing
6. Space2.leading = Button2.trailing
7. Button3.leading = Space2.trailing
8. trailing = Button3.trailing + 5
9. Space2.width = Space1.width
10. Button2.width = Button1.width
11. Button3.width = Button1.width
케이스 1과 거의 같지만 이번에는 4~7의 제약에 의해 Button 사이의 폭은 Space1
와 Space2
의 폭으로 하고 있다. 이 외에도 9의 제약 조건에서 Space1
와 Space2
를 같은 너비로 설정하여 가로 방향의 너비를 결정하는 등 간격 폭을 계산합니다.
수직 방향
ContainerView
1. ContainerView.centerY = centerY
Button
2. Button1.top = top
3. bottom = Button1.bottom
4. Button2.centerY = centerY
5. Button3.centerY = centerY
6. Space1.centerY = Button1.centerY
7. Space2.centerY = Button1.centerY
8. Space1.height = 1
9. Space2.height = 1
수직 방향 제약은 케이스 1과 거의 동일하다. 다른 부분은 7~9에 의해 Space의 수직 방향의 제약을 결정하고 있는 곳이다.Space1
와 Space2
는 간격을 결정하기 위한 보기이므로 색은 투명색을 설정한다. 그러나, 투명색을 설정하는 경우에는, 투과 처리가 들어가 묘화 퍼포먼스가 떨어지므로, 배경색이 정해져 있는 경우는 배경색을 설정하는 편이 좋다.
제약의 전체 이미지
Reference
이 문제에 관하여(케이스에서 AutoLayout 배우기), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다
https://qiita.com/shoheiyokoyama/items/1ff769564dab60767c67
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념
(Collection and Share based on the CC Protocol.)
Reference
이 문제에 관하여(케이스에서 AutoLayout 배우기), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://qiita.com/shoheiyokoyama/items/1ff769564dab60767c67텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념
(Collection and Share based on the CC Protocol.)