欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android貝塞爾曲線初步學(xué)習(xí)第一課

 更新時間:2017年03月13日 10:25:48   作者:猴菇先生  
這篇文章主要為大家詳細(xì)介紹了Android貝塞爾曲線初步學(xué)習(xí)的第一課,具有一定的參考價值,感興趣的小伙伴們可以參考一下

貝塞爾曲線有一階、二階、三階、N階

一階就是一條直線,有起點終點,沒有控制點,對應(yīng)方法就是

canvas.drawLine(float startX, float startY, float stopX, float stopY, @NonNull Paint paint) ;

二階為曲線,有起點終點,一個控制點,對應(yīng)方法就是

path.quadTo(float x1, float y1, float x2, float y2);

其中x1、y1為控制點坐標(biāo), x2、y2為終點坐標(biāo),效果如下:

這里寫圖片描述

三階由倆個控制點控制,對應(yīng)方法就是

path.cubicTo(float x1, float y1, float x2, float y2, float x3, float y3);

其中x1、y1、x2、y2為兩個控制點坐標(biāo), x3、y3為終點坐標(biāo),效果如下:

這里寫圖片描述

做一個demo鞏固一下用法:

這里寫圖片描述

新建一個SecondBezierView繼承View,重寫構(gòu)造方法、初始化畫筆、固定起點和終點的坐標(biāo),重寫onTouchEvent()方法獲取當(dāng)前點擊的點為控制點:

 @Override
 public boolean onTouchEvent(MotionEvent event) {
 switch (event.getAction()) {
 case MotionEvent.ACTION_MOVE:
 mControlX = event.getX();
 mControlY = event.getY();
 invalidate();
 break;
 }
 return true;
 }

在onDraw()方法中畫點、畫連接線、畫文本、畫二階貝塞爾曲線

 @Override
 protected void onDraw(Canvas canvas) {
 super.onDraw(canvas);
 canvas.drawCircle(mStartX, mStartY, 8, mLinePaint);
 canvas.drawText("起點", mStartX, mStartY, mLinePaint);
 canvas.drawCircle(mEndX, mEndY, 8, mLinePaint);
 canvas.drawText("終點", mEndX, mEndY, mLinePaint);
 canvas.drawCircle(mControlX, mControlY, 8, mLinePaint);
 canvas.drawText("控制點", mControlX, mControlY, mLinePaint);
 canvas.drawLine(mStartX, mStartY, mControlX, mControlY, mLinePaint);
 canvas.drawLine(mEndX, mEndY, mControlX, mControlY, mLinePaint);

 mBezierPath.reset();//因為不斷重繪,path的路徑也要重置,不然頁面上會顯示很多條線
 mBezierPath.moveTo(mStartX, mStartY);//移至起點
 mBezierPath.quadTo(mControlX, mControlY, mEndX, mEndY);//二階貝塞爾曲線,傳入控制點和終點坐標(biāo)
 canvas.drawPath(mBezierPath, mBezierPaint);
 }

最后添加一個回彈的動畫,用的是OvershootInterpolator插值器,在onTouchEvent的MotionEvent.ACTION_UP中:

 case MotionEvent.ACTION_UP:
 ValueAnimator animX = ValueAnimator.ofFloat(mControlX, getWidth() / 2);
 animX.setDuration(500);
 animX.setInterpolator(new OvershootInterpolator());
 animX.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {
 @Override
 public void onAnimationUpdate(ValueAnimator animation) {
 mControlX = (float) animation.getAnimatedValue();
 invalidate();
 }
 });
 animX.start();
 ValueAnimator animY = ValueAnimator.ofFloat(mControlY, getHeight() / 2);
 animY.setDuration(500);
 animY.setInterpolator(new OvershootInterpolator());
 animY.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {
 @Override
 public void onAnimationUpdate(ValueAnimator animation) {
 mControlY = (float) animation.getAnimatedValue();
 invalidate();
 }
 });
 animY.start();
 break;

再來個三階的

這里寫圖片描述

