我要投稿 | 留言给我

高仿QQ未读消息气泡拖拽黏连效果

※发布时间:2018-1-12 14:42:28   ※发布作者:平民百姓   ※出自何处: 

  近日,搜狗CEO王小川在接受采访时对百度进行了猛批。他认为百度是一家没有战略的公司,而且自动驾驶也不是搜索公司该干的事。谈及到百度现在最重视的AI,王小川认为搜索本身就是AI,搜索引擎需要像人一样去思考,来帮用户选择出更好的页面,因此搜狗一直都是在做着AI领域的研究。

  了解了Android端的贝塞尔曲线,本篇就举个栗子一下,仿QQ未读消息气泡,是最经典的贝塞尔曲线的东东,效果如下:

  画两个圆,一个黏连小球固定在一个点上,一个气泡小球跟随手指的滑动改变坐标。随着两个圆间距越来越大,黏连小球半径越来越小。

  1.首先老一套~新建attrs.xml文件,编写自定义属性,新建 DragBubbleView 继承View,重写构造方法,获取自定义属性值,初始化Paint、Path等东东,重写 onMeasure 计算宽高,这里不再啰嗦~

  2.在 onSizeChanged 方法中确定黏连小球和气泡小球的圆心坐标,这里我们取宽高的一半:

  3.经分析气泡小球有以下几个状态:默认、拖拽、移动、消失,我们这里定义一下,方便根据不同的状态分析不同情况:

  4.重写 onTouchEvent 方法,其中d代表两圆圆心间距,maxD代表可拖拽的最大间距:

  8.关于气泡爆炸的动画,思就是放几张图片到 drawable 里,然后动态计数重绘,在 onDraw 中调用 canvas.drawBitmap() 方法,具体如下:

  其中android:clipChildren=”lse”这个属性可以使根布局下的子控件超出本身控件范围的大小,加上这个属性就可以满屏幕随意拖拽而不必拘泥于它本身的大小了,炒鸡方便~

  还有如果觉得在属性中设置消息个数不方便,需要在代码中动态获取数据并设置的话,只要在 DragBubbleView 中添加一个方法即可

  如果你有好的技术文章想和大家分享,欢迎向我的号,具体细节请在号主页点击“”菜单查看。

  

相关阅读
  • 没有资料