더보기를 누르면 UILabel이 퍼지는 사람
5927 단어 iOSUIStackViewSwift5UILabel
운영 환경
만드는 사람
이런 식으로 버튼을 누르면
UILabel
가 개폐하는 샘플을 만듭니다. 개폐하고 싶은 라벨이 들어간 UIStackView
와 닫을 때의 높이를 가진 UIView
의 들어간 UIStackView
를 붙여 놓는 것으로, UIStackView
의 전환으로 개폐할 수 있게 됩니다.문장은 여기 에서 빌렸습니다.
data:image/s3,"s3://crabby-images/a1df6/a1df6c6dfc67d26897501d8dff2ea3c2d4e58f07" alt=""
Storyboard를 만드는 방법
Storyboard는 이런 느낌입니다.
data:image/s3,"s3://crabby-images/9347b/9347b180ac93528f4d1c582401ab743181d7199f" alt=""
절차
view.isHidden
를 준비해 UILabel
(이하, UIStackView
라고 한다)에 내포합니다. 당연하지만 TitleContainerView
는 0으로 설정해야합니다.numberOfLines
의 설정은 TitleContainerView
, Axis: Vertical
, Alignment: Center
로 합니다.data:image/s3,"s3://crabby-images/52835/52835716cd69b3e34181751778f814815477dcce" alt=""
Distribution: Fill
에 대한 기준이 되는 위치를 제약합니다.data:image/s3,"s3://crabby-images/e8f39/e8f39597d5ab1cd66355c0efb254bf878af4c827" alt=""
data:image/s3,"s3://crabby-images/982e3/982e337d246e7c25bd24d3f0fa808184ea0e0d00" alt=""
TitleContainerView
의 bottom에 연결합니다. 이렇게 하면 TitleContainerView
가 퍼졌을 때 함께 아래로 움직이게 됩니다.data:image/s3,"s3://crabby-images/aec08/aec0869c354cb512b9c78b5585a949436cb254cf" alt=""
data:image/s3,"s3://crabby-images/fe1e2/fe1e2f0d775e2f27579639acecea5db8e6084555" alt=""
TitleContainerView
를 준비하고 안에 빈 UIStackView
를 놓습니다. 이 UIView
의 상하 좌우와 UIStackView
의 상하 좌우를 일치시키도록 제약을 합니다.data:image/s3,"s3://crabby-images/836fe/836fed810680805150d729d3efe40f13b4240253" alt=""
data:image/s3,"s3://crabby-images/3f404/3f404734d18af0a41e5a0f6445f89e0f13e7e348" alt=""
TitleContainerView
에 height 제약을 가합니다. 이 height가 닫힌 상태에서의 높이가 됩니다.data:image/s3,"s3://crabby-images/b58e1/b58e132cdccf17343332d7bac13a54e42206277e" alt=""
data:image/s3,"s3://crabby-images/4d9ea/4d9ea3fe86789cc2581d26974a21b88fb86d9f68" alt=""
이것을 ViewController에 연결해 갑니다.
ViewController
MoreReadViewController.swift
import UIKit
final class MoreReadViewController: UIViewController {
@IBOutlet private var heightView: UIView!
@IBAction private func moreReadButtonTapped(_ sender: UIButton) {
UIView.animate(withDuration: 0.2) { [weak self] in
guard let self = self else { return }
self.heightView.isHidden.toggle()
}
}
}
동작 확인에 필요한 코드만 쓰고 있습니다.
UIView
의 파트를 UIStackView
로 하면 그 파트가 존재하지 않도록 레이아웃이 결정됩니다.hidden
의 높이는 또 다른 TitleContainerView
안에 있는 UIStackView
의 높이에 의해 정해져 있으므로,UIView
가 UIView
가 된다 -> 높이 제약이 없어진다 -> hidden
의 높이는 TitleContainerView
의 높이에 의해 정해진다라는 흐름으로 개폐할 수 있다는 느낌이라고 생각합니다.
여기 에서 복제할 수 있습니다.
덤
처음 움직였을 때, 이런 애니메이션이 되어 버려, 꽤 당황했습니다.
UILabel
가 왜인가 contentMode
가 되어 있었기 때문이었습니다. 기본값은 left
이므로 신경 쓸 필요는 없지만,,,data:image/s3,"s3://crabby-images/6d105/6d10504f4fc2b8019bd41cad010485120a8bc028" alt=""
Reference
이 문제에 관하여(더보기를 누르면 UILabel이 퍼지는 사람), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://qiita.com/kimioman/items/277dcc3a8bf59eba9751텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념
(Collection and Share based on the CC Protocol.)