亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 系統 > Android > 正文

Android實現水波紋擴散效果

2019-10-21 21:26:02
字體:
來源:轉載
供稿:網友

本文實例為大家分享了Android實現水波紋擴散效果的具體代碼,供大家參考,具體內容如下

先上圖

Android,水波紋,擴散

囧!沒有圖片所以就拿了小安代替了。

先看一下如何使用這個View。

<jianpan.com.mybutton.view.RippleDiffuse android:layout_width="200dp" android:layout_height="200dp" app:btn_img_res="@drawable/rd" app:ripple_img_res="@drawable/rd"></jianpan.com.mybutton.view.RippleDiffuse>

是的,沒有別的代碼了,就這么簡單

實現思路

自定義ViewGroup,創建一個用顯示圖片的view,在創建幾個,大小相同的ImageView。當按下時,對這幾個ImageView進行放大和漸變。

代碼

首先它肯定是一個正方形。

@Overrideprotected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) { super.onMeasure(widthMeasureSpec, widthMeasureSpec); if (!mInitDataSucceed){ initData(); }}

顯示圖片的View的大小,該怎么給?這是個比較蛋疼的問題。給大了就看不到擴散效果了,給小,給多少的值合適呢?有沒有正好的值,有的用父 view 的 size / 子 view 放大的倍數,這樣肯定會達到理想的效果。

private static final int ANIMATION_EACH_OFFSET = 800; // 每個動畫的播放時間間隔private static final int RIPPLE_VIEW_COUNT = 3;//波紋view的個數private static final float DEFAULT_SCALE = 1.6f;//波紋放大后的大小//點擊有擴散效果的viewprivate CircleImageView mBtnImg;private int mBtnViewHeight;private int mBtnViewWidth;private float mScale = DEFAULT_SCALE;//圖片資源private int mBtnImgRes;private int mRippleRes;//是否初始化完成private boolean mInitDataSucceed = false;private void initData(){ if (getMeasuredHeight() > 0 && getMeasuredWidth() > 0){ mInitDataSucceed = true; int height = getMeasuredHeight() - getPaddingTop() - getPaddingBottom(); int width = getMeasuredWidth() - getPaddingLeft() - getPaddingRight(); mBtnViewHeight = (int) (height / mScale); mBtnViewWidth = (int) (width / mScale); mBtnImg = new CircleImageView(getContext()); mBtnImg.setImageResource(mBtnImgRes); mBtnImg.setOnTouchListener(this); addView(mBtnImg, getWaveLayoutParams()); for (int i = 0; i < RIPPLE_VIEW_COUNT; i++){  //創建view  CircleImageView wave = createWave();  mWaves.add(wave);  //創建動畫  mAnimas.add(getNewAnimationSet());  addView(wave, 0, getWaveLayoutParams()); } }}private CircleImageView createWave(){ CircleImageView CircleImageView = new CircleImageView(getContext()); CircleImageView.setScaleType(ImageView.ScaleType.CENTER_CROP); CircleImageView.setImageResource(mRippleRes); return CircleImageView;}private LayoutParams getWaveLayoutParams(){ LayoutParams lp = new LayoutParams(mBtnViewWidth, mBtnViewHeight); return lp;}private AnimationSet getNewAnimationSet() { AnimationSet as = new AnimationSet(true); ScaleAnimation sa = new ScaleAnimation(1f, mScale, 1f, mScale,  ScaleAnimation.RELATIVE_TO_SELF, 0.5f,  ScaleAnimation.RELATIVE_TO_SELF, 0.5f); sa.setDuration(ANIMATION_EACH_OFFSET * 3); sa.setRepeatCount(-1);// 設置循環 AlphaAnimation aniAlp = new AlphaAnimation(1, 0.1f); aniAlp.setRepeatCount(-1);// 設置循環 as.setDuration(ANIMATION_EACH_OFFSET * 3); as.addAnimation(sa); as.addAnimation(aniAlp); return as;}

View 都初始化完成了,好像還差一步,onLayout,只要把子 View 都顯示到中先就可以了。

@Overrideprotected void onLayout(boolean changed, int left, int top, int right, int bottom) { if (mInitDataSucceed) { int childLeft = (getMeasuredWidth() - mBtnViewWidth) / 2; int childTop = (getMeasuredHeight() - mBtnViewHeight) / 2; for (int i = 0; i < RIPPLE_VIEW_COUNT; i++) {  CircleImageView wave = mWaves.get(i);  wave.layout(childLeft, childTop, mBtnViewWidth + childLeft, mBtnViewHeight + childTop); } mBtnImg.layout(childLeft, childTop, mBtnViewWidth + childLeft, mBtnViewHeight + childTop); }else { initData(); }}

最后處理一下圖片的onTouch事件。

@Overridepublic boolean onTouch(View v, MotionEvent event) { switch (event.getAction()) { case MotionEvent.ACTION_DOWN:  showWaveAnimation();  break; case MotionEvent.ACTION_MOVE:  break; case MotionEvent.ACTION_UP: case MotionEvent.ACTION_CANCEL:  cancelWaveAnimation();  break; default:  cancelWaveAnimation();  break; } return true;}private void showWaveAnimation() { for (int i = 0; i < RIPPLE_VIEW_COUNT; i++){ Message message = new Message(); message.obj = i; handler.sendMessageDelayed(message, ANIMATION_EACH_OFFSET * i); }}private void cancelWaveAnimation() { for (int i = 0; i < RIPPLE_VIEW_COUNT; i++){ CircleImageView wave = mWaves.get(i); wave.clearAnimation(); }}private Handler handler = new Handler() { @Override public void handleMessage(Message msg) { int position = (int) msg.obj; CircleImageView wave = mWaves.get(position); wave.startAnimation(mAnimas.get(position)); super.handleMessage(msg); }};

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網。


