Drawable表示的是一种可以在Canvas上进行绘制的抽象概念。
6.1 Drawable简介
Drawable优点:
1、使用简单,开发成本比自定义View低
2、非图片类型的Drawable占用空间小
Drawable使用目的:
1、作为ImageView中的图像来显示
2、作为View的背景
Drawable使用方式:
1、多数用xml
2、少数用自定义Drawable
6.2 Drawable的分类
Drawable是一个抽象类,是所有Drawable对象的基类。
不用细看,内部细节用的时候抠一下即可,真正开发时候远比View用的少。
6.2.1 BitmapDrawable
对应bitmap标签,表示一张图片。
6.2.2 ShapeDrawable
对应shape标签,通过颜色构造图形。
6.2.3 LayerDrawable
对应layer-list标签,将不同的Drawable放置再不哦她那个的层上面从而达到叠加后的效果。
6.2.4 StateListDrawable
对应selector标签,表示Drawable集合,根据View的状态选择合适的Drawable。
6.2.5 LevelListDrawable
对应level-list标签,表示Drawable集合,根据不同等级选择合适的Drawable。
6.2.6 TransitionDrawable
对应transition标签,实现两个Drawable之间淡入淡出的效果。
6.2.7 InsetDrawable
对应inset标签,实现将其他Drawable内嵌到自己当中。
6.2.8 ScaleDrawable
对应scale标签,根据自己的等级将Drawable按比例缩放。
6.2.9 ClipDrawable
对应clip标签,根据自己的等级将Drawable进行裁剪。
6.3 自定义Drawable
因为自定义的Drawable无法在XML中使用,所以基本不用自定义的Drawable,除极其个别的情况。
自定一CustomDrawable,继承Drawable,必须实现draw、setAlpha、setColorFilter和getOpacity这四个方法,源码如下:
public class CustomDrawable extends Drawable {
private Paint mPaint;
public CustomDrawable(int color) {
mPaint = new Paint(Paint.ANTI_ALIAS_FLAG);
mPaint.setColor(color);
}
@Override
public void draw(Canvas canvas) {
final Rect r = getBounds();
float cx = r.exactCenterX();
float cy = r.exactCenterY();
canvas.drawCircle(cx, cy, Math.min(cx, cy), mPaint);
}
@Override
public void setAlpha(int alpha) {
mPaint.setAlpha(alpha);
invalidateSelf();
}
@Override
public void setColorFilter(ColorFilter cf) {
mPaint.setColorFilter(cf);
invalidateSelf();
}
@Override
public int getOpacity() {
// not sure, so be safe
return PixelFormat.TRANSLUCENT;
}
}
在XML中定义一个TextView:
<TextView
android:id="@+id/test_custom_drawable"
android:layout_width="300dp"
android:layout_height="300dp"
android:layout_marginLeft="10dp"
android:layout_marginRight="10dp"
android:gravity="center"
android:text="custom drawable"
android:textColor="#ffffff" />
使用:
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
View testCustomDrawable = findViewById(R.id.test_custom_drawable);
CustomDrawable customDrawable = new CustomDrawable(Color.parseColor("#0ac39e"));
testCustomDrawable.setBackgroundDrawable(customDrawable);
}
结果图: