Android代碼實現刪除拋擲動畫

jopen 10年前發布 | 16K 次閱讀 Android Android開發 移動開發

下面講講是如何通過代碼實現刪除拋擲動畫的。

         如下圖所示就是所說的刪除拋擲功能,對視圖A啟動該動畫效果,動畫完成后視圖A到達B地,在這個過程中既有視圖大小的變化,又有視圖位置的變化:

  Android代碼實現刪除拋擲動畫

         要實現這個動畫效果,需要將位置變換動畫類TranslateAnimation和大小變換動畫類ScaleAnimation結合使用,具體的代碼是這樣子的:

     * 功能描述: 視圖縮小至圖片大小的動畫 
     *  
     * @param fromX 源坐標 
     * @param fromY 
     * @param toX 目的坐標 
     * @param toY 
     * @param xRate 橫縱向縮放比例 
     * @param yRate 
     * @param duration 動畫時長 
     * @return 動畫 
     */  
    private Animation sacleInView( int fromX, int toX, int fromY, int toY, float xRate,  
            float rate, float xTypeValue, float yTypeValue, int duration ){  
        AnimationSet set = new AnimationSet( true );  
        TranslateAnimation go = new TranslateAnimation( fromX, toX, fromY, toY );  
        go.setDuration( duration );  

        ScaleAnimation scale =  
                new ScaleAnimation( 1.0f, xRate, 1.0f, rate, xTypeValue, yTypeValue );  
        scale.setDuration( duration );  

        set.addAnimation( go );  
        set.addAnimation( scale );  

        return set;  
    }  

    /** 
     * 功能描述: 圖片放大至視圖大小的動畫 
     *  
     * @param rromX 源坐標 
     * @param fromY 
     * @param toX 目的坐標 
     * @param toY 
     * @param xRate 橫縱向縮放比例 
     * @param yRate 
     * @param duration 動畫時長 
     * @return 動畫 
     */  
    private Animation sacleOutView( int fromX, int toX, int fromY, int toY, float xRate,  
            float yRate, float xTypeValue, float yTypeValue, int duration ){  
        AnimationSet set = new AnimationSet( true );  
        TranslateAnimation go = new TranslateAnimation( fromX, toX, fromY, toY );  
        go.setDuration( duration );  

        ScaleAnimation scale = new ScaleAnimation( xRate, 1.0f, yRate, 1.0f, xTypeValue, yTypeValue );  
        scale.setDuration( duration );  

        set.addAnimation( go );  
        set.addAnimation( scale );  

        return set;  
}  

簡單的使用例子是這樣的:

public void startAnimation( ){  
        int[ ] fromLocation = new int[ 2 ];  
        view1.getLocationInWindow( fromLocation );  
        int[ ] toLocation = new int[ 2 ];  
        view2.getLocationInWindow( toLocation );  

        Animation scaleOutAnim = sacleOutView(  
        fromLocation[ 0 ] - toLocation[ 0 ], 0,  
        fromLocation[ 1 ] - toLocation[ 1 ], 0,  
        ( float )( ( 1.0 * view1.getWidth( ) ) / view2.getWidth( ) ),  
        ( float )( ( 1.0 * view1.getHeight( ) ) / view2.getHeight( ) ),  
        ( float )( fromLocation[ 0 ] - toLocation[ 0 ] ),  
        ( float )( fromLocation[ 1 ] - toLocation[ 1 ] ),  
        1000 );  
        view.startAnimation( scaleOutAnim );  
    }  
來自:http://blog.csdn.net/ekeuy/article/details/12163773

 本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!