主要就是用到了多點觸控:

 private boolean mIsSecondPoint = false;

 @Override
 public boolean onTouchEvent(MotionEvent event) {
 switch (event.getAction() & MotionEvent.ACTION_MASK) {//多點觸控
 case MotionEvent.ACTION_POINTER_DOWN:
 mIsSecondPoint = true;
 break;
 case MotionEvent.ACTION_POINTER_UP:
 mIsSecondPoint = false;
 break;
 case MotionEvent.ACTION_MOVE:
 mControlX1 = event.getX(0);//獲取控制點1的橫縱坐標(biāo)
 mControlY1 = event.getY(0);
 if (mIsSecondPoint) {
  mControlX2 = event.getX(1);//獲取控制點2的橫縱坐標(biāo)
  mControlY2 = event.getY(1);
 }
 invalidate();
 break;
 }
 return true;
 }

然后再onDraw()中畫三階貝塞爾曲線

 mBezierPath.reset();
 mBezierPath.moveTo(mStartX, mStartY);
 mBezierPath.cubicTo(mControlX1, mControlY1, mControlX2, mControlY2, mEndX, mEndY);
 canvas.drawPath(mBezierPath, mBezierPaint);

大功告成,打完收工。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Android 實現(xiàn)沉浸式狀態(tài)欄的方法

    Android 實現(xiàn)沉浸式狀態(tài)欄的方法

    沉浸式狀態(tài)欄的來源就是很多手機(jī)用的是實體按鍵,沒有虛擬鍵,于是開了沉浸模式就只有狀態(tài)欄消失了。下面腳本之家小編給大家介紹Android 實現(xiàn)沉浸式狀態(tài)欄,需要的朋友可以參考下
    2015-09-09
  • 解決ViewPager和SlidingPaneLayout的滑動事件沖突問題

    解決ViewPager和SlidingPaneLayout的滑動事件沖突問題

    下面小編就為大家分享一篇解決ViewPager和SlidingPaneLayout的滑動事件沖突問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-01-01
  • Android中Intent與Bundle的使用詳解

    Android中Intent與Bundle的使用詳解

    這篇文章主要給大家總結(jié)介紹了關(guān)于Android中傳值Intent與Bundle的關(guān)系,文中通過示例代碼以及圖文介紹的非常詳細(xì),對各位Android開發(fā)者們具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧<BR>
    2022-11-11
  • so加載Linker跟NameSpace機(jī)制詳解

    so加載Linker跟NameSpace機(jī)制詳解

    這篇文章主要為大家介紹了so加載Linker跟NameSpace機(jī)制詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-01-01
  • Android Studio使用教程(六):Gradle多渠道打包

    Android Studio使用教程(六):Gradle多渠道打包

    這篇文章主要介紹了Android Studio使用教程(六):Gradle多渠道打包,本文講解了友盟多渠道打包、assemble結(jié)合Build Variants來創(chuàng)建task、完整的gradle腳本等內(nèi)容,需要的朋友可以參考下
    2015-05-05
  • 解析android中系統(tǒng)日期時間的獲取

    解析android中系統(tǒng)日期時間的獲取

    本篇文章是對在android中,如何系統(tǒng)日期時間獲取的方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-06-06
  • Android中使用定時器的三種方法

    Android中使用定時器的三種方法

    這篇文章主要為大家詳細(xì)介紹了Android定時器的三種使用方法,感興趣的小伙伴們可以參考一下
    2016-05-05
  • Android 自定義可拖拽View界面渲染刷新后不會自動回到起始位置

    Android 自定義可拖拽View界面渲染刷新后不會自動回到起始位置

    這篇文章主要介紹了Android 自定義可拖拽View界面渲染刷新后不會自動回到起始位置的實現(xiàn)代碼,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2017-02-02
  • Android入門之TableLayout應(yīng)用解析(二)

    Android入門之TableLayout應(yīng)用解析(二)

    這篇文章主要介紹了Android入門之TableLayout應(yīng)用,需要的朋友可以參考下
    2014-08-08
  • Android RecyclerView布局就這么簡單

    Android RecyclerView布局就這么簡單

    Android RecyclerView布局就這么簡單!RecyclerView比ListView更靈活,更強(qiáng)大,作為一個android開發(fā)者如果還不知道如何使用android5.X的RecyclerView未免有點說不過去了,本文就為大家講解Android RecyclerView布局,需要的朋友可以參考下
    2016-04-04

最新評論