Android自定義view仿微信刷新旋轉(zhuǎn)小風(fēng)車
本文實(shí)例為大家分享了Android仿微信刷新旋轉(zhuǎn)小風(fēng)車 具體代碼,供大家參考,具體內(nèi)容如下
不太會(huì)錄像,沒辦法,智能截圖了
不多說了,直接上代碼
package com.shipneg.demoysp.demo; import android.content.Context; import android.graphics.Bitmap; import android.graphics.Canvas; import android.graphics.Matrix; import android.graphics.Paint; import android.os.CountDownTimer; import android.util.AttributeSet; import android.util.Log; import android.view.MotionEvent; import android.widget.ImageView; /** * Created by dell on 2017/4/7. */ public class RotationView extends ImageView { /** * 要轉(zhuǎn)動(dòng)的圖片 **/ private Bitmap bitMap; /** * 風(fēng)車每次轉(zhuǎn)動(dòng)的弧度 **/ private int rad = 0; /** * 風(fēng)車移動(dòng)的軌跡 **/ private int excursion = -100; /** * 圖片的寬度:在這里提供的是正方形的圖片,所以寬度和高度是一樣的 **/ private int width = 0; /*** * 圖片的高度:在這里提供的是正方形的圖片,所以寬度和高度是一樣的 **/ private int height = 0; /** * 定義一個(gè)畫筆 **/ private Paint paint = new Paint(); public RotationView(Context context, AttributeSet attrs) { super(context, attrs); } public RotationView(Context context, AttributeSet attrs, int defStyleAttr) { super(context, attrs, defStyleAttr); } public RotationView(Context context) { super(context); } /** * 獲取圖片的寬和高 */ public void initSize() { width = bitMap.getWidth(); height = bitMap.getHeight(); postInvalidate(); } public void setBitMap(Bitmap bitMap) { this.bitMap = bitMap; } //一圖片的寬和高來設(shè)定自定義View的寬和高,由于是正方形寬和高是一樣的 @Override protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) { // TODO Auto-generated method stub super.onMeasure(widthMeasureSpec, heightMeasureSpec); setMeasuredDimension(widthMeasureSpec, heightMeasureSpec); } CountDownTimer c = new CountDownTimer(5000, 10) { @Override public void onTick(long millisUntilFinished) { postInvalidate(); rad = rad + 7; } @Override public void onFinish() { downY = 0; excursion = -100; postInvalidate(); } }; /*** * 實(shí)現(xiàn)onDraw方法把風(fēng)車圖片繪制出來,同時(shí)繪制出來風(fēng)車的旋轉(zhuǎn)效果,通過Matrix來控制 */ @Override protected void onDraw(Canvas canvas) { Matrix matrix = new Matrix(); // 設(shè)置轉(zhuǎn)軸位置 matrix.setTranslate((float) width / 2, (float) height / 2); // rad -=15;//每次旋轉(zhuǎn)的弧度增量為3當(dāng)然,數(shù)字越大轉(zhuǎn)動(dòng)越快 // 開始轉(zhuǎn) matrix.preRotate(rad); // 開始平移 matrix.postTranslate(0, excursion); // 轉(zhuǎn)軸還原 matrix.preTranslate(-(float) width / 2, -(float) height / 2); //繪制風(fēng)車圖片 canvas.drawBitmap(bitMap, matrix, paint); super.onDraw(canvas); } private int downY = 0; private int moveY = 0; private int abc = 0; @Override public boolean onTouchEvent(MotionEvent event) { int action = event.getAction(); switch (action) { case MotionEvent.ACTION_DOWN://隨著手指的move而不斷進(jìn)行重繪,進(jìn)而讓風(fēng)車轉(zhuǎn)動(dòng)起來 postInvalidate();//調(diào)用方法進(jìn)行重繪 downY = (int) event.getY(); c.cancel(); break; case MotionEvent.ACTION_MOVE://隨著手指的move而不斷進(jìn)行重繪,進(jìn)而讓風(fēng)車轉(zhuǎn)動(dòng)起來 //調(diào)用方法進(jìn)行重繪 int movey2 = moveY; rad = (int) -event.getY() * 6;//旋轉(zhuǎn)的速度 moveY = (int) (event.getY() - downY);//手指移動(dòng)的距離 int chz = moveY - movey2; if (chz > 10) { chz = chz / 10; } else if (chz < -10) { chz = chz / 10; } Log.e("TAG:" + excursion, "chz: " + chz + "http://moveY:" + moveY + "http://movey2:" + movey2); //100是向下滑動(dòng)的最大距離 if (excursion >= 100) { abc = abc + chz; if (chz < 0 && abc - chz < 0) { excursion = excursion + chz; } } else { //開始向下運(yùn)動(dòng) excursion += chz; } postInvalidate(); c.cancel(); break; case MotionEvent.ACTION_UP: c.start(); break; } return true; } }
調(diào)用方法
//調(diào)用的方法 RotationView rotation = (RotationView) view.findViewById(R.id.rotationView); BitmapDrawable drawable = (BitmapDrawable) getResources().getDrawable(R.drawable.fengche); rotation.setBitMap(drawable.getBitmap()); rotation.initSize();
圖片資源自己切的,本人不會(huì)ps,所以有點(diǎn)切的不太好,見諒
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Android自定義ListView實(shí)現(xiàn)下拉刷新上拉加載更多
- android RecycleView實(shí)現(xiàn)下拉刷新和上拉加載
- 解決android viewmodel 數(shù)據(jù)刷新異常的問題
- Android巧用XListView實(shí)現(xiàn)萬能下拉刷新控件
- Android自定義控件ListView下拉刷新的代碼
- Android ExpandableListView實(shí)現(xiàn)下拉刷新和加載更多效果
- Android RecyclerView的刷新分頁的實(shí)現(xiàn)
- android使用SwipeRefreshLayout實(shí)現(xiàn)ListView下拉刷新上拉加載
- android使用PullToRefresh框架實(shí)現(xiàn)ListView下拉刷新上拉加載更多
- Android 中RecyclerView頂部刷新實(shí)現(xiàn)詳解
- Android四種方式刷新View的操作方法
相關(guān)文章
淺談Android應(yīng)用安全防護(hù)和逆向分析之a(chǎn)pk反編譯
我們有時(shí)候在某個(gè)app上見到某個(gè)功能,某個(gè)效果蠻不錯(cuò)的,我們想看看對(duì)方的思路怎么走的,這時(shí)候,我們就可以通過反編譯來編譯該apk,拿到代碼,進(jìn)行分析。2021-06-06android實(shí)現(xiàn)指紋識(shí)別功能
這篇文章主要介紹了android指紋識(shí)別功能,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-09-09淺談 Android 7.0 多窗口分屏模式的實(shí)現(xiàn)
這篇文章主要介紹了淺談 Android 7.0 多窗口分屏模式的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-03-03Android實(shí)現(xiàn)簡(jiǎn)易秒表功能
這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)簡(jiǎn)易秒表功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-09-09Android學(xué)習(xí)小結(jié)之Activity保存和恢復(fù)狀態(tài)
這篇文章主要介紹了Activity狀態(tài)保存和恢復(fù)的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-08-08flutter 怎么實(shí)現(xiàn)app整體灰色效果
Flutter 是 Google 開源的 UI 工具包,幫助開發(fā)者通過一套代碼庫高效構(gòu)建多平臺(tái)精美應(yīng)用,支持移動(dòng)、Web、桌面和嵌入式平臺(tái)。這篇文章給大家介紹flutter 怎么實(shí)現(xiàn)app整體灰色效果,感興趣的朋友一起看看吧2020-04-04Android LaunchMode四種啟動(dòng)模式詳細(xì)介紹
這篇文章主要介紹了Android LaunchMode四種啟動(dòng)模式詳細(xì)介紹的相關(guān)資料,這里對(duì)launchmode的使用方法進(jìn)行了詳解及啟動(dòng)模式的比較,需要的朋友可以參考下2016-12-12解決Eclipse創(chuàng)建android項(xiàng)目無法正常預(yù)覽布局文件問題的方法
這篇文章主要介紹了解決Eclipse創(chuàng)建android項(xiàng)目無法正常預(yù)覽布局文件問題的方法,需要的朋友可以參考下2015-12-12Android 系統(tǒng)相機(jī)拍照后相片無法在相冊(cè)中顯示解決辦法
這篇文章主要介紹了Android 系統(tǒng)相機(jī)拍照后相片無法在相冊(cè)中顯示解決辦法的相關(guān)資料,需要的朋友可以參考下2016-12-12Android 中TeaPickerView數(shù)據(jù)級(jí)聯(lián)選擇器功能的實(shí)例代碼
這篇文章主要介紹了Android TeaPickerView數(shù)據(jù)級(jí)聯(lián)選擇器 ,需要的朋友可以參考下2019-06-06