취소

커뮤니티

가이드

서포트

전체

정말 머리아픕니다 애니메이션...

글도 머리아프게 써있을수 있으므로(?) 원본글에서 관람 추천드립니다(?)

http://itmir.tistory.com/515

정말 오랜만입니다

글쓰는거 참 어렵내요;

이번에는 아주 간단한 애니메이션에 대해 알아보겠습니다

30. 애니메이션에 대해 알아보자 (Tween Animation)

30-1 애니메이션?

이 강좌에서 알려드릴 애니메이션은 Tween Animation이라는 이름을 가진 애니메이션 입니다

트윈 애니메이션 이라고 하는대요

버튼이 움직이거나, 사라지거나, 위치가 바뀌거나, 커지거나

이런 효과를 띄울수 있습니다

사용되는 속성이 적지 않고 이해하기 어려운 부분이 많습니다

다음 강좌가 올라올때까지 예제소스를 숨겨두지 말고 바로 오픈하고 있으니 글 한번 보시고 바로 소스를 보시는걸 추천드립니다

참고로 이 트윈 애니메이션은 간단한 애니메이션입니다;

나중에는 그래프 애니메이션등등등... 머리아파요 ㅠㅠ

30-2 메인 레이아웃 투척

30대 강좌에서 레이아웃을 공부하는것은 무의미 하므로 투척합니다

메인 레이아웃에는 버튼 5개를 만들어 주시면 됩니다

이 강좌에서 배울 애니메이션은 4가지이고, Set이라는건 두가지 이상의 효과를 동시에 사용할때 사용합니다

30-3 res/anim

애니메이션을 정의한 xml파일은 res/anim폴더에 들어있습니다

[Development/App] - #3 App의 구조와 동작 원리 강좌에서 res폴더 내부를 관찰할때 설명했던 부분입니다

혹시 까먹으신분 있으실까봐...

기본적으로 프로젝트를 만들면 이 폴더는 없습니다

따로 만들어 주시면 됩니다

res/anim에는 5가지의 xml 파일을 만들꺼예요

먼저 투명도를 조절하는 alpha부터 관찰해 봅시다

정말 간단합니다

저 <alpha> 태그에 정의된 대로 애니메이션이 표시될 겁니다

먼저, 어떤 속성들이 존재하는지 확인해 보겠습니다

종합해 보면, 10초동안 처음에 완전 투명에서 불투명으로 투명도를 바꿔라 라는 뜻입니다

<alpha>에서 3개의 속성만 사용할수 있을까요?

그건 아닙니다

아래에 공통적으로 쓰이는 몇가지 속성을 입력해 두겠습니다

이중 android:interpolator에 들어가는 속성에 대해 자세한 설명을 더보기 처리 해두었습니다

다음은 회전을 담당하는 rotate입니다

여기서도 처음 보는 속성들이 몇개 보입니다

이부분이 좀 이해하기 어렵습니다...

android:fromDegrees와 android:toDegrees는 직접 값을 변경해 보시면서 알아가시는게 확실히 와닿습니다

아래 두개의 설명을 더 자세하게 드리면

View가 회전할때 회전의 중심이 되는 중심 축을 설정합니다

이때 단위를 "정수", "%", "%p"를 사용할수 있는대요

정수의 경우는 절대 좌표이고, %는 애니메이션을 적용할 View를 기준으로 한 비율, %p는 View를 감싸는 부모 View를 기준으로 한 비율입니다

이해가 안됩니다...

제가 이해한것이 맞다면 이렇게 표현될것입니다

50%, 50%는 딱 중간이겠지요?

즉 중간을 기준으로 0도부터 360도 까지 회전한다 라는 뜻입니다

3번째로 크기를 담당하는 Scale입니다

으어어어어어어어어

머리아프네요

다음은 위치변경 입니다

이제 마지막으로 애니메이션을 묶을수 있는 Set에 대해 알아봅시다

이건... 그냥 <set> </set>으로 여러 애니메이션들을 묶어주시면 됩니다 ㅋㅋㅋ

작동 영상을 확인해 보겠습니다

간단하다고 했지만 설명하면 이게 뭔말인지 모르실겁니다

저도 아직 완벽하게 이해한부분이 아니므로 틀린부분이 있을수 있습니다

많은 지적 부탁드립니다

java로 애니메이션을 만드는 방법은 자세한 글이 있어 소게해 드립니다

http://blog.naver.com/jolangma/150115948509

이 강좌의 예제소스는 그냥 업로드 합니다

카페에서는 원본글에서만 다운로드가 가능합니다

예제소스 다운로드 : http://itmir.tistory.com/515

머리가 아파서 횡설수설한거같네요;

예제소스 뜯어보시며 값 하나씩 수정해 보시면 더 정확히 아실수 있을겁니다