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

首頁 > 系統 > Android > 正文

Android使用貝塞爾曲線仿QQ聊天消息氣泡拖拽效果

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

本文實例為大家分享了Android仿QQ聊天消息氣泡拖拽效果展示的具體代碼,供大家參考,具體內容如下

先畫圓,都會吧。代碼如下:

public class Bezier extends View { private final Paint mGesturePaint = new Paint(); private final Path mPath = new Path(); private float mX1 = 100, mY1 = 150; private float mX2 = 300, mY2 = 150; private boolean mBezier = true; private int mRadius = 30;  public Bezier(Context context, AttributeSet attrs) { super(context, attrs); mGesturePaint.setAntiAlias(true); mGesturePaint.setStyle(Paint.Style.FILL_AND_STROKE); mGesturePaint.setStrokeWidth(5); mGesturePaint.setColor(Color.RED); }  @Override protected void onDraw(Canvas canvas) { // TODO Auto-generated method stub super.onDraw(canvas); canvas.drawCircle(mX1, mX2, mRadius, mGesturePaint); } }

效果

Android,貝塞爾曲線,仿QQ,消息氣泡,拖拽

拖拽的另個一圓就不畫了,效果的實現主要是計算兩個點之間的拖拽區域,如下圖:

Android,貝塞爾曲線,仿QQ,消息氣泡,拖拽

求出區域之后,使用貝塞爾線畫出效果就可以了,代碼:

public class Bezier extends View { private final Paint mGesturePaint = new Paint(); private final Path mPath = new Path(); private float mX1 = 100, mY1 = 150; private float mX2 = 300, mY2 = 150; private boolean mBezier = true; private int mRadius = 30;  public Bezier(Context context, AttributeSet attrs) { super(context, attrs); mGesturePaint.setAntiAlias(true); mGesturePaint.setStyle(Paint.Style.FILL_AND_STROKE); mGesturePaint.setStrokeWidth(5); mGesturePaint.setColor(Color.RED); setBezier(); }  private void setBezier() { float offsetX = (float) (mRadius * Math.sin(Math.atan((mY2 - mY1) / (mX2 - mX1)))); float offsetY = (float) (mRadius * Math.cos(Math.atan((mY2 - mY1) / (mX2 - mX1)))); float x1 = mX1 - offsetX; float y1 = mY1 + offsetY;  float x2 = mX2 - offsetX; float y2 = mY2 + offsetY;  float x3 = mX2 + offsetX; float y3 = mY2 - offsetY;  float x4 = mX1 + offsetX; float y4 = mY1 - offsetY;  mPath.reset(); mPath.moveTo(x1, y1); mPath.quadTo((mX1 + mX2) / 2, (mY1 + mY2) / 2, x2, y2);//錨點直接取偏移量的一半 mPath.lineTo(x3, y3); mPath.quadTo((mX1 + mX2) / 2, (mY1 + mY2) / 2, x4, y4); mPath.lineTo(x1, y1); }  @Override protected void onDraw(Canvas canvas) { // TODO Auto-generated method stub super.onDraw(canvas); //通過畫布繪制多點形成的圖形 canvas.drawCircle(mX1, mY1, mRadius, mGesturePaint); if (mBezier) { canvas.drawPath(mPath, mGesturePaint); canvas.drawCircle(mX2, mY2, mRadius, mGesturePaint); } }}

效果圖:

Android,貝塞爾曲線,仿QQ,消息氣泡,拖拽

拖拽效果只要在onTouchEvent里動態改變拖動點的坐標重繪就可以實現了,代碼:

public class Bezier extends View { private final Paint mGesturePaint = new Paint(); private final Path mPath = new Path(); private float mX1 = 100, mY1 = 150; private float mX2 = 300, mY2 = 150; private boolean mBezier = true; private int mRadius = 30;  public Bezier(Context context, AttributeSet attrs) { super(context, attrs); mGesturePaint.setAntiAlias(true); mGesturePaint.setStyle(Paint.Style.FILL_AND_STROKE); mGesturePaint.setStrokeWidth(5); mGesturePaint.setColor(Color.RED); setBezier(); }  private void setBezier() { float offsetX = (float) (mRadius * Math.sin(Math.atan((mY2 - mY1) / (mX2 - mX1)))); float offsetY = (float) (mRadius * Math.cos(Math.atan((mY2 - mY1) / (mX2 - mX1)))); float x1 = mX1 - offsetX; float y1 = mY1 + offsetY;  float x2 = mX2 - offsetX; float y2 = mY2 + offsetY;  float x3 = mX2 + offsetX; float y3 = mY2 - offsetY;  float x4 = mX1 + offsetX; float y4 = mY1 - offsetY;  mPath.reset(); mPath.moveTo(x1, y1); mPath.quadTo((mX1 + mX2) / 2, (mY1 + mY2) / 2, x2, y2);//錨點直接取偏移量的一半 mPath.lineTo(x3, y3); mPath.quadTo((mX1 + mX2) / 2, (mY1 + mY2) / 2, x4, y4); mPath.lineTo(x1, y1); }  @Override protected void onDraw(Canvas canvas) { // TODO Auto-generated method stub super.onDraw(canvas); //通過畫布繪制多點形成的圖形 canvas.drawCircle(mX1, mY1, mRadius, mGesturePaint); if (mBezier) { canvas.drawPath(mPath, mGesturePaint); canvas.drawCircle(mX2, mY2, mRadius, mGesturePaint); } }  @Override public boolean onTouchEvent(MotionEvent event) { mX2 = event.getX(); mY2 = event.getY(); switch (event.getAction()) { case MotionEvent.ACTION_DOWN: mBezier = true; setBezier(); break; case MotionEvent.ACTION_MOVE: mBezier = true; setBezier(); break; case MotionEvent.ACTION_UP: mBezier = false; break;  } invalidate(); return true; } }

源碼:Android仿QQ聊天消息氣泡拖拽效果

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


注:相關教程知識閱讀請移步到Android開發頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲激情电影中文字幕| 亚洲色图狂野欧美| 国产日韩欧美中文在线播放| 911国产网站尤物在线观看| 国内免费精品永久在线视频| 亚洲视频欧洲视频| 亚洲国产精品人久久电影| 欧美巨大黑人极品精男| 欧美丝袜第一区| 日韩成人黄色av| 欧美在线亚洲在线| 欧美日本高清一区| 亚洲国产精品成人精品| 国产97免费视| 国产在线观看精品一区二区三区| 3344国产精品免费看| 日韩免费在线播放| 91精品视频专区| 日韩有码片在线观看| 国产精品视频内| 久久激情五月丁香伊人| 欧美电影在线播放| 国产美女精彩久久| 日韩成人av网址| 一道本无吗dⅴd在线播放一区| 国产精品三级美女白浆呻吟| 国产精品亚洲激情| 在线色欧美三级视频| 亚洲精品国产福利| 色妞在线综合亚洲欧美| 成人在线观看视频网站| 久久亚洲精品中文字幕冲田杏梨| 少妇久久久久久| 日韩av快播网址| 日韩av电影在线免费播放| 成人观看高清在线观看免费| 欧美亚洲激情视频| 91精品国产色综合久久不卡98口| 日韩中文字幕在线视频播放| 亚洲性猛交xxxxwww| 最近2019年日本中文免费字幕| 日韩女优人人人人射在线视频| 久久人人爽人人爽人人片av高请| 中文字幕欧美精品日韩中文字幕| 狠狠色噜噜狠狠狠狠97| 一个色综合导航| 91美女片黄在线观看游戏| 96sao精品视频在线观看| 国产精品久久久久av| 国产z一区二区三区| 亚洲天堂成人在线| 97色在线播放视频| 精品久久久久久亚洲国产300| 亚洲夜晚福利在线观看| 亚洲国产精品人人爽夜夜爽| 日韩欧中文字幕| 国产精品永久免费| 大胆欧美人体视频| 成人a视频在线观看| 美女国内精品自产拍在线播放| 欧美日韩亚洲国产一区| 亚洲精品日韩激情在线电影| 亚洲免费视频一区二区| 亚洲第一福利网站| 国产亚洲激情视频在线| 国产精品美女网站| 国产精品成人av性教育| 久久综合免费视频影院| 国产一区二区丝袜| 国产日韩精品在线播放| 国产成人一区二区三区电影| 中文字幕日韩欧美精品在线观看| 久久久精品影院| 国产精品午夜一区二区欲梦| 狠狠躁夜夜躁人人爽超碰91| 精品视频在线播放色网色视频| 日韩精品视频在线观看网址| 久久久久久综合网天天| 国产精品麻豆va在线播放| 中文字幕在线日韩| 91极品视频在线| 国产精品自拍小视频| 久久亚洲精品一区| 黑人巨大精品欧美一区二区| 亚洲男女性事视频| 久久久久久中文字幕| 成人午夜在线影院| 另类色图亚洲色图| 日韩激情片免费| 久久久久久亚洲精品不卡| 国外色69视频在线观看| 亚洲综合视频1区| 亚洲国产91精品在线观看| 亚洲电影在线观看| www日韩欧美| 欧美极品美女电影一区| 中文字幕自拍vr一区二区三区| 欧美性jizz18性欧美| 精品视频在线播放| 色综合五月天导航| 日韩一级裸体免费视频| 国产精品中文字幕久久久| 亚洲国产91精品在线观看| 日韩精品在线影院| 97色伦亚洲国产| 欧美成人免费va影院高清| 国产精品久久久久久久久久久久久久| 欧美在线一级va免费观看| xxav国产精品美女主播| 欧美激情一区二区久久久| 综合网中文字幕| 欧美国产日韩免费| 久久久久国产精品免费| 一区二区亚洲欧洲国产日韩| 亚洲第一福利在线观看| 国产精品91一区| 亚洲国产精品人久久电影| 欧美精品生活片| 亚洲欧洲在线视频| 欧美一区视频在线| www.欧美三级电影.com| 隔壁老王国产在线精品| 97视频在线观看视频免费视频| 精品国内自产拍在线观看| 久久国内精品一国内精品| 日本国产高清不卡| 欧洲日本亚洲国产区| 欧洲美女7788成人免费视频| 国产精品视频在线观看| 一区二区三区视频免费| 在线亚洲国产精品网| 日韩一中文字幕| 9.1国产丝袜在线观看| 欧美激情一区二区三区在线视频观看| 亚洲www视频| 国产精自产拍久久久久久蜜| 欧美极品少妇xxxxⅹ免费视频| 久久91超碰青草是什么| 亚洲欧美综合图区| 亚洲一区精品电影| 中文字幕综合在线| 国内精品久久久久伊人av| 亚洲天堂av综合网| 欧美视频在线免费| xxxxx91麻豆| 爱福利视频一区| 亚洲国产精品va在看黑人| 高清一区二区三区四区五区| 国产精品欧美激情在线播放| 日韩av在线网| 国内自拍欧美激情| 日韩av在线资源| 中文字幕9999| 亚洲精品乱码久久久久久按摩观| 国产成人久久久精品一区| 亚洲第一免费网站| 欧美大秀在线观看| 国产精品久久久久久一区二区| 国产亚洲精品久久| 国产亚洲激情在线| 91精品久久久久久久久青青| 国产在线视频欧美| 久久男人资源视频| www国产亚洲精品久久网站|