电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

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

Android 實現的下拉刷新效果

瀏覽:50日期: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
相關文章:
主站蜘蛛池模板: 检验科改造施工_DSA手术室净化_导管室装修_成都特殊科室建设厂家_医疗净化工程公司_四川华锐 | 广州迈驰新GMP兽药包装机首页_药品包装机_中药散剂包装机 | 水厂自动化|污水处理中控系统|水利信息化|智慧水务|智慧农业-山东德艾自动化科技有限公司 | 无水硫酸铝,硫酸铝厂家-淄博双赢新材料科技有限公司 | 云南标线|昆明划线|道路标线|交通标线-就选云南云路施工公司-云南云路科技有限公司 | 专业生物有机肥造粒机,粉状有机肥生产线,槽式翻堆机厂家-郑州华之强重工科技有限公司 | 深圳成考网-深圳成人高考报名网 深圳工程师职称评定条件及流程_深圳职称评审_职称评审-职称网 | 高精度电阻回路测试仪-回路直流电阻测试仪-武汉特高压电力科技有限公司 | 杭州顺源过滤机械有限公司官网-压滤机_板框压滤机_厢式隔膜压滤机厂家 | 短信通106短信接口验证码接口群发平台_国际短信接口验证码接口群发平台-速度网络有限公司 | 精密五金加工厂-CNC数控车床加工_冲压件|蜗杆|螺杆加工「新锦泰」 | 三佳互联一站式网站建设服务|网站开发|网站设计|网站搭建服务商 赛默飞Thermo veritiproPCR仪|ProFlex3 x 32PCR系统|Countess3细胞计数仪|371|3111二氧化碳培养箱|Mirco17R|Mirco21R离心机|仟诺生物 | 包塑软管|金属软管|包塑金属软管-闵彬管业 | 自动记录数据电子台秤,记忆储存重量电子桌称,设定时间记录电子秤-昆山巨天 | 风化石头制砂机_方解石制砂机_瓷砖石子制砂机_华盛铭厂家 | 精密模具加工制造 - 富东懿| 吹塑加工_大型吹塑加工_滚塑代加工-莱力奇吹塑加工有限公司 | 福建珂朗雅装饰材料有限公司「官方网站」 | 滚塑PE壳体-PE塑料浮球-警示PE浮筒-宁波君益塑业有限公司 | 在线钠离子分析仪-硅酸根离子浓度测定仪-油液水分测定仪价格-北京时代新维测控设备有限公司 | 气动隔膜泵-电动隔膜泵-循环热水泵-液下排污/螺杆/管道/化工泵「厂家」浙江绿邦 | 体视显微镜_荧光生物显微镜_显微镜报价-微仪光电生命科学显微镜有限公司 | 护栏打桩机-打桩机厂家-恒新重工| 仿古瓦,仿古金属瓦,铝瓦,铜瓦,铝合金瓦-西安东申景观艺术工程有限公司 | 防锈油-助焊剂-光学玻璃清洗剂-贝塔防锈油生产厂家 | 优考试_免费在线考试系统_培训考试系统_题库系统_组卷答题系统_匡优考试 | 高低温老化试验机-步入式/低温恒温恒湿试验机-百科 | 合肥废气治理设备_安徽除尘设备_工业废气处理设备厂家-盈凯环保 合肥防火门窗/隔断_合肥防火卷帘门厂家_安徽耐火窗_良万消防设备有限公司 | 保温杯,儿童婴童奶瓶,运动水壶「广告礼品杯定制厂家」超朗保温杯壶 | 学叉车培训|叉车证报名|叉车查询|叉车证怎么考-工程机械培训网 | 真石漆,山东真石漆,真石漆厂家,真石漆价格-山东新佳涂料有限公司 | 北京签证代办_签证办理_商务签证_旅游签证_寰球签证网 | 深圳标识制作公司-标识标牌厂家-深圳广告标识制作-玟璟广告-深圳市玟璟广告有限公司 | 搜活动房网—活动房_集装箱活动房_集成房屋_活动房屋 | 艺术涂料_进口艺术涂料_艺术涂料加盟_艺术涂料十大品牌 -英国蒙太奇艺术涂料 | 西安标准厂房_陕西工业厂房_西咸新区独栋厂房_长信科技产业园官方网站 | 周口风机|周风风机|河南省周口通用风机厂 | 最新电影-好看的电视剧大全-朝夕电影网 | 特种阀门-调节阀门-高温熔盐阀-镍合金截止阀-钛阀门-高温阀门-高性能蝶阀-蒙乃尔合金阀门-福建捷斯特阀门制造有限公司 | 采暖炉_取暖炉_生物质颗粒锅炉_颗粒壁炉_厂家加盟批发_烟台蓝澳采暖设备有限公司 | 金属抛光机-磁悬浮抛光机-磁力研磨机-磁力清洗机 - 苏州冠古科技 |