注:相關教程知識閱讀請移步到Android開發頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩极品精品视频免费观看| 国产有码一区二区| 亚洲无亚洲人成网站77777| 欧美久久精品一级黑人c片| 日韩av在线一区| 欧美另类69精品久久久久9999| 中文字幕久久久| 性夜试看影院91社区| 欧美大片在线看| 成人免费视频网| 国产精品久久久久久婷婷天堂| 在线成人激情视频| 久久精品精品电影网| 亚洲精品福利资源站| 国产成人精品优优av| 欧美裸体xxxx极品少妇| 亚洲网站在线看| 欧美激情一区二区久久久| 成人免费大片黄在线播放| 久久综合九色九九| 日韩欧美中文字幕在线观看| 久久久久久久一区二区三区| 国产精品视频自在线| 欧美特黄级在线| 欧美激情一二区| 日本免费在线精品| 久久久精品视频在线观看| 国内精品小视频在线观看| 91精品国产九九九久久久亚洲| 国产精品视频男人的天堂| 91久久夜色精品国产网站| 精品综合久久久久久97| 国产精品一区二区性色av| 一级做a爰片久久毛片美女图片| 国产成人在线亚洲欧美| 亚洲性av网站| 欧美激情精品久久久久久久变态| 国内外成人免费激情在线视频| 欧美精品18videosex性欧美| 性欧美xxxx视频在线观看| 日韩av男人的天堂| 视频在线观看一区二区| 欧美夫妻性生活视频| 亚洲а∨天堂久久精品9966| 久久久久久国产免费| 日韩精品中文字幕在线观看| 欧美极度另类性三渗透| 亚洲人午夜精品| 国产精品成人一区二区| 秋霞av国产精品一区| 国产精品直播网红| 2019中文字幕免费视频| 最近2019中文字幕mv免费看| 中文日韩电影网站| 91手机视频在线观看| 欧美高跟鞋交xxxxhd| 欧美日韩亚洲天堂| 高清视频欧美一级| 日韩久久精品成人| 国产精品丝袜久久久久久不卡| 国产精品扒开腿做爽爽爽的视频| 黑人极品videos精品欧美裸| 精品成人国产在线观看男人呻吟| 日韩欧美成人区| 亚洲精品美女在线| 亚洲有声小说3d| 日本成人免费在线| 九九久久久久99精品| 久久久亚洲影院你懂的| 一道本无吗dⅴd在线播放一区| 亚洲人成在线一二| 亚洲天天在线日亚洲洲精| 国产自产女人91一区在线观看| 欧美老女人xx| 日韩在线免费视频观看| 亚洲综合一区二区不卡| 91久久精品国产91久久| 91av视频在线观看| 久久久噜噜噜久噜久久| 亚洲人成亚洲人成在线观看| 午夜精品福利电影| 日韩精品在线播放| 97久久精品国产| 夜夜嗨av一区二区三区免费区| 久久精品影视伊人网| 欧美成人午夜激情在线| 亚洲成人网在线观看| 中文字幕av一区二区| 国产亚洲欧美一区| 国产精品成人aaaaa网站| 青青草99啪国产免费| 日韩欧美中文第一页| 国产精品久久99久久| 国产精品高潮在线| 丝袜美腿精品国产二区| 在线观看国产精品日韩av| 久久影视电视剧免费网站清宫辞电视| 欧美另类交人妖| 欧美激情亚洲综合一区| 国产不卡在线观看| 欧美激情视频一区二区| 日韩欧美在线中文字幕| 久久精品国产久精国产一老狼| 亚洲第一免费播放区| 日韩大陆毛片av| 日产日韩在线亚洲欧美| 亚洲一区二区中文| 亚洲综合国产精品| 91精品久久久久久久久久另类| 日韩高清中文字幕| 日韩在线中文字幕| 欧美伊久线香蕉线新在线| 美女999久久久精品视频| 日韩高清有码在线| 亚洲v日韩v综合v精品v| 久久九九有精品国产23| 国产精品久久久久久久久久新婚| 日韩精品视频观看| 欧美日韩激情视频8区| 97国产精品视频人人做人人爱| 亚洲国产欧美一区二区三区久久| 亚洲国产精品国自产拍av秋霞| 欧美性xxxxx极品| 欧美人成在线视频| 亚洲成人在线视频播放| 91av在线播放| 97av在线视频| 欧美专区第一页| 欧美电影电视剧在线观看| 日韩久久午夜影院| 日本视频久久久| 亚洲影院色在线观看免费| 国产精品美女www爽爽爽视频| 亚洲人精选亚洲人成在线| 成人在线中文字幕| 日韩激情av在线播放| 日韩精品免费在线视频观看| 久久久av一区| 欧美成aaa人片免费看| 国模精品视频一区二区三区| 亚洲成年人影院在线| 亚洲视频在线免费观看| 国产精品白丝jk喷水视频一区| 日韩一区二区福利| 精品久久久久久久久久| 日韩精品一区二区三区第95| 日韩一中文字幕| 欧美午夜精品久久久久久浪潮| 久久69精品久久久久久久电影好| 国产免费一区二区三区香蕉精| 一本色道久久综合亚洲精品小说| 美女福利视频一区| 国产aⅴ夜夜欢一区二区三区| 777国产偷窥盗摄精品视频| 精品国产依人香蕉在线精品| 91精品免费久久久久久久久| 日韩黄色高清视频| 不卡在线观看电视剧完整版| 久久中国妇女中文字幕| 亚洲男人的天堂网站| 中文字幕日韩在线播放| 精品毛片网大全| 2019中文字幕在线免费观看| 亚洲精品乱码久久久久久金桔影视|