IT_Programming/Android_Java

[펌][Android] Animation 정리

JJun ™ 2013. 12. 30. 22:42



 출처

 : http://koreaparks.tistory.com/126



애니메이션 추가설명 : http://www.tipssoft.com/bulletin/board.php?bo_table=FAQ&wr_id=1112


더보기


팁스소프트에서 제공하는 프로그래밍과 관련된 자료나 정보들을 무단으로 복제하거나 게재하는 행위는
상호간의 신뢰를 무너뜨리는 행위이며, 법적인 문제를 야기할 수 있으므로 각별한 주의를 당부드립니다.
* 팁스소프트 저작권 정책 보기 -  http://www.tipssoft.com/bulletin/tb.php/FAQ/637
 
이 자료들은 팁스소프트에서 제공하는 [ 알짜배기 ] 프로그램을 이용하면 더 편리하게 볼수 있습니다.
* 알짜배기 프로그램 받기 -  http://www.tipssoft.com/bulletin/tb.php/QnA/8406
 
* 관리자의 Tipssoft 이야기를 들어보세요 ( 트위터 ID : tipssoft ) 
 
* 안드로이드 강좌 목록 - http://www.tipssoft.com/bulletin/tb.php/old_bbs/501    
 
* 이 예제는 안드로이드 팜으로 만들어졌습니다.
   
 
 
트윈 애니메이션(Tween Animation) 은 View Animation 의 한 종류로 뷰 객체에 애니메이션을
적용할 때 사용합니다. 트윈 애니메이션은 쉽고 간편하게 XML 형식으로 구현할 수 있으며
구성된 XML 파일은 res 폴더에 anim 폴더를 생성하고 해당 폴더 내부에 위치시켜야합니다.
 
이제 트윈 애니메이션에 대해 알아보고 간략한 코드 구성을 살펴보도록 하겠습니다. 먼저 애니메이션의
전체적인 개요를 살펴보고 싶으시면 아래에 링크된 자료를 보시기 바랍니다.
 
    애니메이션 ( Animation ) - 개요 : http://www.tipssoft.com/bulletin/tb.php/FAQ/1111 
   
  
