日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

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

Android自定義View實現波浪動畫

瀏覽:155日期:2022-09-22 17:08:31

本文實例為大家分享了Android自定義View實現波浪動畫的具體代碼,供大家參考,具體內容如下

效果演示

代碼調用與實現效果

xml中調用

<developer.shivam.waveview.Wave android:layout_width='match_parent' android:layout_height='match_parent' app:amplitude='100' app:quadrant='0.5' app:speed='0.15'/>

Android自定義View實現波浪動畫

實現原理

屬性配置

attrs.xml文件中,進行屬性配置

<?xml version='1.0' encoding='utf-8'?><resources> <declare-styleable name='Wave'> <!--波浪顏色--> <attr name='waveColor' format='color'/> <!--波浪背景顏色--> <attr name='waveBackgroundColor' format='color'/> <!--波浪速度--> <attr name='speed' format='float'/> <!--正弦曲線相關--> <!--波浪振幅--> <attr name='amplitude' format='integer'/> <!--波浪相對于控件的位置--> <attr name='quadrant' format='float'/> <!--波浪的頻率--> <attr name='frequency' format='float'/> </declare-styleable></resources>

獲取屬性,同時對屬性賦默認值

final TypedArray array = context.obtainStyledAttributes(set, R.styleable.Wave); mSpeed = array.getFloat(R.styleable.Wave_speed, DEFAULT_SPEED); mWaveColor = array.getColor(R.styleable.Wave_waveColor, DEFAULT_WAVE_COLOR); mWaveBKColor = array.getColor(R.styleable.Wave_waveBackgroundColor, DEFAULT_WAVE_BK_COLOR); mAmplitude = array.getInt(R.styleable.Wave_amplitude, DEFAULT_AMPLITUDE); mQuadrant = array.getFloat(R.styleable.Wave_quadrant, DEFAULT_QUADRANT); mFrequency = array.getFloat(R.styleable.Wave_frequency, DEFAULT_FREQUENCY); array.recycle();

繪制波浪

在onDraw()中使用Canvas進行繪制即可,這里需要注意的正弦曲線的繪制.

正弦曲線(y=Asin(ωx+φ)+k)的一些參數如下:

A——振幅,當物體作軌跡符合正弦曲線的直線往復運動時,其值為行程的1/2。 (ωx+φ)——相位,反映變量y所處的狀態。 φ——初相,x=0時的相位;反映在坐標系上則為圖像的左右移動。 k——偏距,反映在坐標系上則為圖像的上移或下移。 ω——角速度, 控制正弦周期(單位角度內震動的次數)。

onDraw中的代碼:

