Android基础入门教程——8.1.2 Android中的13种Drawable小结 Part 2
标签(空格分隔): Android基础入门教程
本节引言:
本节我们继续来学习Android中的Drawable资源,上一节我们学习了: ColorDrawable;NinePatchDrawable; ShapeDrawable;GradientDrawable!这四个Drawable~ 而本节我们继续来学习接下来的五个Drawable,他们分别是: BitmapDrawable;InsertDrawable;ClipDrawable; RotateDrawable;AnimationDrawable! 还是贴下13种Drawable的导图:
好的,开始本节内容~
1.BitmapDrawable
对Bitmap的一种封装,可以设置它包装的bitmap在BitmapDrawable区域中的绘制方式,有: 平铺填充,拉伸填或保持图片原始大小!以<bitmap>为根节点! 可选属性如下:
tileMode:指定图片平铺填充容器的模式,设置这个的话,gravity属性会被忽略,有以下可选值: disabled(整个图案拉伸平铺),clamp(原图大小), repeat(平铺),mirror(镜像平铺)
对应的效果图:
①XML定义BitmapDrawable:
==”@drawable/ic_launcher”android:tileMode=”mirror” />
②实现相同效果的Java代码:
BitmapDrawable bitDrawable = new BitmapDrawable(bitmap); bitDrawable.setDither(true); bitDrawable.setTileModeXY(TileMode.MIRROR,TileMode.MIRROR); 2.InsetDrawable
表示把一个Drawable嵌入到另外一个Drawable的内部,并且在内部留一些间距, 类似与Drawable的padding属性,但padding表示的是Drawable的内容与Drawable本身的边距! 而InsetDrawable表示的是两个Drawable与容器之间的边距,当控件需要的**背景比实际的边框 小的时候**,比较适合使用InsetDrawable,比如使用这个可以解决我们自定义Dialog与屏幕之间 的一个间距问题,相信做过的朋友都知道,即使我们设置了layout_margin的话也是没用的,这个 时候就可以用到这个InsetDrawable了!只需为InsetDrawable设置一个insetXxx设置不同 方向的边距,然后为设置为Dialog的背景即可!
相关属性如下:
①XML中使用:
===”10dp”android:insetTop=”10dp” />
在Java代码中使用:
InsetDrawable insetDrawable = new InsetDrawable(getResources().getDrawable(R.drawable.test1), 10, 10, 10, 10);
使用效果图:
3.ClipDrawable
Clip可以译为剪的意思,我们可以把ClipDrawable理解为从位图上剪下一个部分; Android中的进度条就是使用ClipDrawable来实现的,他根据设置level的值来决定剪切 区域的大小,根节点是<clip>
相关属性如下:
clipOrietntion:设置剪切的方向,可以设置水平和竖直2个方向 gravity:从那个位置开始裁剪 drawable:引用的drawable资源,为空的话需要有一个Drawable类型的子节点 ps:这个Drawable类型的子节点:就是在==”@mipmap/ic_bg_meizi”android:gravity=”left” />
②在activity_main主布局文件中设置一个ImageView,将src设置为clipDrawable! 记住是src哦,如果你写成了blackground的话可是会报空指针的哦!!!!
==”match_parent”android:orientation=”vertical”><ImageView=>
③MainActivity.java通过setLevel设置截取区域大小:
{private ImageView img_show;private ClipDrawable cd;private Handler handler = new Handler() {(Message msg) {if (msg.what == 0x123) {cd.setLevel(cd.getLevel() + 500);}}};(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);img_show = (ImageView) findViewById(R.id.img_show);// 核心实现代码cd = (ClipDrawable) img_show.getDrawable();final Timer timer = new Timer();timer.schedule(new TimerTask() {() {handler.sendEmptyMessage(0x123);if (cd.getLevel() >= 10000) {timer.cancel();}}}, 0, 300);}}
好的,有点意思,妹子图别问我拿,百度上一堆哈~
4.RotateDrawable
用来对Drawable进行旋转,也是通过setLevel来控制旋转的,最大值也是:10000
相关属性如下:
pivotY:设置参照点的Y坐标,取值为0~1,默认是50%,即0.5 ps:如果出现旋转图片显示不完全的话可以修改上述两个值解决! drawable:设置位图资源 visible:设置drawable是否可见!
角度图如下:
使用示例:
运行效果图:
代码实现:
在第三点的clipDrawable上做一点点修改即可!
①定义一个rotateDrawable资源文件:
===”50%” /> 我希望你能知道,我的心永远只为你跳动。