1. 트윈 애니메이션의 종류 및 설명
 
    트윈 애니메이션은 주어진 정보를 이용하여 뷰의 출력 영역을 연산하는 방법을 사용하며 이러한
    방법으로 이동, 회전, 투명화, 크기 변경을 구현할 수 있습니다. 하지만 뷰의 출력에 대한 부분만
    연산하여 출력시키기 때문에 뷰가 화면에 보이지 않더라도 지속적으로 터치 이벤트를 받는 등
    뷰 자체가 애니메이션에 영향을 받지 않으므로 추가적인 처리를 해야할 수도 있습니다.
  
 
    1.1 투명화 적용
 
        트윈 애니메이션으로 투명화를 적용하면 화면에서 뷰가 점점 사라지도록 표현할 수 있고, 반대로
        보이지 않는 뷰가 점점 나타나도록 표현할 수도 있습니다. XML 에서 투명화를 표현할 때 사용하는
        요소 및 속성은 아래와 같습니다.
 
        요소명 - alpha
        속성
            - android:fromAlpha : 애니메이션 시작시 적용될 투명도입니다. 0.0 으로 설정하면 완전한
                                        투명화가 적용되며 1.0 으로 하면 투명도가 적용되지 않습니다.
            - android:toAlpha : 애니메이션 종료시 적용될 투명도입니다. 0.0 으로 설정하면 완전한
                                        투명화가 적용되며 1.0 으로 하면 투명도가 적용되지 않습니다.
 
        투명화 애니메이션은 애니메이션 설정한 시간동안 fromAlpha 속성에 지정한 투명도에서 toAlpha
        속성에 지정한 투명도로 뷰를 변형시킵니다.
 
 
    1.2 크기 변경 ( scale )
  
        크기 변경은 뷰의 크기를 변경하는 것입니다. 시작시 뷰의 크기와 애니메이션이 종료될 때의
        크기를 지정할 수 있으며 크기 변경시 뷰의 어느 위치를 기준으로 변경이 되는지도 설정할 수
        있습니다.
 
        요소명 - scale
        속성
            - android:fromXScale : 애니메이션 시작시 뷰의 너비입니다. 1.0 이 온전한 뷰의 크기를
                        의미하며 1.0 보다 작으면 뷰의 너비가 작아지고, 1.0 보다 크면 뷰의 너비가 커집니다.
            - android:toXScale : 애니메이션 종료시 뷰의 너비입니다. 1.0 이 온전한 뷰의 크기를
                        의미하며 1.0 보다 작으면 뷰의 너비가 작아지고, 1.0 보다 크면 뷰의 너비가 커집니다.
 
            - android:fromYScale : 애니메이션 시작시 뷰의 높이입니다. 1.0 이 온전한 뷰의 크기를
                        의미하며 1.0 보다 작으면 뷰의 너비가 작아지고, 1.0 보다 크면 뷰의 너비가 커집니다.
            - android:toYScale : 애니메이션 종료시 뷰의 높이입니다. 1.0 이 온전한 뷰의 크기를
                        의미하며 1.0 보다 작으면 뷰의 너비가 작아지고, 1.0 보다 크면 뷰의 너비가 커집니다. 
 
            - android:pivotX : 뷰의 크기가 변경될 때 뷰의 위치를 의미합니다. 0% 이면 뷰의 좌측이
                        고정된 상태로 크기가 변경되며 50% 이면 뷰의 중점을 중심으로 뷰의 크기가 변경
                        됩니다. 즉, 뷰가 커질 땐 좌우로 함께 커지고, 작아질때에도 좌우로 줄어듭니다.
            - android:pivotY : 뷰의 크기가 변경될 때 뷰의 위치를 의미합니다. 0% 이면 뷰의 상단이
                        고정된 상태로 크기가 변경되며 50% 이면 뷰의 중점을 중심으로 뷰의 크기가 변경
                        됩니다. 즉, 뷰가 커질 땐 상하로 함께 커지고, 작아질때에도 상하로 줄어듭니다.
            
 
    1.3 이동 ( translate )
 
        두개의 위치 값을 지정하여 시작 위치에서 이동 종료 위치로 뷰를 이동시킵니다.
 
        요소명 - translate
        속성
            - android:fromXDelta : 뷰의 X 좌표상 시작 위치입니다. 수치값을 직접 입력하면 픽셀단위의
                        위치로 판단하여 해당 위치에서 시작하며 퍼센트값을 입력하면 뷰의 너비에서 해당
                        퍼센트를 연산한 위치에서 시작합니다. 또, 퍼센트 뒤에 p 를 붙이면 뷰를 소유한
                        부모 객체의 너비에서 퍼센트를 연산한 위치에서 시작하게 됩니다.
            - android:toXDelta : 뷰의 X 좌표상 이동 종료 위치입니다. 해당 속성이 가질 수 있는 값은
                        fromXDelta 와 같습니다.
            - android:fromYDelta : 뷰의 Y 좌표상 시작 위치입니다. 해당 속성이 가질 수 있는 값은
                        fromXDelta 와 같습니다.
            - android:toYDelta : 뷰의 Y 좌표상 이동 종료 위치입니다. 해당 속성이 가질 수 있는 값은
                        fromXDelta 와 같습니다.
 
 
    1.4 회전 ( rotate )
 
        애니메이션의 시작 시점과 종료 시점의 뷰의 각도, 위치를 지정하여 뷰를 회전 시킵니다.
 
        요소명 - rotate
        속성
            - android:fromDegrees : 애니메이션이 시작될 때 뷰에 적용되는 각도입니다.
            - android:toDegrees : 애니메이션이 종료될 때 뷰에 적용되는 각도입니다.
            - android:pivotX : 회전 애니메이션이 이루어질 X 좌표상의 기준 위치입니다. 이 요소에
                        수치값을 직접 입력하면 픽셀단위의 위치로 판단하여 해당 위치에서 시작하며
                        퍼센트값을 입력하면 뷰의 너비에서 해당 퍼센트를 연산한 위치에서 시작합니다.
                        또, 퍼센트 뒤에 p 를 붙이면 뷰를 소유한 부모 객체의 너비에서 퍼센트를 연산한
                        위치에서 시작하게 됩니다.
            - android:pivoxY : 회전 애니메이션이 이루어질 Y 좌표상의 기준 위치입니다. pivotX 속성과
                        동일하게 값을 설정할 수 있습니다.
   
     
2. set 요소와 부가적인 속성들
   
    XML 형식으로 애니메이션을 정의할 때에는 반드시 set 요소 안에 애니메이션 요소들을 정의해야
    합니다. set 요소는 여러개의 애니메이션을 하나로 그룹짓는 역할을 하며 애니메이션의 효과를
    정의할 수 있는 interpolator 속성을 포함하고 있습니다. 아래의 코드는 이동 애니메이션을 구성하는
    간단한 XML 코드입니다.
  
    <?xml version="1.0" encoding="utf-8"?>
    <set
         xmlns:android="http://schemas.android.com/apk/res/android"
         android:interpolator="@android:anim/bounce_interpolator">

        <translate 
            android:fromYDelta="0%" 
            android:toYDelta="50%"
            android:duration="2000"
            />
    </set>
 
    루트의 set 요소에는 어플리케이션에서 레이아웃을 구성할 때처럼 요소와 속성명들을 해석할 수
    있도록 네임스페이스를 정의해줍니다. set 요소의 interpolator 속성은 뷰의 이동시 어떤 효과를
    부가적으로 표현할지를 정의하는데 set 요소에서 모든 애니메이션에 동일하게 효과를 적용시킬
    수도 있습니다. interpolator 속성으로 정의 가능한 값과 효과는 다음과 같습니다.
  
    @android:anim/accelerate_decelerate_interpolator
 
        애니메이션이 점점 빠르게 동작하다가 점점 천천히 동작합니다.
 
 
    @android:anim/accelerate_interpolator
 
        애니메이션이 점점 빠르게 동작합니다.
 
 
    @android:anim/anticipate_interpolator
 
        애니메이션이 시작할 때 반대 방향으로 동작을 한 후에 본래의 방향으로 동작합니다.
 
 
    @android:anim/anticipate_overshoot_interpolator
 
        애니메이션이 시작할 때 반대 방향으로 동작을 한 후에 종료 지점을 지나갔다가 종료 지점으로
        돌아옵니다. 예를 들어 왼쪽에서 오른쪽으로 이동하는 애니메이션이 있다면 시작할 때 뷰가
        왼쪽으로 조금 움직인 후 오른쪽으로 이동하고, 원래 도착해야할 위치를 지났다가 다시 왼쪽으로
        이동합니다.
 
 
    @android:anim/bounce_interpolator
 
        애니메이션이 종료될 때 튕기면서 스프링 효과를 표현합니다.
 
 
    @android:anim/cycle_interpolator
  
        애니메이션을 동작한 후에 반대 방향으로 한번 더 동작합니다. 만약 오른쪽으로 50 위치까지
        이동하는 애니메이션에 이 효과가 적용되면 오른쪽으로 50 만큼 이동한 후에 왼쪽으로 -50
        위치까지 이동하게됩니다.
       
       
    @android:anim/decelerate_interpolator
 
        애니메이션의 움직임이 점점 느려집니다.
 
 
    @android:anim/linear_interpolator
 
        특별한 효과 없이 일정하게 애니메이션이 동작합니다.
 
 
    @android:anim/overshoot_interpolator
 
        애니메이션이 동작할 때 멈춰야할 위치를 지난 후에 다시 돌아옵니다.
  
 
    set 요소에서는 interpolator 속성과 함께 shareInterpolator 속성을 설정해주어야 합니다.
    shareInterpolator 속성는 interpolator 속성에 설정한 효과를 내부의 다른 애니메이션들이 공유하여
    사용할 것인지 여부를 설정하는 것입니다. 이 속성값은 기본이 true 이며 true 로 설정하면 set 요소
    내의 애니메이션이 interpolator 속성에 설정한 효과로 일괄 적용되며 false 로 설정하면 내부의
    애니메이션에서 설정한 interpolator 속성을 따로따로 적용하게 됩니다.
 
    그래서 애니메이션마다 각기 다른 interpolator 속성을 적용하더라도 set 요소에서 shareInterpolator
    속성에 true 를 지정하면 각자의 애니메이션에서 설정한 효과가 적용되지 않습니다.
 
    또 애니메이션에 startOffset 속성과 duration 속성을 설정할 수 있는데 startOffset 속성은 지정한
    밀리초 시간 후에 애니메이션을 동작하겠다는 것이고, duration 속성은 지정한 밀리초 시간만큼
    애니메이션을 동작하겠다는 것입니다. 기본적으로 set 요소 내부에 정의된 애니메이션은 동시에
    애니메이션이 수행되기 때문에 애니메이션간에 시간 차를 두고싶을 때 startOffset 속성을 사용하며
    duration 속성은 지정하지 않으면 애니메이션이 동작할 수 있는 시간이 설정되지 않는 것이므로
    반드시 지정해주어야합니다.
 
 
