android自定義view波浪曲線

最近需求要再登錄頁(yè)面添加倆條動(dòng)態(tài)波浪線,參考大神們的Demo解決了需求献汗,廢話不多說直接上代碼旱函!

一、自定義View

public class DoubleWaveView extends View {

private Paint mPaint;

private Path mPath;

private int width, height;

private int dx;

public DoubleWaveView(Context context, int width, int height) {

super(context);

this.width = width;

this.height = height;

init();

}

public DoubleWaveView(Context context, AttributeSet attrs) {

super(context, attrs);

}

public DoubleWaveView(Context context, AttributeSet attrs, int defStyleAttr) {

super(context, attrs, defStyleAttr);

}

private void init() {

mPath = new Path();

//?初始繪制波紋的畫筆

mPaint = new Paint();

// 設(shè)置風(fēng)格為實(shí)線

mPaint.setStyle(Paint.Style.STROKE);

//? ? ? ? mPaint.setStyle(Paint.Style.FILL_AND_STROKE);//填充滿

}

@Override

protected void onDraw(Canvas canvas) {

super.onDraw(canvas);

//重置繪制路線泄朴,即隱藏之前繪制的軌跡

mPath.reset();

// 去除畫筆鋸齒

mPaint.setAntiAlias(true);

// 設(shè)置畫筆顏色

mPaint.setColor(Color.parseColor("#F333EC"));

//mPath繪制的繪制起點(diǎn)高度

mPath.moveTo(-width + dx, height / 3 * 2);

for (int i = 0; i < 3; i++) {

//畫貝塞爾曲線

mPath.rQuadTo(width / 5, -70, width / 2, 0);

mPath.rQuadTo(width / 5, 70, width / 2, 0);

}

//填充形成波浪效果

//? ? ? ? mPath.lineTo(width, height);

//? ? ? ? //兩點(diǎn)連成直線

//? ? ? ? mPath.lineTo(0, height);

//? ? ? ? //回到初始點(diǎn)形成封閉的曲線

//? ? ? ? mPath.close();

canvas.drawPath(mPath, mPaint);

mPath.reset();

mPaint.setColor(Color.parseColor("#5733F3"));

mPath.moveTo(-width + dx, height / 3 * 2);

for (int i = 0; i < 3; i++) {

mPath.rQuadTo(width / 4, 70, width / 2, 0);

mPath.rQuadTo(width / 4, -70, width / 2, 0);

}

//? ? ? ? mPath.lineTo(width, height);

//? ? ? ? mPath.lineTo(0, height);

//? ? ? ? mPath.close();

//? ? ? ? 開始繪制

canvas.drawPath(mPath, mPaint);

}

public void startAnimation() {

// 屬性動(dòng)畫

ValueAnimator valueAnimator = ValueAnimator.ofInt(0, width);// 從某個(gè)值變化到某個(gè)值

valueAnimator.setDuration(2000);//動(dòng)畫時(shí)間

valueAnimator.setRepeatCount(ValueAnimator.INFINITE);// 設(shè)置播放次數(shù)重抖。如果為ValueAnimator.INFINITE表示無(wú)限播放下去

valueAnimator.setInterpolator(new LinearInterpolator());//動(dòng)畫拋物線勻速運(yùn)動(dòng)

//如果不加,ValueAnimator或是AnimatorSet.start時(shí)改動(dòng)畫對(duì)象不能播放

valueAnimator.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {

@Override

public void onAnimationUpdate(ValueAnimator animation) {

dx = (int) animation.getAnimatedValue();//得到當(dāng)前值

invalidate();//刷新View

}

});

valueAnimator.start();//啟動(dòng)動(dòng)畫

}

}

二祖灰、MainActivity

public class MainActivity extends AppCompatActivity {

private FrameLayout rootView;

private DoubleWaveView waveView;

private int width,height;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.doublewaveview);

WindowManager wm = (WindowManager) getSystemService(Context.WINDOW_SERVICE);

width = wm.getDefaultDisplay().getWidth();

height = wm.getDefaultDisplay().getHeight();

initWaveView();

}

private void initWaveView() {

rootView = (FrameLayout) findViewById(R.id.rootView);

waveView = new DoubleWaveView(this, width, height);

FrameLayout.LayoutParams params = new FrameLayout.LayoutParams(width, height);

rootView.addView(waveView, params);

waveView.startAnimation();

}

}

三钟沛、XML中有一個(gè)FramLaout就可以

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市局扶,隨后出現(xiàn)的幾起案子恨统,更是在濱河造成了極大的恐慌叁扫,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,194評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件畜埋,死亡現(xiàn)場(chǎng)離奇詭異莫绣,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)悠鞍,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,058評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門对室,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人狞玛,你說我怎么就攤上這事软驰。” “怎么了心肪?”我有些...
    開封第一講書人閱讀 156,780評(píng)論 0 346
  • 文/不壞的土叔 我叫張陵锭亏,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我硬鞍,道長(zhǎng)慧瘤,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,388評(píng)論 1 283
  • 正文 為了忘掉前任固该,我火速辦了婚禮锅减,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘伐坏。我一直安慰自己怔匣,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,430評(píng)論 5 384
  • 文/花漫 我一把揭開白布桦沉。 她就那樣靜靜地躺著每瞒,像睡著了一般。 火紅的嫁衣襯著肌膚如雪纯露。 梳的紋絲不亂的頭發(fā)上剿骨,一...
    開封第一講書人閱讀 49,764評(píng)論 1 290
  • 那天,我揣著相機(jī)與錄音埠褪,去河邊找鬼浓利。 笑死,一個(gè)胖子當(dāng)著我的面吹牛钞速,可吹牛的內(nèi)容都是我干的贷掖。 我是一名探鬼主播,決...
    沈念sama閱讀 38,907評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼渴语,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼羽资!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起遵班,我...
    開封第一講書人閱讀 37,679評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤屠升,失蹤者是張志新(化名)和其女友劉穎潮改,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體腹暖,經(jīng)...
    沈念sama閱讀 44,122評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡汇在,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,459評(píng)論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了脏答。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片糕殉。...
    茶點(diǎn)故事閱讀 38,605評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖殖告,靈堂內(nèi)的尸體忽然破棺而出阿蝶,到底是詐尸還是另有隱情,我是刑警寧澤黄绩,帶...
    沈念sama閱讀 34,270評(píng)論 4 329
  • 正文 年R本政府宣布羡洁,位于F島的核電站,受9級(jí)特大地震影響爽丹,放射性物質(zhì)發(fā)生泄漏筑煮。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,867評(píng)論 3 312
  • 文/蒙蒙 一粤蝎、第九天 我趴在偏房一處隱蔽的房頂上張望真仲。 院中可真熱鬧,春花似錦初澎、人聲如沸秸应。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,734評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)灸眼。三九已至,卻和暖如春墓懂,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背霉囚。 一陣腳步聲響...
    開封第一講書人閱讀 31,961評(píng)論 1 265
  • 我被黑心中介騙來(lái)泰國(guó)打工捕仔, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人盈罐。 一個(gè)月前我還...
    沈念sama閱讀 46,297評(píng)論 2 360
  • 正文 我出身青樓榜跌,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親盅粪。 傳聞我的和親對(duì)象是個(gè)殘疾皇子钓葫,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,472評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容