不专门练习的话,自定义View的知识又忘了许多。正好新项目里有这个需求,就再练习一下,代码已上传:地址

可以修改文本、文字大小、各种颜色:

1、按照国际惯例,就是新建attrs,写各种需要的属性,然后获取,新建各种所需的Paint、Rect,重写onMeasure计算宽高,重写onDraw画图搞起。。

2、关于可展开效果,其实就是点击发布时,启动一个ValueAnimator,对一个圆角矩形的左边距离不断改变:

int mBackgroundRectFLeft;

RectF mBackgroundRectF = new RectF();

@Override

protected void onDraw(Canvas canvas) {

mBackgroundRectF.set(mBackgroundRectFLeft, 0, getWidth(), getHeight());

canvas.drawRoundRect(mBackgroundRectF, mOuterRadius, mOuterRadius, mmBackgroundRectPaint);//圆角背景矩形

}

private void openButton() {

ValueAnimator rectLeftAnim = ValueAnimator.ofInt(mBackgroundRectFLeft, mArcWidth / 2);

rectLeftAnim.setDuration(250);

ValueAnimator textAlphaAnim = ValueAnimator.ofInt(0, mItemTextAlpha);

textAlphaAnim.setDuration(120);

rectLeftAnim.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {

@Override

public void onAnimationUpdate(ValueAnimator animation) {

mBackgroundRectFLeft = (int) animation.getAnimatedValue();

invalidate();

}

});

}

3、关于呼吸效果,就是一个对外圆圈半径改变的ValueAnimator:

mBreatheRadius = getHeight() / 2 - mArcWidth / 4;

mBreatheAnim = ValueAnimator.ofFloat(mBreatheRadius, mBreatheRadius - mArcWidth / 2);

mBreatheAnim.setDuration(1000);

mBreatheAnim.setRepeatMode(ValueAnimator.REVERSE);

mBreatheAnim.setRepeatCount(Integer.MAX_VALUE);

mBreatheAnim.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {

@Override

public void onAnimationUpdate(ValueAnimator animation) {

mBreatheRadius = (float) animation.getAnimatedValue();

invalidate();

}

});

mBreatheAnim.start();

@Override

