1、自定义Button,设置GradientDrawable为背景
因为GradientDrawable是shape标签的具体代码实现,所以,如果婚恋源码想通过GradientDrawable来实现圆角等功能需求的话,需要把上一步骤中我们自定义的GradientDrawable来作为button的background,具体代码如下:
/**
* @author xiaoman
* 可以设置背景色、指定圆角、描边的宽度和颜色
*/
public class RoundButton extends AppCompatTextView {
private RoundButtonDrawable roundButtonDrawable;
public RoundButton(Context context) {
super(context);
init(context, null, 0);
}
public RoundButton(Context context, AttributeSet attrs) {
super(context, attrs, R.attr.RoundButtonStyle);
init(context, attrs, R.attr.RoundButtonStyle);
}
public RoundButton(Context context, AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
init(context, attrs, defStyleAttr);
}
private void init(Context context, AttributeSet attrs, int defStyleAttr) {
roundButtonDrawable = RoundButtonDrawable.fromAttrSet(context, attrs, defStyleAttr);
ViewHelperUtils.setBackgroundKeepingPadding(this, roundButtonDrawable);
}
/**
* 设置背景颜色
* @param color
*/
@Override
public void setBackgroundColor(int color) {
roundButtonDrawable. setColor(color);
}
/**
* 设置描边的宽度和颜色
* @param width
* @param color
*/
public void setStrokeData(int width, int color) {
roundButtonDrawable.setStrokeData(width, color);
}
/**
* 设置描边颜色
* @param color
*/
public void setStrokeColors(int color) {
roundButtonDrawable.setStrokeColor(color);
}
/**
* 设置四个角的半径
* @param radius
*/
public void setRadius(int radius){
roundButtonDrawable.setCornerRadius(radius);
}
/**
* 设置 每一个角的半径
* @param topLeftRadius 左上角半径
* @param topRightRadius 右上角半径
* @param bottomLeftRadius 右下角半径
* @param bottomRightRadius 左下角半径
*/
public void setEachCornerRadius(int topLeftRadius,int topRightRadius,int bottomLeftRadius,int bottomRightRadius){
float[] radius = new float[]{
topLeftRadius, topLeftRadius,
topRightRadius, topRightRadius,
bottomRightRadius, bottomRightRadius,
bottomLeftRadius, bottomLeftRadius
};
roundButtonDrawable. setCornerRadii(radius);
}
/**
* 设置渐变
* @param gradientType 渐变类型
* @param orientation 渐变方向
* @param colors 渐变颜色
*/
public void setGradient(int gradientType, GradientDrawable.Orientation orientation, int[] colors){
roundButtonDrawable.setGradientType(gradientType);
roundButtonDrawable.setOrientation(orientation);
roundButtonDrawable.setColors(colors);
}
public static void setBackgroundKeepingPadding(View view, Drawable drawable) {
int[] padding = new int[]{view.getPaddingLeft(), view.getPaddingTop(), view.getPaddingRight(), view.getPaddingBottom()};
view.setBackground(drawable);
view.setPadding(padding[0], padding[1], padding[2], padding[3]);
}
}
这样,婚恋源码就能通过自定义button实现圆角功能了。
声明:本文由云豹科技转发自笑慢博客,如有侵权请联系作者删除