목표

  • Flutter에서 애니메이션의 기본 개념.
  • AnimatedContainer 위젯을 사용하여 간단한 애니메이션을 구현.
  • Hero 위젯으로 화면 전환 트랜지션 효과 적용.

1.애니메이션의 기본 개념

Flutter에서는 애니메이션을 사용하여 UI를 더 역동적으로 만들 수 있습니다. Flutter는 프레임워크에 내장된 다양한 애니메이션 도구를 제공하며, 이를 통해 간단한 움직임부터 복잡한 트랜지션까지 구현할 수 있습니다.

Flutter 애니메이션 종류

1.1 암시적 애니메이션:

  • AnimateContainer, AnimateOpacity 등 애니메이션이 포함된 위젯.
  • 코드가 간단하고 구현이 쉽다.

1.2 명시적 애니메이션:

  • AnimationController와 Tween을 사용하여 세부적으로 제어.
  • 더 복잡한 애니메이션을 구현할 때 사용.

2. AnimatedContainer 위젯

AnimatedContainer는 상태 변화에 따라 부드러운 전환을 자동으로 처리합니다.

새로운 프로젝트 또는 이전 프로젝트의 소스코드를 다음과 같이 작성합니다.

결과

  • 버튼 클릭 시 AnimatedContainer가 크기와 색상을 부드럽게 전한합니다.
  • duration 속성으로 애니메이션의 시간을 설정합니다.
  • curve 속성으로 애니메이션의 동작을 설정합니다.(예: Curves.easeInOut).

3. Hero 위젯

Hero 위제은 화면 전환 시 특정 위젯 간의 애니메이션을 제공합니다

3.1 MainPage에서 SecodPage로 전환하며 이미지 이동 효과를 구현해보겠습니다.

MainPage 코드를 다음과 같이 작성해보세요

SecondPage 소스코드

결과

  • MainPage에서 이미지를 클릭하면 SecondPage로 이동하며 이미지가 부드럽게 확대됩니다.
  • Hero 위젯의 tag 속성이 동일한 위젯 간에 애니메이션을 연결합니다.

4. 실습

1단계: 위치 이동 애니메이션 구현

  • AnimatedContainer를 사용하여 버튼 클릭 시 사각형이 화면 왼쪽으로 이동하도록 구현하세요.
  • 힌트
    • AnimatedContainer의 aligment 속성을 변경합니다.
    • 예: Aligment.center –> Aligment.centerLeft()

2단계: Hero 위젯 확장

  • Hero 위젯을 사용하여 이미지뿐만 아니라 텍스트를 함께 이동시키도록 해보세요.
  • 힌트:
    • Column으로 이미지와 텍스트를 그룹화하고 Hero 위젯을 묶으세요.
    • 두 패이지 모두 같은 Tag를 사용해야 애니메이션이 연결됩니다.

5. 결론

이번에는 Flutter에서 간단한 애니메이션을 구현하는 방법과 전환 트랜지션을 배웠습니다. 이를 통해 역동적인 효과를 추가할 수 있습니다. 다음 시간에는 Flutter 네트워킹 및 HTTP 요청 처리를 알아 보겠습니다.

감사합니다.


TechTinkerer's에서 더 알아보기

구독을 신청하면 최신 게시물을 이메일로 받아볼 수 있습니다.

댓글 남기기

  • 3. 첫 번째 Flutter 앱 만들기: Hello, Flutter

    Flutter 앱 기본 구조 이해 및 간단한 앱 실행 방법.

  • 2. Flutter 개발 환경 설정하기

    Flutter 개발 환경을 설정하고 첫 앱 실행 준비 완료.

  • 1. Flutter란 무엇인가?

    목표 Flutter의 기본 개념과 특징을 이해하고, 앱 개발에 Flutter가 적합한 이유를 알아보겠습니다. 1. 1 소개 Flutter는 Google에서 개발한 오픈소스 UI 프레임워크로, 하나의 코드베이스로 Android, iOS, 웹, 데스크톱 앱을 개발할 수 있습니다. 빠른 개발 속도와 일관된 UI, 뛰어난 성능이 장점입니다. Flutter의 주요 특징 Flutter의 주요 활용 사례 1. 2 사전 준비 Flutter를 시작하기 위해 필요한 개발…

  • [Flutter] 타이머 앱 알람 추가하기

    타이머 앱에 알람 기능 추가 방법과 필요한 파일 설정을 설명합니다.

  • [Flutter] 타이머 앱 만들기

    Flutter로 간단한 타이머 앱을 생성하고 기능을 구현하는 방법을 설명합니다.

← 뒤로

응답해 주셔서 감사합니다. ✨

TechTinkerer's에서 더 알아보기

지금 구독하여 계속 읽고 전체 아카이브에 액세스하세요.

계속 읽기

TechTinkerer's에서 더 알아보기

지금 구독하여 계속 읽고 전체 아카이브에 액세스하세요.

계속 읽기