TextView自定义下划线、点击弹框

github地址:https://github.com/shuaijia/NoteText

更多精彩内容,请关注我的微信公众号——安卓干货营

前言

最近公司有意需求,就是类似于电子书,选择一段文字然后做笔记,需要给做过的文字加下划线,下划线最后加一图标按钮,点击弹框显示笔记内容。

立马会想到使用TextView的fromHtml方法,给添加笔记的文本手动加标签,或者使用SpanString类的相关方法设置标签。

但是!

经过反复测试,无论使用何种下划线标签或者SpanString设置下划线,画出的下划线颜色始终和文本内容颜色一样,还不能随便定义颜色。更何况:我们需要在下划线最后加图标,并且能够点击。看来这种方法不可行…

于是,便开始了我的自定义之路~~~~

先看效果图:

这是纯文本的TextView
这里写图片描述

这是富文本的TextView
这里写图片描述

分析

这里写图片描述

要实现以上需求,应该从这几个方面入手:

文本展示,普通文本调用TextView的setText方法既可,如果是富文本,就使用TextView的fromHtml方法,至于图片如何展示,我在上一篇文章用TextView实现富文本展示,点击断句和语音播报介绍过了,有兴趣的可以跳转阅读,核心是拦截到图片url然后自己实现加载图片。

给TextView设置要划线的起始位置和结束位置,需要计算出在哪些行进行绘制,每行又是从哪里开始,到哪里结束,注意第一行和最后一行。

然后就是在onDraw方法中对计算出的行进行逐行绘制,在最后一行的结束位置绘制笔记图标(小圆圈)。

在TextView的onTouchEvent判断按下位置是否是笔记图标(小圆圈)的附近,是的话则弹框(PopupWindow)显示。

文本显示

这里就不再重复累赘了,文本展示很简单:

调用setText或fromHtml方法既可。

颜色等属性设置

private Rect mRect;
private Paint mPaint;
private int mColor = 0xFFFFA200;
private float density;
private float mStrokeWidth;

// 笔记白点
private Paint mPointPaint;

// 开始各结束位置索引,startIndex必须大于等于endIndex
private int startIndex = 0;
private int endIndex = 0;

// 下划线的位置(每次更新)
private float x_start, x_stop, x_diff;
private int baseline;
// 小圆圈的位置
private float notePointX, notePointY;

private int scrollY = 
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值