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

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

Android自定義View實(shí)現(xiàn)波浪動(dòng)畫

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

本文實(shí)例為大家分享了Android自定義View實(shí)現(xiàn)波浪動(dòng)畫的具體代碼,供大家參考,具體內(nèi)容如下

效果演示

代碼調(diào)用與實(shí)現(xiàn)效果

xml中調(diào)用

<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實(shí)現(xiàn)波浪動(dòng)畫

實(shí)現(xiàn)原理

屬性配置

attrs.xml文件中,進(jìn)行屬性配置

<?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'/> <!--正弦曲線相關(guān)--> <!--波浪振幅--> <attr name='amplitude' format='integer'/> <!--波浪相對(duì)于控件的位置--> <attr name='quadrant' format='float'/> <!--波浪的頻率--> <attr name='frequency' format='float'/> </declare-styleable></resources>

獲取屬性,同時(shí)對(duì)屬性賦默認(rèn)值

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進(jìn)行繪制即可,這里需要注意的正弦曲線的繪制.

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

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

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

波浪動(dòng)畫

這時(shí)波浪應(yīng)該已經(jīng)繪制完成了,下面使用Handler中的周期任務(wù)實(shí)現(xiàn)動(dòng)畫效果.

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

在View被創(chuàng)建的時(shí)候讓它進(jìn)行執(zhí)行

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

完整代碼

public class Wave extends View { // 默認(rèn)屬性值 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; // 波浪的頻率,這個(gè)值越大,波浪越密集 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); // 開始波浪動(dòng)畫 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); } }}

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Android
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
99国产精品99久久久久久粉嫩| 午夜国产精品视频免费体验区| 免费人成黄页网站在线一区二区| 香蕉国产精品| 91超碰国产精品| 亚洲精品1区2区| 久久不射网站| 日韩福利视频一区| 国产麻豆一区| 国产高清日韩| 国产精品一区二区三区av麻| 国产乱人伦丫前精品视频| 91精品国产自产在线丝袜啪| 欧美日本三区| 老司机精品视频在线播放| 电影91久久久| 999久久久91| 国产精品婷婷| 日本成人中文字幕在线视频| 国产欧美日韩一级| 精品久久精品| 欧美片第1页| 婷婷成人综合| 日韩中文字幕91| 日韩精品一区二区三区中文字幕| 日本不卡视频在线观看| 国产精品一国产精品k频道56| 美女久久99| 久久久久久久久丰满| 亚洲一区欧美激情| 热久久久久久| 成人福利视频| 久久av一区二区三区| 国产日韩在线观看视频| 国产va免费精品观看精品视频| 亚洲91久久| 亚洲va久久久噜噜噜久久| 免费一区二区三区在线视频| 成人羞羞视频播放网站| 日韩影院在线观看| 国产伦乱精品| 欧美一级精品| 亚洲精品动态| 国产成人免费视频网站视频社区| 米奇777超碰欧美日韩亚洲| 免费日本视频一区| 麻豆91小视频| 国产亚洲综合精品| 国产精品天天看天天狠| 久久美女精品| 国产精品亚洲欧美日韩一区在线| 久久久久美女| 欧美精品中文字幕亚洲专区| 久久视频一区| 国产精品男女| 国产一区二区三区自拍| 欧美亚洲免费| 一区二区自拍| 国产一区二区三区亚洲综合| 久久午夜精品| av资源中文在线| 中文一区一区三区免费在线观 | 国产一区二区三区久久| 亚洲免费成人| 精品国产欧美| 亚洲v天堂v手机在线| 日韩中文欧美| 欧美日韩一区二区三区不卡视频| 欧美在线观看视频一区| 国产精品极品| 免费看欧美美女黄的网站| 四季av一区二区凹凸精品| 日本亚洲最大的色成网站www | 丝袜美腿一区| 欧美一级网站| 在线国产一区| 国产成人77亚洲精品www| 蜜臀av性久久久久蜜臀aⅴ流畅| 麻豆成人在线观看| 四虎精品永久免费| 精品一区三区| 亚洲涩涩在线| 国产精品伦一区二区| 日韩在线观看一区二区| 久久中文字幕av一区二区不卡| 久久99久久人婷婷精品综合| 亚洲欧洲免费| 亚洲国产日韩欧美在线| 国产一区二区三区天码| 清纯唯美亚洲综合一区| 在线看片一区| 999在线观看精品免费不卡网站| 日韩免费在线| 毛片不卡一区二区| 国产日产精品_国产精品毛片| 蜜桃视频在线观看一区| 国产精品美女| 欧美日韩国产欧| 免费观看不卡av| 久久国产主播| 欧美日韩视频网站| 日韩av自拍| 精品国产乱码久久久| 日韩不卡一二三区| 视频一区二区国产| 国产亚洲精品久久久久婷婷瑜伽| 99久久激情| 国产资源在线观看入口av| 九九99久久精品在免费线bt| 欧美日韩1区2区3区| 日韩精品社区| 日韩激情综合| 18国产精品| 欧美日韩1区| 国产日韩欧美一区二区三区 | 国际精品欧美精品| 欧美伊人影院| 奇米色欧美一区二区三区| 综合在线一区| 亚洲精品乱码日韩| 日韩二区在线观看| 青草综合视频| 国产日韩一区| 国产精品男女| 国产精品极品| 精品视频一区二区三区四区五区| 免费视频一区二区三区在线观看| 欧美激情aⅴ一区二区三区| 国产精品一在线观看| 国产欧美88| 你懂的亚洲视频| 欧美精品aa| 精品美女视频 | 国产一区二区三区黄网站 | 午夜国产一区二区| 99香蕉国产精品偷在线观看 | 免费在线成人网| 综合欧美精品| 日韩精品国产欧美| 国产精品hd| 高清久久一区| 国产在线不卡| 亚洲欧美网站在线观看| 国产区精品区| 色婷婷综合网| 亚洲二区免费| 亚洲乱码视频| 欧美激情麻豆| 亚洲a一区二区三区| 日韩中文字幕区一区有砖一区| 视频国产精品| 国产精品久久久久久久免费软件 | 麻豆91在线播放| 欧洲一区二区三区精品| 欧美日韩免费观看一区=区三区| 亚洲精品国模| 精品国产亚洲一区二区三区| 91精品国产调教在线观看| 亚洲经典在线| 日本电影久久久| 国产精品久久观看| 国产精品日本| 国产精品白丝av嫩草影院| 欧美成a人国产精品高清乱码在线观看片在线观看久 | 激情婷婷综合| 日韩中文字幕| 国产成人久久精品一区二区三区| 欧美日韩在线二区| 欧美一区精品| 99精品电影| 国产日韩一区二区三区在线| 亚洲精品一区三区三区在线观看| 蜜臀av一区二区在线免费观看 | 亚洲丝袜美腿一区| 里番精品3d一二三区| 不卡在线一区二区| 日韩av二区在线播放| 精品日韩视频| 日本色综合中文字幕| 久久精品中文| 日韩av中文字幕一区二区| 日韩久久一区二区三区| 亚洲精品少妇| 激情亚洲影院在线观看| 日韩国产欧美在线视频| 久久久久久久久99精品大| 97精品资源在线观看| 亚洲视频综合| 久久天堂影院| 亚洲综合五月| 欧美久久天堂| 日韩精品国产欧美| 影视先锋久久| 久久99精品久久久久久园产越南| 一区免费在线| 久久精品国产免费| 亚洲v天堂v手机在线| 久久影院一区| 国产第一亚洲| 91福利精品在线观看|