一个TextView的艺术,轻松实现评论列表功能

本人发帖宗旨:
1.不长篇大论。
2.发文前简单搜一下是不是有人发过(简单的)。
3.直说知识点,基础知识请自行补习。
4.随性

此文已在Github和CSDN上发布过,简书上目前才开始写 (ˇˍˇ) 想~(欢迎star)
此文为引子,想看我写好的请到Github上
Github:https://github.com/hnsugar

先睹为快,是不是想要这种效果,一个textview就可以实现


pic1.jpg

pic2.gif

简单说一下原理吧
大家知道emoji吧,自定义文本表情图标也是同理,下面请大家好好理解理解SpannableString这个类,

SpannableString可以做什么?
看一下style下有哪些类


Paste_Image.png

看图说一下,我们能给每个字符指定一些属性,除了常见的字号字体前景色背景色下划线之外,还可以设置点击事件、文本替换成图片等等等,注意,是每个字符都可以单独设置

简单代码示例(start操作字符串开始位置 end操作字符串结束位置)
添加点击事件 mString.setSpan(new ClickAbleSpan(){.....},start,end,flag);
添加前景色 mString.setSpan (new ForegroundColorSpan (mTalkColor),start,end,flag);

        mString.setSpan (new ClickableSpan () {

            @Override
            public void updateDrawState (TextPaint ds) {
                /**
                 * 是否有下划线
                 */
                ds.setUnderlineText (false);
                /**
                 * 橘红色字体
                 */
                ds.setColor (mNameColor);
            }

            @Override
            public void onClick (final View widget) {
                isNickNameClick = true;
                if (mListener != null) {
                    mListener.onNickNameClick (finalMI, mInfos.get (finalMI));
                }
            }
        }, 0, end, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);

然后拼接换行符就可以了,就打造好了如开始图片的样子了,对SpannableString如果感兴趣可以自行探索,这里不再介绍,本文只提供一个思路,别再用listview这种来写了。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容