protected void onDraw(Canvas canvas) {

canvas.drawCircle(mInnerCircleCenterX, mInnerCircleCenterY, mBreatheRadius, mBreathePaint);//呼吸圈

4、关于文字位置居中计算,以前我用一个Rect,用

paint.getTextBounds(text, 0, text.length(), mTextRect);

int textWidth = mTextRect.width();

int textHeight = mTextRect.height();

这样计算不准确,可能是因为返回的宽高是int值,应该用FontMetrics类来计算,大家可以搜一下:

float buttonTextWidth = mButtonTextPaint.measureText(mButtonStr, 0, mButtonStr.length());

Paint.FontMetrics publishFontMetrics = mButtonTextPaint.getFontMetrics();

canvas.drawText(mButtonStr, 0, mButtonStr.length(), getWidth() - mOuterRadius - mArcWidth / 2 - buttonTextWidth / 2, mOuterRadius + mArcWidth / 2 + -(publishFontMetrics.ascent + publishFontMetrics.descent) / 2, mButtonTextPaint);

5、再有就是OnTouchEvent的处理,因为这个控件不是一直都是展开状态,那么就要求控件在闭合的时候,要不影响该控件下层控件对点击的处理。比如我这个ExpandableBreathngButton,下层是一个RecyclerView,并设置了OnItemClickListener,那我这个按钮在闭合时,点击按钮左侧但还是在这个View范围内的地方,如下图红框内

这个范围内应该不处理事件,return false

@Override

public boolean onTouchEvent(MotionEvent event) {

switch (event.getAction()) {

case MotionEvent.ACTION_DOWN:

x = (int) event.getX();

y = (int) event.getY();

if (!isOpen && x < getWidth() - 2 * mOuterRadius && y > 0 && y < getHeight()) {

//未展开状态下,点击发布圆左侧的位置,不处理事件

return false;

}

break;

}

}

然后在up事件中计算点击了发布按钮还是展开的item,就是计算点击的坐标是在圆半径内,还是在item矩形范围内。

最后源码奉上: 详细地址

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

android 展开式按钮,Android自定义View实现可展开、会呼吸的按钮相关推荐

  1. Android动画特效之自定义View

      Android动画特效之Animator属性动画实现_Angel-杭州的博客-CSDN博客   我在百忙之中抽出宝贵时间来实现Android动画特效,也就是Android Animator动画效果 ...

  2. Android实现雪花特效自定义view

    一.前言 这个冬天,老家一直没有下雨, 正好圣诞节,就想着制作一个下雪的特效. 圣诞祝福:平安夜,舞翩阡.雪花飘,飞满天.心与心,永相伴. 圣诞节是传统的宗教节日,对于基 督徒,那是庆祝耶稣的诞生,纪 ...

  3. Android 气泡动画(自定义View类)

    Android 气泡动画(自定义View类) 一.前言 二.代码 1. 随机移动的气泡 2.热水气泡 一.前言 最近有需求制作一个水壶的气泡动画,首先在网上查找了一番,找到了一个文章. https:/ ...

  4. Android Matrix手势缩放自定义view 不止于Imageview

    转载请注明出处:http://blog.csdn.net/coderyue/article/details/51397409 之前写过一篇文章Android TextView 横竖排切换(字方向不变) ...

  5. android炫酷的自定义view,Android自定义View实现炫酷进度条

    本文实例为大家分享了Android实现炫酷进度条的具体代码,供大家参考,具体内容如下 下面我们来实现如下效果: 第一步:创建attrs文件夹,自定义属性: 第二步:自定义View: /** * Cre ...

  6. Android Paint应用之自定义View实现进度条控件

    在上一篇文章<Android神笔之Paint>学习了Paint的基本用法,但是具体的应用我们还没有实践过.从标题中可知,本文是带领读者使用Paint,自定义一个进度条控件. 上图就是本文要 ...

  7. 【Android 应用开发】自定义View 和 ViewGroup

    一. 自定义View介绍 自定义View时, 继承View基类, 并实现其中的一些方法. (1) ~ (2) 方法与构造相关 (3) ~ (5) 方法与组件大小位置相关 (6) ~ (9) 方法与触摸 ...

  8. Android开发-将自定义View布局到Layout中并调用

    写程序的时候,关于布局方面遇到并解决的问题 1.自定义View及其layout属性. 自定义View: [java] view plaincopy public class DrawView exte ...

  9. Android 高手进阶之自定义View,自定义属性(带进度的圆形进度条)

    转载请注明地址:http://blog.csdn.net/xiaanming/article/details/10298163 很多的时候,系统自带的View满足不了我们功能的需求,那么我们就需要自己 ...

最新文章

  1. 职场思想分享002 | 入职第一个月工资这样花,一年内工资至少再涨50%!
  2. android 渐变卡片,手机SIM卡的进化史,从有到无,渐变虚拟eSIM卡
  3. android 控件监听方法,Android界面控件(2)—注册点击事件监听器
  4. win7倒计时桌面小工具_iOS 14系统面板截图曝光,新增桌面小工具,越来越像安卓了...
  5. BZOJ 2157: 旅游
  6. java方法怎么写_关于java方法,这几题该怎么写
  7. 在SQL Server中以运行总计运行
  8. C#常见错误解决方法
  9. python函数求导_python_exp
  10. DEVONthink Pro作为浏览器插件脚本,如何使用
  11. 助力不文明行为检测识别—基于yolov3-tiny实现抽烟检测
  12. 2022云管和云网大会|《云容灾白皮书2022》发布,万博智云参与撰写
  13. Druid 监控配置
  14. Git之删除本地仓库
  15. a-upload上传图片
  16. 一个蚂蚁前端曾经的辛酸面试历程 | 掘金技术征文
  17. for .... in 存在的兼容问题你造吗?
  18. 阿里云ACE改革后难度变大了,还有人考吗?划不划算?
  19. 野火i.MX6ULL Linux开发板资料
  20. ISIC Archive数据集下载

热门文章

  1. python使用matplotlib可视化、为可视化图像添加标题(title)、自定义标题的字体格式、字体大小、字体颜色等
  2. python使用matplotlib可视化折线图、在可视化图像中同时绘制多条折线图
  3. R语言使用str_split函数和str_split_fixed函数将字符串分割(分裂、split)成几个部分:str_split函数使用指定的字符或者字符串分割字符串、str_split_fixed
  4. R语言使用dplyr包基于因子变量(factor)将原dataframe拆分为每一个因子对应的单独数据集dataframe实战
  5. 关于文献中二代测序数据下载(NCBI)的问题
  6. 什么检索是借助计算机技术进行自动标引的,自动文献检索系统
  7. ajax更新,AJAX网址更新(AJAX URL update)
  8. javascript 判断字符串中是否包含某个字符串
  9. 【ES6】正则表达式的拓展
  10. 图像拼接--A multiresolution spline with application to image mosaics