前言
在项目开发过程中在drawable目录下会逐渐被shape,selector等xml文件充斥,到项目后期会变得难以维护,还在一定程度上增加了安装包的大小,基于这个现象,结合一些需要扩展的功能,例如drawableLeft不支持SVG等等,CompatTextView借此而生
特点
CompatTextView继承自AppCompatTextView,目前支持了以下功能:
- 支持shape的solid、stroke、gradient、radius的配置
- 支持enabled、pressed、selected、unenabled共计4种状态的配置
- 不再需要写大量的shape、selector文件配置
- 支持上下左右的drawable大小配置,SVG支持、Tint着色支持
- 支持上下左右的drawable的对齐方式配置
- 5.0+配置pressed时点击涟漪效果
上图:
自定义属性一览:
<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扩展的开源项目: