项目初衷: 公司项目样式文件n+1个,多人开发文件命名各类各样,每次都要搜索半天,我也在网上看了不少相似样式设置库,大多数都是自定义View,我只想代码直接设置样式,比较方便一点,就在闲暇时间写了这个项目,代码直接设置样式,没有太多的属性须要设置,使用简单、为了更方便、快捷、省时的项目开发。java
在项目的 build.gradle
添加:android
dependencies {
...
implementation 'cn.luliangdev:DevShapeUtils:1.0.1'
}
复制代码
android {
defaultConfig {
...
minSdkVersion 16
...
}
}
复制代码
public class DevApplication extends Application {
@Override
public void onCreate() {
super.onCreate();
DevShapeUtils.init(this);
}
}
复制代码
效果展现: git
//椭圆
DevShapeUtils.shape(DevShape.OVAL).solid(R.color.colorAccent).into(view);
//矩形
DevShapeUtils.shape(DevShape.RECTANGLE).solid(R.color.colorAccent).into(view);
//圆角
DevShapeUtils.shape(DevShape.RECTANGLE).solid(R.color.colorAccent).radius(10).into(view);
//方向圆角(top-left方向圆角)
DevShapeUtils.shape(DevShape.RECTANGLE).solid(R.color.colorAccent).tlRadius(10).into(view);
//半圆角
DevShapeUtils.shape(DevShape.RECTANGLE).solid(R.color.colorAccent).radius(999).into(view);
//实线圆角边框(line 参数1:边框宽度 参数2:边框颜色)
DevShapeUtils.shape(DevShape.RECTANGLE).line(1, R.color.colorAccent).radius(10).into(view);
//虚线圆角边框(dashLine 参数1:边框宽度 参数2:边框颜色 参数3:虚线宽度 参数4:虚线间隙宽度)
DevShapeUtils.shape(DevShape.RECTANGLE).dashLine(1, R.color.colorPrimary, 5, 5).radius(10).into(view);
//渐变(默认线性上下方向渐变)
DevShapeUtils.shape(DevShape.RECTANGLE).gradient(R.color.colorAccent, R.color.colorPrimary).into(view);
//线性渐变(gradientLinear 参数1:渐变方向 参数2:渐变颜色,颜色数量必须两个及以上)
DevShapeUtils.shape(DevShape.RECTANGLE).gradientLinear(DevShape.TOP_BOTTOM, R.color.colorAccent, R.color.colorPrimary).into(view);
//扫描渐变(gradientSweep 参数1:渐变颜色,颜色数量必须两个及以上)
DevShapeUtils.shape(DevShape.OVAL).gradientSweep(R.color.colorAccent, R.color.colorPrimary).into(view);
//辐射渐变(gradientRadial 参数1:辐射范围 参数2:渐变颜色,颜色数量必须两个及以上)
DevShapeUtils.shape(DevShape.OVAL).gradientRadial(30, R.color.colorAccent, R.color.colorPrimary).into(view);
复制代码
效果展现: github
//触摸背景颜色变化(selectorBackground 参数1:触摸颜色 参数2 正常颜色)
DevShapeUtils.selectorBackground(R.color.colorAccent,R.color.colorPrimary).into(view);
//触摸背景颜色和字体颜色变化(selectorColor 参数1:触摸颜色 参数2 正常颜色)
DevShapeUtils
.selectorBackground(R.color.colorAccent,R.color.colorPrimary)
.selectorColor("#ffffff", "#000000")
.into(view);
//触摸圆角背景和字体颜色变化
Drawable pressedDrawable = DevShapeUtils.shape(DevShape.RECTANGLE).solid(R.color.colorAccent).radius(10).build();
Drawable normalDrawable = DevShapeUtils.shape(DevShape.RECTANGLE).solid(R.color.colorPrimary).radius(10).build();
DevShapeUtils
.selectorBackground(pressedDrawable,normalDrawable)
.selectorColor("#ffffff", "#000000")
.into(view);
复制代码
若是遇到问题或者好的建议,请反馈到:issue、927195249@qq.com 或者LiangLuDev@gmail.comide