android自定义控件android开源APPAndroid知识

动手扩展一个CompatTextView

2017-06-13  本文已影响151人  TruthKeeper

前言

在项目开发过程中在drawable目录下会逐渐被shape,selector等xml文件充斥,到项目后期会变得难以维护,还在一定程度上增加了安装包的大小,基于这个现象,结合一些需要扩展的功能,例如drawableLeft不支持SVG等等,CompatTextView借此而生

【项目地址】

特点

CompatTextView继承自AppCompatTextView,目前支持了以下功能:

自定义属性一览:

<declare-styleable name="CompatTextView">
        <!--四个位置的圆角,传入对应宽度或者高度的一半就是圆形-->
        <attr name="ctv_topLeftRadius" format="dimension" />
        <attr name="ctv_topRightRadius" format="dimension" />
        <attr name="ctv_bottomLeftRadius" format="dimension" />
        <attr name="ctv_bottomRightRadius" format="dimension" />
        <!--边框宽度-->
        <attr name="ctv_strokeWidth" format="dimension" />
        <!--边框线颜色-->
        <attr name="ctv_strokeColor" format="color" />
        <attr name="ctv_strokePressedColor" format="color" />
        <attr name="ctv_strokeSelectedColor" format="color" />
        <attr name="ctv_strokeDisabledColor" format="color" />
        <!--内容颜色-->
        <attr name="ctv_solidColor" format="color" />
        <attr name="ctv_solidPressedColor" format="color" />
        <attr name="ctv_solidSelectedColor" format="color" />
        <attr name="ctv_solidDisabledColor" format="color" />
        <!--文本颜色-->
        <attr name="ctv_textColor" format="color" />
        <attr name="ctv_textPressedColor" format="color" />
        <attr name="ctv_textSelectedColor" format="color" />
        <attr name="ctv_textDisabledColor" format="color" />
        <!--渐变颜色-->
        <attr name="ctv_gradientStartColor" format="color" />
        <attr name="ctv_gradientStartPressedColor" format="color" />
        <attr name="ctv_gradientStartSelectedColor" format="color" />
        <attr name="ctv_gradientStartDisabledColor" format="color" />

        <attr name="ctv_gradientEndColor" format="color" />
        <attr name="ctv_gradientEndPressedColor" format="color" />
        <attr name="ctv_gradientEndSelectedColor" format="color" />
        <attr name="ctv_gradientEndDisabledColor" format="color" />
        <!--渐变方向-->
        <attr name="ctv_gradientDirection" format="enum">
            <enum name="topToBottom" value="0" />
            <enum name="leftToRight" value="1" />
            <enum name="topLeftToBottomRight" value="2" />
            <enum name="bottomLeftToTopRight" value="3" />
        </attr>
        <attr name="ctv_gradientDirectionDisabled" format="enum">
            <enum name="topToBottom" value="0" />
            <enum name="leftToRight" value="1" />
            <enum name="topLeftToBottomRight" value="2" />
            <enum name="bottomLeftToTopRight" value="3" />
        </attr>
        <attr name="ctv_gradientDirectionPressed" format="enum">
            <enum name="topToBottom" value="0" />
            <enum name="leftToRight" value="1" />
            <enum name="topLeftToBottomRight" value="2" />
            <enum name="bottomLeftToTopRight" value="3" />
        </attr>
        <attr name="ctv_gradientDirectionSelected" format="enum">
            <enum name="topToBottom" value="0" />
            <enum name="leftToRight" value="1" />
            <enum name="topLeftToBottomRight" value="2" />
            <enum name="bottomLeftToTopRight" value="3" />
        </attr>
        <!--Tint着色支持与drawable细腻配置-->
        <attr name="ctv_tintLeft" format="color" />
        <attr name="ctv_tintDrawableLeft" format="reference" />
        <attr name="ctv_tintDrawableLeftWidth" format="dimension" />
        <attr name="ctv_tintDrawableLeftHeight" format="dimension" />

        <attr name="ctv_tintRight" format="color" />
        <attr name="ctv_tintDrawableRight" format="reference" />
        <attr name="ctv_tintDrawableRightWidth" format="dimension" />
        <attr name="ctv_tintDrawableRightHeight" format="dimension" />

        <attr name="ctv_tintTop" format="color" />
        <attr name="ctv_tintDrawableTop" format="reference" />
        <attr name="ctv_tintDrawableTopWidth" format="dimension" />
        <attr name="ctv_tintDrawableTopHeight" format="dimension" />

        <attr name="ctv_tintBottom" format="color" />
        <attr name="ctv_tintDrawableBottom" format="reference" />
        <attr name="ctv_tintDrawableBottomWidth" format="dimension" />
        <attr name="ctv_tintDrawableBottomHeight" format="dimension" />
        <!--drawable对齐方式-->
        <attr name="ctv_drawableLeftAlign" format="enum">
            <enum name="top" value="0" />
            <enum name="center" value="1" />
            <enum name="bottom" value="2" />
        </attr>
        <attr name="ctv_drawableRightAlign" format="enum">
            <enum name="top" value="0" />
            <enum name="center" value="1" />
            <enum name="bottom" value="2" />
        </attr>
        <attr name="ctv_drawableTopAlign" format="enum">
            <enum name="left" value="0" />
            <enum name="center" value="1" />
            <enum name="right" value="2" />
        </attr>
        <attr name="ctv_drawableBottomAlign" format="enum">
            <enum name="left" value="0" />
            <enum name="center" value="1" />
            <enum name="right" value="2" />
        </attr>
        <!--切换的渐变,毫秒,默认0,无效果-->
        <attr name="ctv_fadeDuring" format="integer" />
        <!--5.0+以上的涟漪效果,默认开启,与渐变、边框颜色等配置冲突时建议关闭-->
        <attr name="ctv_ripple" format="boolean" />
    </declare-styleable>

使用

dependencies {
    compile 'com.tk.compattextview:library:1.2'
}

当然直接拷贝CompatTextView和attrs文件就可以轻松扩展符合您项目业务的功能。
顾名思义,CompatTextView被用来扩展、兼容、简化一些开发作业,如果您需要一些炫酷的功能,可以看看以下基于TextView扩展的开源项目:

SuperTextView

Fancybuttons

上一篇 下一篇

猜你喜欢

热点阅读