TabBar 애니메이션커스텀해보기

1 답변 글타래를 보이고 있습니다
  • 글쓴이
    • 남수
      참가자
      • 글작성 : 13
      • 답글작성 : 2

      탭바gif

      위에서 보이는것같이

      탭바가 움직이면서 강조되는 효과를 주고싶어서 공부를 해봤어요

       

      기본적인 레이아웃으로는

      collectionView -> 상단tab부분

      view -> 탭바 밑줄

      collectionView -> page부분

      이렇게 3개를 사용할거에요

       

      위의 탭바가될 cell에 선택됬을 때 효과를 정의하고

       


      class TabBarCollectionViewCell: UICollectionViewCell { static let reuseIdentifier = "TabBarCell" @IBOutlet weak var titleLabel: UILabel! func setTitle(title: String) { titleLabel.text = title } override var isSelected: Bool { willSet { if newValue { titleLabel.textColor = .black } else { titleLabel.textColor = .lightGray } } } }

       

      하단의 페이지가될 cell도 정의해볼게요

       


      class TabPageCollectionViewCell: UICollectionViewCell { static let reuseIdentifier = "TabPageCell" lazy var backColor: [UIColor] = [.lightGray, .purple, .orange, .cyan, .magenta] func setColor(index: Int){ self.backgroundColor = backColor[index] } }

       

      제일 중요한거라고 생각되는거중 하나가

      초기값 설정이에요

      저는 여기서 시간좀 많이 썻던거 같아요

      원하는 초기값이 안나와서요…

      보통 selectItem하면 클릭하는 함수가 실행 되겟지하고 설정해보면

      collectionView의 delegate함수의 didSelectItemAt가 실행되지 않아요

       

      selectItem는 Cell의 클릭상태 즉, Cell의 isSelected상태를 변경시키고

      collectionView(_ collectionView: UICollectionView, didSelectItemAt indexPath: IndexPath) 함수는

      delegate의 didSelectItemAt을 실행시켜주더라구요!!

       

      클릭 할 때 cell과 오토레이아웃을 맞춰놓으면

      알아서 움직이더라구요…!!

      처음에는 center를 계산해서 했엇는데 이게 더 좋은 방법같아요

       

       

      이렇게하면 문제가 생겨요

      왜냐하면 AutoLayout이 중복되거든요..!!

      다른 아이템을 선택하면 

      highlightView(밑줄효과)의 leadinng, trailinng이 또 적용되면서 중복되는 현상이 일어나서

      제대로된 레이아웃이 잡히지 않아요

       

       

      지금까지 모르고 지나쳤는데 이번에 구현하면서

      더 레이아웃에 대해 알게된거 같아요

       

      이 문제를 해결 하기위해선

      [NSLayoutConstraint] 타입을 저장할 변수를 하나 두고

      activate, deactivate 로 오토레이아웃을

      중복되지않도록 조절해주는 거에요!

       

      오토레이아웃을 새로잡기전에 deactivate하고

      적용하고나서 activate하는 식으로 하면 되요

       

       

      이제 클릭할 때는 잘 움직이는것을 확인할 수 있어요


      func collectionView(_ collectionView: UICollectionView, didSelectItemAt indexPath: IndexPath) { if collectionView == tabCollectionView { highlightView.translatesAutoresizingMaskIntoConstraints = false constraints = [ highlightView.leadingAnchor.constraint(equalTo: cell.leadingAnchor), highlightView.trailingAnchor.constraint(equalTo: cell.trailingAnchor) ] NSLayoutConstraint.activate(constraints) UIView.animate(withDuration: 0.3) { self.view.layoutIfNeeded() } } } tabPageCollectionView.scrollToItem(at: indexPath, at: .centeredHorizontally, animated: true)

       

      • 이 게시글은 남수에 의해 3 years, 11 months 전에 수정됐습니다.
      • 이 게시글은 남수에 의해 3 years, 11 months 전에 수정됐습니다.
    • 야곰
      키 마스터
      • 글작성 : 37
      • 답글작성 : 580

      오… 밑줄을 view로 사용하지 않고 draw(_:) 메서드를 사용하면 Core Graphics로 선을 그릴수도 있어요 ㅎㅎ
      그렇지만 Core Graphics는 UIKit으로 해결할 수 없는 문제가 있을 때 사용하는 것을 권장하므로 뷰를 사용하는 것이 더 좋을 것 같네요.
      만약 실선이 아니라 점선이었으면 Core Graphics를 사용해야 했을수도 있고, 이미지를 사용해야 했을 수도 있고 그렇겠네요 🙂

1 답변 글타래를 보이고 있습니다
  • 답변은 로그인 후 가능합니다.

logo landscape small

사업자번호 : 743-81-02195
통신판매업 신고번호 : 제 2022-충북청주-1278 호
고객센터 : 카카오톡채널 @yagom