3. 간단한 예제 
 
    아래의 코드는 네 종류의 애니메이션을 볼 수 있도록 네개의 버튼을 구성하여 각 버튼을 누를때마다
    하단의 뷰가 동작하도록 구성한 것입니다.
 
    // rotation.xml - 회전
    <?xml version="1.0" encoding="utf-8"?>
    <set xmlns:android="http://schemas.android.com/apk/res/android"
        android:interpolator="@android:anim/cycle_interpolator">
        <rotate
            android:fromDegrees="0"           
            android:toDegrees="-45"           
            android:toYScale="0.0"           
            android:pivotX="0%"           
            android:pivotY="0%"           
            android:duration="1000" 
            />
    </set>
 
    // size.xml - 크기 변경
    <?xml version="1.0" encoding="utf-8"?>
    <set xmlns:android="http://schemas.android.com/apk/res/android"
        android:interpolator="@android:anim/cycle_interpolator">
        <scale
            android:fromXScale="1.0"
            android:toXScale="1.4"
            android:fromYScale="1.0"
            android:toYScale="0.6"
            android:pivotX="50%"        
            android:pivotY="50%"   
            android:duration="1000" 
            />   
    </set>
 
    // transparent.xml - 투명화
    <?xml version="1.0" encoding="utf-8"?>
    <set xmlns:android="http://schemas.android.com/apk/res/android">
        <alpha
            android:fromAlpha="1.0"
            android:toAlpha="0.5"
            android:duration="1000"
            />
    </set>
 
    // move.xml - 뷰 이동
    <?xml version="1.0" encoding="utf-8"?>
    <set xmlns:android="http://schemas.android.com/apk/res/android"
        android:shareInterpolator="false">
        <translate 
            android:interpolator="@android:anim/bounce_interpolator"
            android:fromYDelta="0%" 
            android:toYDelta="50%"
            android:duration="2000"
            />
    </set>
 
    // mix.xml - 복합 애니메이션
    <?xml version="1.0" encoding="utf-8"?>
    <set xmlns:android="http://schemas.android.com/apk/res/android"
        android:shareInterpolator="false">
        <scale
            android:interpolator="@android:anim/accelerate_decelerate_interpolator"
            android:fromXScale="1.0"
            android:toXScale="0.5"
            android:fromYScale="1.0"
            android:toYScale="0.5"
            android:pivotX="50%"
            android:pivotY="50%"
            android:duration="2000" 
            />
        <alpha
            android:fromAlpha="1.0"
            android:toAlpha="0.5"
            android:duration="2000"
            />
        <set android:interpolator="@android:anim/accelerate_interpolator">
            <scale
                android:fromXScale="0.5"
                android:toXScale="0.0"
                android:fromYScale="0.5"
                android:toYScale="0.0"
                android:pivotX="50%"
                android:pivotY="50%"
                android:startOffset="2000"
                android:duration="2000" 
                />
            <rotate
                android:fromDegrees="0"
                android:toDegrees="-45"
                android:toYScale="0.0"
                android:pivotX="50%"
                android:pivotY="50%"
                android:startOffset="2000"
                android:duration="2000" 
                />
        </set>
    </set>
  
    // 소스 코드 - 버튼을 클릭하여 onClickListener 인터페이스의 onClick 메소드가 호출되었을 때
    public void onClick(View view)
    {
        int id = view.getId();
        
        if(id == R.id.rotation_btn) {
            // rotation.xml 에 정의된 애니메이션을 불러온다.
            Animation ani = AnimationUtils.loadAnimation(this, R.anim.rotation);
            // 애니메이션을 동작시킨다.
            m_tween_view.startAnimation(ani);         
  
        } else if(id == R.id.size_btn){
            // size.xml 에 정의된 애니메이션을 불러온다.
            Animation ani = AnimationUtils.loadAnimation(this, R.anim.size);
            // 애니메이션을 동작시킨다.
            m_tween_view.startAnimation(ani); 
          
        } else if(id == R.id.transparent_btn) {
            // transparent.xml 에 정의된 애니메이션을 불러온다.
            Animation ani = AnimationUtils.loadAnimation(this, R.anim.transparent);
            // 애니메이션을 동작시킨다.
            m_tween_view.startAnimation(ani); 
          
        } else if(id == R.id.move_btn) {
            // move.xml 에 정의된 애니메이션을 불러온다.
            Animation ani = AnimationUtils.loadAnimation(this, R.anim.move);
            // 애니메이션을 동작시킨다.
            m_tween_view.startAnimation(ani);          
 
        } else if(id == R.id.mix_btn) {
            // mix.xml 에 정의된 애니메이션을 불러온다.
            Animation ani = AnimationUtils.loadAnimation(this, R.anim.mix);
            // 애니메이션을 동작시킨다.
            m_tween_view.startAnimation(ani);           
        }
    }
 
 
    - 실행 화면
 


 