@Overrideprotected void onDraw(Canvas canvas) { super.onDraw(canvas); final int width = getWidth(); final int height = getHeight(); final int waveHeight = (int) (getHeight() * mQuadrant); // 繪制背景 canvas.drawColor(mWaveBKColor); mWavePath.moveTo(0, height); mWavePath.lineTo(0, waveHeight); for (int i = 1; i <= width; i++) { // 繪制正弦曲線 y = A Sin(ωt+ ρ) = A sin(2πft + ρ) final float y = (float) (waveHeight + mAmplitude * Math.sin(2 * Math.PI * i * mFrequency + mShift)); mWavePath.lineTo(i, y); } // 將曲線閉合 mWavePath.lineTo(width, height); canvas.drawPath(mWavePath, mWavePaint);}

波浪動畫

這時波浪應該已經繪制完成了,下面使用Handler中的周期任務實現動畫效果.

// 創建一個周期任務,它的職責是改變正弦曲線的偏移量 final class WaveAnimation implements Runnable { @Override public void run() { mWavePath.reset(); mShift += mSpeed; invalidate(); Wave.this.postDelayed(this, DEFAULT_PERIOD); } }

在View被創建的時候讓它進行執行

// 開始波浪動畫postDelayed(new WaveAnimation(), DEFAULT_PERIOD);

完整代碼

public class Wave extends View { // 默認屬性值 private static final int DEFAULT_AMPLITUDE = 200; private static final int DEFAULT_PERIOD = 16; private static final float DEFAULT_SPEED = .1F; private static final float DEFAULT_QUADRANT = .33F; private static final float DEFAULT_FREQUENCY = 1F / 360F; private static final int DEFAULT_WAVE_COLOR = Color.parseColor('#64B5F6'); private static final int DEFAULT_WAVE_BK_COLOR = Color.parseColor('#EEEEEE'); @SuppressWarnings('FieldCanBeLocal') @ColorInt private int mWaveColor; @ColorInt private int mWaveBKColor; // 振幅 private int mAmplitude; // 波浪位于View的位置 private float mQuadrant; // 波浪的頻率,這個值越大,波浪越密集 private float mFrequency; // 速度 private float mSpeed; private float mShift; private final Paint mWavePaint = new Paint(Paint.ANTI_ALIAS_FLAG); private final Path mWavePath = new Path(); public Wave(Context context) { this(context, null); } public Wave(Context context, AttributeSet attrs) { this(context, attrs, 0); } public Wave(Context context, AttributeSet attrs, int defStyleAttr) { super(context, attrs, defStyleAttr); init(context, attrs); } private void init(Context context, AttributeSet set) { final TypedArray array = context.obtainStyledAttributes(set, R.styleable.Wave); mSpeed = array.getFloat(R.styleable.Wave_speed, DEFAULT_SPEED); mWaveColor = array.getColor(R.styleable.Wave_waveColor, DEFAULT_WAVE_COLOR); mWaveBKColor = array.getColor(R.styleable.Wave_waveBackgroundColor, DEFAULT_WAVE_BK_COLOR); mAmplitude = array.getInt(R.styleable.Wave_amplitude, DEFAULT_AMPLITUDE); mQuadrant = array.getFloat(R.styleable.Wave_quadrant, DEFAULT_QUADRANT); mFrequency = array.getFloat(R.styleable.Wave_frequency, DEFAULT_FREQUENCY); array.recycle(); mWavePaint.setStrokeWidth(2); mWavePaint.setColor(mWaveColor); // 開始波浪動畫 postDelayed(new WaveAnimation(), DEFAULT_PERIOD); } @Override protected void onDraw(Canvas canvas) { super.onDraw(canvas); final int width = getWidth(); final int height = getHeight(); final int waveHeight = (int) (getHeight() * mQuadrant); // 繪制背景 canvas.drawColor(mWaveBKColor); mWavePath.moveTo(0, height); mWavePath.lineTo(0, waveHeight); for (int i = 1; i <= width; i++) { // 繪制正弦曲線 y = A Sin(ωt+ ρ) = A sin(2πft + ρ) final float y = (float) (waveHeight + mAmplitude * Math.sin(2 * Math.PI * i * mFrequency + mShift)); mWavePath.lineTo(i, y); } // 將曲線閉合 mWavePath.lineTo(width, height); canvas.drawPath(mWavePath, mWavePaint); } final class WaveAnimation implements Runnable { @Override public void run() { mWavePath.reset(); mShift += mSpeed; invalidate(); Wave.this.postDelayed(this, DEFAULT_PERIOD); } }}

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

標簽: Android
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
婷婷精品视频| 激情综合网五月| 久久影院一区| 精品女同一区二区三区在线观看| 日韩国产在线观看| 久久久男人天堂| 丝袜美腿一区| 999久久久免费精品国产| 亚洲人成亚洲精品| 久久不卡日韩美女| 欧美日韩精品一区二区视频| 久久婷婷久久| 91超碰国产精品| 国产精品社区| 亚洲欧美一级| 国产精品一区毛片| 久久国产人妖系列| 美女视频黄免费的久久| 风间由美中文字幕在线看视频国产欧美| 成人影视亚洲图片在线| 激情亚洲影院在线观看| 狠狠爱成人网| 日韩中文字幕无砖| 捆绑调教美女网站视频一区| 精品国产第一福利网站| 欧美日韩国产探花| 日韩精品亚洲一区二区三区免费| 国产日韩免费| 在线亚洲人成| 午夜一级久久| 欧美精品三级在线| 国产精品久久久久久av公交车| 久久精品国产亚洲aⅴ| 韩国精品主播一区二区在线观看 | 久久视频一区| 日韩在线一区二区| 日韩av在线播放网址| 18国产精品| 日韩在线网址| 国产毛片一区| 女人av一区| 精品中文字幕一区二区三区av| 亚洲色诱最新| 97久久精品| 精品亚洲美女网站| 日本中文字幕视频一区| 黄色在线网站噜噜噜| 日韩中文字幕不卡| 久久精品国产久精国产| 婷婷六月综合| 国产精品115| 欧美精品一区二区三区精品| 日韩精品亚洲专区| 在线一区视频观看| 亚洲欧洲另类| 国产欧美自拍| 黑丝美女一区二区| 国产精品入口久久| 国产女优一区| 免费福利视频一区二区三区| 丝袜亚洲精品中文字幕一区| 老司机精品在线| 亚洲一区国产一区| 免费在线日韩av| 伊人久久大香伊蕉在人线观看热v| 精品一区二区三区的国产在线观看| 国产一区成人| 国产成人精选| 日本视频一区二区| 欧产日产国产精品视频| 欧美亚洲一区二区三区| 一区二区三区四区日韩| 国产精品hd| 美女毛片一区二区三区四区最新中文字幕亚洲| 亚洲精品影视| 日韩成人午夜精品| 国产剧情一区二区在线观看| 日韩欧美三级| 蜜桃一区二区三区在线观看| 久久精品色播| 婷婷激情一区| 欧美日韩亚洲一区二区三区在线| 欧美亚洲国产激情| 国产精品不卡| 一级欧美视频| 日韩一级网站| 91精品蜜臀一区二区三区在线| 国产极品一区| 亚洲精品自拍| 久久都是精品| 欧美~级网站不卡| 中文在线а√在线8| 国产日韩一区二区三免费高清 | 久久av网站| 婷婷综合成人| 九九综合九九| 精精国产xxxx视频在线野外| 精品视频99| 国产精品激情| 欧美日一区二区在线观看| 亚洲一区导航| 日韩中文字幕区一区有砖一区 | 日本高清不卡一区二区三区视频| 蜜桃精品视频| 国产欧美一区二区三区国产幕精品| 手机精品视频在线观看| 欧美日韩视频一区二区三区| 日韩精品免费一区二区在线观看| 四虎4545www国产精品| 亚洲精品美女91| 欧美香蕉视频| 国产在线视频欧美一区| 精品国产日韩欧美精品国产欧美日韩一区二区三区| 鲁大师成人一区二区三区| 婷婷亚洲综合| 韩国久久久久久| 亚洲精品黄色| 激情五月综合网| 国产在线不卡| 久久青草久久| 国精品一区二区三区| 99国产精品免费视频观看| 色婷婷色综合| av综合电影网站| 国产精品免费不| 久久99久久久精品欧美| 免费看久久久| 福利一区二区三区视频在线观看| 日本欧美国产| 97在线精品| 91精品推荐| 影院欧美亚洲| 亚洲v天堂v手机在线| 青青草91视频| 精品日本视频| 久久三级福利| 天堂成人免费av电影一区| 日韩在线成人| 麻豆成人av在线| 日韩成人精品一区二区| 午夜av成人| 久久高清国产| 91精品国产自产精品男人的天堂 | 久久蜜桃精品| 国产美女一区| 欧美一级二级视频| 麻豆91精品视频| 日本а中文在线天堂| 美国三级日本三级久久99| 日韩成人精品一区二区三区| 亚洲免费观看高清完整版在线观| 午夜在线一区| 欧美91在线| 国产精品99一区二区| 国产精品入口久久| 免费久久精品视频| caoporn视频在线| 亚洲另类视频| 国产亚洲在线观看| 亚洲精品激情| 久久久国产精品网站| 国产在线看片免费视频在线观看| 久久国产毛片| 综合一区av| 欧美精品97| 久久视频精品| 视频一区免费在线观看| 麻豆国产欧美一区二区三区 | 欧美69视频| 日韩精品高清不卡| 激情黄产视频在线免费观看| 欧美一区=区| 国产精品videossex| 欧美性感美女一区二区| 日韩精品福利一区二区三区| 精品一区二区三区四区五区| 亚洲精品极品少妇16p| 日本va欧美va欧美va精品| 国产一区二区三区亚洲综合| 欧美精品黄色| 久久只有精品| 黑丝一区二区| 精品亚洲a∨| 手机精品视频在线观看| 91亚洲一区| 日韩精品91亚洲二区在线观看| 九九精品调教| 国产精品一区高清| 日韩视频一区| 精品国产麻豆| 中文字幕一区二区三区四区久久 | 日韩精品一区二区三区中文在线 | 国产一区日韩| 亚洲天堂黄色| 日韩高清不卡一区| 亚洲午夜av| 国产激情一区| 99日韩精品| 国产成人免费| 日韩va欧美va亚洲va久久|