亚洲免费在线视频-亚洲啊v-久久免费精品视频-国产精品va-看片地址-成人在线视频网

您的位置:首頁技術文章
文章詳情頁

Android 實現的下拉刷新效果

瀏覽:49日期:2022-09-17 17:46:51

下面是自己實現的效果:

Android 實現的下拉刷新效果

1、分析

可以將動畫分解成:

睜眼毛驢繞著中心地球旋轉,并且在到達地球中心時,切換為閉眼毛驢,最后發射出去

地球自我旋轉,隨著下拉而緩緩上升,達到半徑距離后停止上升

一顆上下來回移動的衛星

2、實現

(1)下載趕集app,然后將其后綴名改為zip解壓獲取我們需要的資源圖片:

Android 實現的下拉刷新效果

(2) 我們先實現衛星的上下移動

核心代碼:

@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來設置圖形變換,調用setScale()設置Bitmap縮放大小,然后調用postTranslate()將Bitmap平移到衛星的初始位置。最后使用ValueAnimator計算衛星上下移動的距離,再調用postTranslate()即可。

(3)地球自我旋轉,隨著下拉而緩緩上升,達到半徑距離后停止上升。

核心代碼:

@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,先設置縮放大小。調用

matrixBall.postTranslate(locationX - flyingBall_Width / 2, locationY + upDateY);

將bitmap隱藏在view可視范圍的下方,然后通過下拉刷新列表獲取下拉刷新的Y坐標的改變量,調用postTranslate()上移改變量大小的距離即可。自轉動畫的實現,就是調用postRotate()方法 使用ValueAnimator 獲取改變量。因為地球是上升的,所以我們需要動態的設置旋轉的中心。

matrixBall.postRotate(degreeBall, locationX, (locationY +upDateY + flyingBall_Height /2) );

只需要改變減去下拉刷新列表獲取下拉刷新的Y坐標的改變量就可以了。

(3) 睜眼毛驢繞著中心地球旋轉,并且在到達地球中心時,切換為閉眼毛驢,最后發射出去

核心代碼:

@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); }

思想:與上面一樣,先調用setScale()設置縮放大小,在進行平移旋轉操作的時候。

matrix.postRotate(degree, locationX, locationY + flyingBall_Width / 2); matrix.postTranslate(0 , upDateY);

我們先繞著還沒有移動的地球旋轉,然后調用postTranslate()將其與地球一起上升。

源碼地址:

https://github.com/sangenan/DonkeyRefresh

到這里就結束啦。

以上就是Android 實現的下拉刷新效果的詳細內容,更多關于Android 下拉刷新的資料請關注好吧啦網其它相關文章!

標簽: Android
相關文章:
主站蜘蛛池模板: 精品久久在线 | 国产精品不卡无毒在线观看 | 欧美精品一区二区在线观看 | 日本一区二区不卡视频 | 日韩欧美~中文字幕 | 韩国自拍偷自拍亚洲精品 | 最新亚洲情黄在线网站无广告 | 国产精品国产欧美综合一区 | 国产在线精品一区免费香蕉 | 国产欧美日韩图片一区二区 | 精品国产一区在线观看 | 国产精品午夜波多野结衣性色 | 欧美成人毛片 | 亚洲精品久久片久久 | 99久久精品免费观看区一 | 精品成人在线 | 日韩一级片在线观看 | 日本韩经典三级在线播放 | 美女张开腿让人捅 | 国产女厕偷窥系列在线视频 | 亚洲精品一区二区三区在线观看 | 亚洲国产成人久久三区 | 日韩一级特黄 | 亚洲在线观看视频 | 69欧美另类xxxxx高清 | 日黄网站| 国产精品久久久一区二区三区 | 久久a 热6 | 真人毛片免费全部播放完整 | 高清不卡一区二区三区 | 国产精品青草久久 | 精品久 | 看真人视频一级毛片 | 日本欧美视频 | 日本特级黄毛片毛片视频 | 国产精品永久在线 | 手机看片久久高清国产日韩 | 黄色三级毛片网站 | 一区二区不卡视频在线观看 | 久久99精品久久久久久久不卡 | 欧美一级成人免费大片 |