안드로이드 애니메이션에 관해 정리가 잘 된 블로그에서 퍼온 것 임을 밝힙니다.

출처 : http://blog.naver.com/PostView.nhn?blogId=space5084&logNo=60150456069


여러 애니메이션 효과들에 대해 정리를 해봤습니다.

주로 위아래로 이동하거나 좌우로 이동하는 정도의 애니메이션만 써왔는데

다른 효과들도 좋은 것들이 많은 것 같아 책을 참조하여 정리해봅니다.

 

 

1뷰가 기울어지는 효과를 주는 애니메이션.

기울어지는 효과는 처음봤는데 별로 쓸일이 없지 싶은 효과지만 일단 있다는 것 정도만 알고가자.

 

class SkewAnim extends Animation { public void initialize(int width, int height, int parentWidth, int parentHeight) { super.initialize(width, height, parentWidth, parentHeight); setDuration(3000); // 지속시간 setInterpolator(new LinearInterpolator()); // 일정하게 } protected void applyTransformation(float interpolatedTime, Transformation t) { Matrix matrix = t.getMatrix(); matrix.setSkew(2.0f * interpolatedTime, 0); // 기울기 * 시간 } }

 

 

사용법은 

1 view.startAnimation(new SkewAnim());

 

 

 

2뷰가 회전하는 효과를 주는 애니메이션

camera객체를 사용하여 뷰를 바라보는 시점을 변화시킴으로써 회전하는 효과를 줄수 있다.

여기서 camera객체는 android.graphics에 소속된 camera 객체이다

 

class CameraAnim extends Animation { float cx, cy; public void initialize(int width, int height, int parentWidth, int parentHeight) { super.initialize(width, height, parentWidth, parentHeight); cx = width/2; // 좌표를 뷰의 중앙으로 지정 cy = height/2; setDuration(3000); setInterpolator(new LinearInterpolator()); } protected void applyTransformation(float interpolatedTime, Transformation t) { Camera cam = new Camera(); /** * 360도 * 시간 - 시간이 0~1이므로 점진적으로 360도 회전 */ cam.rotateX(360 * interpolatedTime); cam.rotateY(360 * interpolatedTime); cam.rotateZ(360 * interpolatedTime); Matrix matrix = t.getMatrix(); cam.getMatrix(matrix); // 회전 중심을 이미지 중심으로 하기 위해 카메라를 회전하기 전 중심을 matrix.preTranslate(-cx, -cy); // 원점으로 옮기고 matrix.postTranslate(cx, cy); // 회전 후 다시 원래 위치 } }

 

 

xml 을 통해 애니메이션 정의

 

먼저 한가지 속성을 보고 가겠습니다.

android:interpolator

미리 정의된 안드로이드 애니메이션의 설정을 할수 있습니다.

속성값으로는


linear_interpolator : 일정하게

accelerate_interpolator : 점점 빠르게

decelerate_interpolator : 점점 느리게

accelerate_decelerate_interpolator : 위의 둘을 동시에

anticipate_interpolator : 시작위치에서 조금 뒤로 이동햇다가 이동

overshoot_interpolator : 도착위치를 조금 지나쳣다가 도착위치로 이동

anticipate_overshoot_interpolator : 위의 둘을 동시에

bounce_interpolator : 도착위치에서 튕김

cycle_interpolator : 반복

 

해당 속성값을 어떤식으로 주느냐에 따라서도 보기 좋은 애니메이션 효과를 적용할 수 있습니다.

 

3. translate - 이동 애니메이션 ( 시작, 끝, 지속시간 등을 지정 )

위치 좌표는 정수를 쓰면 절대좌표, %를 쓰면 자기기준, %p를 쓰면 부모기준

 

<?xml version="1.0" encoding="utf-8"?> <set xmlns:android="http://schemas.android.com/apk/res/android" android:interpolator="@android:anim/bounce_interpolator"> <translate android:fromXDelta="0" android:toYDelta="100%" android:duration="3000"/> </set>


4. rotate - 회전 애니메이션 camera를 사용한 회전과는 약간 다르다 ( 회전 각도, 기준점등을 지정 )

 

<?xml version="1.0" encoding="utf-8"?> <set xmlns:android="http://schemas.android.com/apk/res/android" android:interpolator="@android:anim/bounce_interpolator"> <rotate android:fromDegrees="0" android:toDegrees="360" android:pivotX="50%" android:pivotY="50%" android:duration="3000"/> </set>

 

5. scale - 확대/축소 애니메이션 ( 크기, 기준점 등을 지정 )

크기는 0.0~1.0까지 (0%~100%)

 

<?xml version="1.0" encoding="utf-8"?> <set xmlns:android="http://schemas.android.com/apk/res/android" android:interpolator="@android:anim/bounce_interpolator"> <scale android:fromXScale="1.0" android:toXScale="0.0" android:fromYScale="1.0" android:toYScale="0.0" android:pivotX="50%" android:pivotY="50%" android:duration="3000"/> </set>

 

 

6. alpha - 투명도 애니메이션 ( 알파값 지정 0.0~1.0 )

 

<?xml version="1.0" encoding="utf-8"?> <set xmlns:android="http://schemas.android.com/apk/res/android" android:interpolator="@android:anim/accelerate_decelerate_interpolator"> <alpha android:fromAlpha="1.0" android:toAlpha="0.0" android:repeatMode="reverse" android:repeatCount="1" android:duration="3000"/> </set>

 

 

참고로 여러개의 효과를 같이 쓰려면 하나의 set안에 중첩해서 쓰면 됩니다.

 

 

7. layoutAnimation 

- 앞의 애니메이션들은 트윈 애니메이션으로 적용되는 대상이 뷰였지만, 레이아웃 애니메이션은

ViewGroup으로부터 파생되는 레이아웃에 대해 적용되며 레이아웃내의 개별항목에 대해 적용됩니다.

 

<?xml version="1.0" encoding="utf-8"?> <layoutAnimation xmlns:android="http://schemas.android.com/apk/res/android" android:delay="50%" android:animationOrder="reverse" android:animation="@anim/rotate" />

 

delay는 각각의 애니메이션에 대한 startOffset이라고 생각하면 될것 같습니다.

animationOrder는 애니메이션 적용 순서이다. random으로 하면 무작위로 수행

animation은 적용할 애니메이션

 

적용하는 방법은 테스트용으로 listView를 만들고 아래의 속성을 주면 된다.

 

1 android:layoutAnimation="@anim/layoutani"

 

간단히 테스트를 해본 결과는 애니메이션 도중에 listView를 스크롤하여 내리면 좀 엉망으로 나오는 듯 했다.

한화면만을 구성하는 리스트일때정도만 쓸만할듯. 아니면 해결방법이 있을려나...



아무튼 다른 애니메이션효과들이 더 있을지는 모르나 제가 알기로는 이정도의 효과라면

원하는 애니메이션 효과는 다 줄수 있을 것 같습니다.