pile·
모바일·theswing더스윙·

스윙 iOS에서 더 개선된 애니메이션 시스템 만들기

문제UIView.animate·UIViewPropertyAnimator 사용 시 CATransaction 잔존·레이아웃 연쇄 반응·타이밍 충돌·비애니메이션 속성 한계·취소 어려움 등 5가지 비의도적 동작 발생
접근CADisplayLink 기반 SWAnimation 프레임워크 자체 구축. DisplayLinkManager가 화면 갱신 콜백을 중앙 관리하고, SWAnimation이 progress(0.0→1.0)를 직접 전달해 속성 보간을 개발자가 명시적으로 제어. linear·easeIn·easeOut·back 등 easing curve 열거형 포함
결과CATransaction 부작용 완전 차단, textColor 등 비CALayer 속성도 부드럽게 전환. FPSWatcher 등 부가 기능을 추가할 수 있는 애니메이션 인프라 확보
theswing
더스윙 블로그
원문은 여기서 이어서 읽을 수 있어요
원문 읽기
읽음 (0)

이 글과 비슷한

  1. 모바일·토스 SLASH토스 SLASH·

    디자이너가 시안 대신 앱을 만든 이유

    토스 UX 디자이너가 AI를 협력자로 삼아 피그마 시안 대신 실제 SwiftUI 코드로 iOS 앱을 직접 구현한 경험을 다룬다. "데드엔드" 화면(송금·결제 완료 등)을 다음 경험의 시작점으로 전환하는 underlay 컴포넌트를 설계하면서 Metal 셰이더 구현까지 디자이너가 주도했고, 완성된 코드를 개발팀에 전달해 협업 방식 자체를 바꿨다.

    #design-system#ai-coding#ios+2