Android 實現(xiàn)的下拉刷新效果
下面是自己實現(xiàn)的效果:
1、分析
可以將動畫分解成:
睜眼毛驢繞著中心地球旋轉(zhuǎn),并且在到達地球中心時,切換為閉眼毛驢,最后發(fā)射出去
地球自我旋轉(zhuǎn),隨著下拉而緩緩上升,達到半徑距離后停止上升
一顆上下來回移動的衛(wèi)星
2、實現(xiàn)
(1)下載趕集app,然后將其后綴名改為zip解壓獲取我們需要的資源圖片:
(2) 我們先實現(xiàn)衛(wèi)星的上下移動
核心代碼:
@Override protected void onDraw(Canvas canvas) { super.onDraw(canvas); Matrix matrixPlanet = new Matrix(); matrixPlanet.setScale(0.4f, 0.4f); matrixPlanet.postTranslate(locationX / 2 * 3, locationY /4); matrixPlanet.postTranslate(0, upDateY); canvas.drawBitmap(flyingPlanet,matrixPlanet,null); } public void startTranslatePlanet(int duration){ ValueAnimator valueAnimator = new ValueAnimator(); valueAnimator.setFloatValues(-50.0f, 50.0f); valueAnimator.setDuration(duration); valueAnimator.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() { @Override public void onAnimationUpdate(ValueAnimator animation) { upDateY = (float) animation.getAnimatedValue(); invalidate(); } }); valueAnimator.setRepeatCount(ValueAnimator.INFINITE); valueAnimator.setRepeatMode(ValueAnimator.REVERSE); valueAnimator.setInterpolator(new LinearInterpolator()); valueAnimator.start(); }
思想:使用Matrix來設(shè)置圖形變換,調(diào)用setScale()設(shè)置Bitmap縮放大小,然后調(diào)用postTranslate()將Bitmap平移到衛(wèi)星的初始位置。最后使用ValueAnimator計算衛(wèi)星上下移動的距離,再調(diào)用postTranslate()即可。
(3)地球自我旋轉(zhuǎn),隨著下拉而緩緩上升,達到半徑距離后停止上升。
核心代碼:
@Override protected void onDraw(Canvas canvas) { super.onDraw(canvas); Matrix matrixBall = new Matrix(); matrixBall.setScale(0.2f, 0.2f); if ((locationY + upDateY) > (locationY - flyingBall_Height / 2)) { matrixBall.postTranslate(locationX - flyingBall_Width / 2, locationY + upDateY); matrixBall.postRotate(degreeBall, locationX, (locationY +upDateY + flyingBall_Height /2) ); } else { matrixBall.postTranslate(locationX - flyingBall_Width / 2, locationY - flyingBall_Height / 2); matrixBall.postRotate(degreeBall, locationX, locationY); } canvas.drawBitmap(flyingBall, matrixBall, null); canvas.drawBitmap(cloudBig , null , rectfCloudBig , null); canvas.drawBitmap(cloudSmall , null , rectfCloudSmall ,null); } public void startBallAnim(long duration) { ValueAnimator valueAnimator = new ValueAnimator(); valueAnimator.setFloatValues(0.0f, 360.0f); valueAnimator.setDuration(duration); valueAnimator.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() { @Override public void onAnimationUpdate(ValueAnimator animation) { degreeBall = (float) animation.getAnimatedValue(); invalidate(); } }); valueAnimator.setRepeatCount(ValueAnimator.INFINITE); valueAnimator.setInterpolator(new LinearInterpolator()); valueAnimator.start(); } public void UpBall(float offsetY){ if (upDateY!=offsetY) { upDateY = offsetY; invalidate(); } } public void accelerateBall(long duration) { clearAnimation(); startBallAnim(duration); }
思想:同樣使用Matrix,先設(shè)置縮放大小。調(diào)用
matrixBall.postTranslate(locationX - flyingBall_Width / 2, locationY + upDateY);
將bitmap隱藏在view可視范圍的下方,然后通過下拉刷新列表獲取下拉刷新的Y坐標(biāo)的改變量,調(diào)用postTranslate()上移改變量大小的距離即可。自轉(zhuǎn)動畫的實現(xiàn),就是調(diào)用postRotate()方法 使用ValueAnimator 獲取改變量。因為地球是上升的,所以我們需要動態(tài)的設(shè)置旋轉(zhuǎn)的中心。
matrixBall.postRotate(degreeBall, locationX, (locationY +upDateY + flyingBall_Height /2) );
只需要改變減去下拉刷新列表獲取下拉刷新的Y坐標(biāo)的改變量就可以了。
(3) 睜眼毛驢繞著中心地球旋轉(zhuǎn),并且在到達地球中心時,切換為閉眼毛驢,最后發(fā)射出去
核心代碼:
@Override protected void onDraw(Canvas canvas) { super.onDraw(canvas); Matrix matrix = new Matrix(); matrix.setScale(0.3f, 0.3f); matrix.postTranslate(pointDonkey.getDx(), pointDonkey.getDy()); matrix.postRotate(degree, locationX, locationY + flyingBall_Width / 2); matrix.postTranslate(0 , upDateY); canvas.drawBitmap(flyingDonkey, matrix, null); }
思想:與上面一樣,先調(diào)用setScale()設(shè)置縮放大小,在進行平移旋轉(zhuǎn)操作的時候。
matrix.postRotate(degree, locationX, locationY + flyingBall_Width / 2); matrix.postTranslate(0 , upDateY);
我們先繞著還沒有移動的地球旋轉(zhuǎn),然后調(diào)用postTranslate()將其與地球一起上升。
源碼地址:
https://github.com/sangenan/DonkeyRefresh
到這里就結(jié)束啦。
以上就是Android 實現(xiàn)的下拉刷新效果的詳細內(nèi)容,更多關(guān)于Android 下拉刷新的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Android開發(fā)實現(xiàn)的IntentUtil跳轉(zhuǎn)多功能工具類【包含視頻、音頻、圖片、攝像頭等操作功能】
這篇文章主要介紹了Android開發(fā)實現(xiàn)的IntentUtil跳轉(zhuǎn)多功能工具類,該封裝類還包含視頻、音頻、圖片、攝像頭等操作功能,需要的朋友可以參考下2017-11-11解決Android Studio XML編輯界面不顯示下面的Text和Design選項卡
這篇文章主要介紹了解決Android Studio XML編輯界面不顯示下面的Text和Design選項卡,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-03-03Android學(xué)習(xí)筆記之Shared Preference
在之前遇到有個需求是要改settings里面自動轉(zhuǎn)屏的首選項,于是就學(xué)習(xí)了下Shared Preference。Shared Preference是一種簡單的、輕量級的鍵/值對機制,用于保存原始應(yīng)用程序數(shù)據(jù),最常見的就是首選項2013-09-09Android編程實現(xiàn)異步消息處理機制的幾種方法總結(jié)
這篇文章主要介紹了Android編程實現(xiàn)異步消息處理機制的幾種方法,結(jié)合實例形式詳細總結(jié)分析了Android異步消息處理機制的原理、相關(guān)實現(xiàn)技巧與操作注意事項,需要的朋友可以參考下2018-08-08Android控件AppWidgetProvider使用方法詳解
這篇文章主要為大家詳細介紹了Android控件AppWidgetProvider的使用方法詳解,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-08-08Android側(cè)滑菜單之DrawerLayout用法詳解
今天小編就為大家分享一篇關(guān)于Android側(cè)滑菜單之DrawerLayout用法詳解,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2019-03-03Android編程實現(xiàn)應(yīng)用程序開機自啟動的方法
這篇文章主要介紹了Android編程實現(xiàn)應(yīng)用程序開機自啟動的方法,涉及Android權(quán)限控制及廣播操作相關(guān)技巧,需要的朋友可以參考下2017-02-02Android ToolBar 修改邊距的實現(xiàn)方法
這篇文章主要介紹了Android ToolBar 修改邊距的實現(xiàn)方法的相關(guān)資料,通過此文希望能幫助到大家,需要的朋友可以參考下2017-08-08