美文网首页Android开发Android学习知识Android使用基础
Android实践: 一步实现图标文本+小红点

Android实践: 一步实现图标文本+小红点

作者: AssIstne | 来源:发表于2017-02-04 17:31 被阅读1411次

    图标+文本作为一个按钮这种形式在国内大部分app都会使用.

    京东首页

    虽然TextView可以包含图标, 但是存在问题,

    TextView问题

    当你指定了TextView的高度时, 图标和文本之间的间距并不等于drawablePadding.

    所以当使用TextView实现的时候, TextView只能是wrap_content, 如果这个按钮是有指定尺寸并且可以点击的话, 那么单纯使用TextView就不能满足要求了, 需要在外部嵌套一个FrameLayout来捕捉点击事件.

    当一个app有多个这种按钮的时候(通常都有好几个, 底部tab按钮, 个人中心的按钮等等), 这种实现显得非常臃肿.如果还需要实现"小红点"的需求, 则更加麻烦了.

    另外值得一提的是, TextView是一个比较"重"的控件, SDK24中的源码超过1W行, 单纯的显示静态文本作为按钮, 显得有点大材小用.

    所以写了一个控件来满足需要:
    这个控件包含图标, 文本和红点以及红点内的文本. 可以任意设置元素的大小, 位置和内容. 能够满足常见的需求.

    通过gradle添加依赖:

    compile 'com.assistne.android:icon-dot-text-view:1.0'
    

    一个控件满足所有需要:

    <com.assistne.icondottextview.IconDotTextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
    
        app:text="Category"
        app:icon="@drawable/ic_shopping_cart_black_48dp"
        app:dot_visible="true"
        app:dot_text="400"
        />
    

    效果如图:

    Demo

    源码已经上传GitHub-IconDotTextView
    欢迎提意见和issue :)
    能帮到你的话, 点个star吧~ >-<

    相关文章

      网友评论

      • 78983551cc90:textview的图标不能制定大小
        AssIstne:@两津勘 首先获取一个Drawable实例, 然后Drawable#setBounds()方法设置大小, 然后TextView#setCompoundDrawables()
        78983551cc90: @AssIstne 怎么设置,给个提示
        AssIstne:@两津勘 可以,通过代码可以设置drawable的大小

      本文标题:Android实践: 一步实现图标文本+小红点

      本文链接:https://www.haomeiwen.com/subject/cxfsittx.html