当前位置: 首页 > news >正文

Android应用资源---绘制资源类型(Drawable)(五)

嵌入可绘制资源

定义在XML中的一个可绘制资源,它能够用指定的距离嵌入到另一个可绘制资源中。这种资源可在View对象需要的背景比它的实际边界小的时候使用。
文件位置(FILE LOCATION):

res/drawable/filename.xml

文件名被用于资源ID

被编译资源的数据类型(COMPILED RESOURCE DATATYPE):

资源指向一个InsetDrawable对象。

资源引用(RESOURCE REFERENCE):

Java代码中:R.drawable.filename

XML中:@[package:]drawable/filename

语法(SYNTAX):

    <?xml version="1.0" encoding="utf-8"?>
<inset
   
xmlns:android="http://schemas.android.com/apk/res/android"
   
android:drawable="@drawable/drawable_resource"
   
android:insetTop="dimension"
   
android:insetRight="dimension"
   
android:insetBottom="dimension"
   
android:insetLeft="dimension"/>

元素(ELEMENTS):

  <inset>

      定义嵌入的可绘制资源。它必须是根元素。

      属性(ATTRIBUTES):

      xmlns:android

      字符串值,必须的。它定义了XML的命名空间,必须是:http://schemas.android.com/apk/res/android

      android:drawable

      要绘制的资源,必须的,它指向一个要嵌入的可绘制资源。

      android:insetTop

      尺寸值。用尺寸值或Dimension资源定义顶部的嵌入位置。

      android:insetRight

      尺寸值。用尺寸值或Dimension资源定义右边的嵌入位置。

      android:insetBottom

      尺寸值。用尺寸值或Dimension资源定义底部的嵌入位置。

      android:insetLeft

      尺寸值。用尺寸值或Dimension资源定义左边的嵌入位置。

例子(EXAMPLE):

<?xml version="1.0" encoding="utf-8"?>
<insetxmlns:android="http://schemas.android.com/apk/res/android"
   
android:drawable="@drawable/background"
   
android:insetTop="10dp"
   
android:insetLeft="10dp"/>

裁剪可绘制资源

定义在XML中的一个可绘制资源,它能够基于这个资源的当前级别来裁剪另一个绘制资源。它能够基于级别来控制子绘制资源要被裁剪掉宽度和高度,就像重力来控制资源被放在容器中位置一样。这种资源经常被用于像进度条这样的效果。

文件位置(FILE LOCATION):

res/drawable/filename.xml

文件名被用作资源ID

被编译资源的数据类型(COMPILED RESOURCE DATATYPE

资源指向一个ClipDrawable对象。

资源引用(RESOURCE REFERENCE

Java代码中:R.drawable.filename

XML中:@[package:]drawable/filename

语法(SYNTAX):

 <?xml version="1.0" encoding="utf-8"?>
<clip
   
xmlns:android="http://schemas.android.com/apk/res/android"
   
android:drawable="@drawable/drawable_resource"
   
android:clipOrientation=["horizontal" | "vertical"]
   
android:gravity=["top" | "bottom" | "left" | "right" | "center_vertical"
|
                     
"fill_vertical" | "center_horizontal" | "fill_horizontal"
|
                     
"center" | "fill" | "clip_vertical" | "clip_horizontal"] />

 

元素(ELEMENTS):

<clip>

定义要裁剪的绘制资源。它必须是根元素。

属性(ATTRIBUTES):

    xmlns:android

    字符串值,必须的。它定义了XML的命名空间,必须是:http://schemas.android.com/apk/res/android

    android:drawable

   可绘制的资源,必须的。它指向要裁剪的一个可绘制资源。

    android:clipOrientation

关键值,它定义了裁剪的方向。必须是下列值之一。

说明

horizontal

水平方向裁剪可绘制的资源

vertical

垂直方向裁剪可绘制的资源

    android:gravity

关键值,它指定了可绘制资源的裁剪位置。

它必须是下表中的一个或多个值的组合(组合时用“|”来分隔)。

说明

top

把对象放到容器的顶部,不改变它的尺寸。当clipOrientation被设置为vertical时,会在可绘制资源的底部进行裁剪。

bottom

把对象放到容器的底部,不改变它的尺寸。当clipOrientation被设置为vertical时,会在可绘制资源的顶部进行裁剪。

left

把对象放到容器的左边,不改变它的尺寸。这是默认的设置。当clipOrientation被设置为horizontal时,会在可绘制资源的右边进行裁剪。

right

把对象放到容器的右边,不改变它的尺寸。当clipOrientation被设置为horizontal时,会在可绘制资源的左边进行裁剪。

center_vertical

把对象放在容器的垂直中心位置,不改变它的尺寸。裁剪行为与重力被设为center时相同。

fill_vertical

如果需要,对象的垂直尺寸会增长,以便在垂直方向能够完全填充它的容器。当clipOrientation被设置为vertical时,因为绘制资源要填充垂直空间,所以不会有裁剪发生(除非可绘制资源的级别是0,导致它不可见)。

center_horizontal

把对象放在容器的水平中心,不改变它的尺寸。裁剪行为与重力是center是相同。

fill_horizontal

如果需要,对象会增长它的水平尺寸,以便在水平方向能够完全填充它的容器。当clipOrientation被设置为horizontal时,因为可绘制资源要填充水平空间,所以不会有裁剪发生(除非可绘制资源被设置为0,导致它不可见)。

center

把对象放到它的容器的中心位置,不改变它的尺寸。当clipOrientation被设置为horizontal时,在左右两边会发生裁剪;当clipOrientation被设置为vertical时,在上下两边会发生裁剪。

fill

如果需要,对象水平和垂直尺寸都会增长,以便能够完全填充它的容器。因为可绘制资源要完全填充它的容器的水平和垂直空间,所以不会裁剪发生(除非可绘制资源的级别被设置为0,导致它不可见)。

clip_vertical

额外的选项,它能够把它的容器的上下边界,设置为子对象的上下边缘的裁剪边界。裁剪要基于对象垂直重力设置:如果重力设置为top,则裁剪下边,如果设置为bottom,则裁剪上边,否则则上下两边都要裁剪。

clip_horizontal

额外的选项,它能够把它的容器的左右边界,设置为子对象的左右边缘的裁剪边界。裁剪要基于对象垂直重力设置:如果重力设置为right,则裁剪左边,如果设置为left,则裁剪右边,否则则左右两边都要裁剪。

例子(EXAMPLE):

XML文件被放在res/drawable/clip.xml中:

<?xml version="1.0" encoding="utf-8"?>
<clipxmlns:android="http://schemas.android.com/apk/res/android"
   
android:drawable="@drawable/android"
   
android:clipOrientation="horizontal"
   
android:gravity="left"/>

下面的布局XML给一个View对象应用了这个裁剪可绘制资源。

<ImageView
   
android:id="@+id/image"
   
android:background="@drawable/clip"
   
android:layout_height="wrap_content"
   
android:layout_width="wrap_content"/>

下面的代码获取了这个可绘制资源,并且为了能够逐步显示这张图片,它添加了裁剪效果:

ImageView imageview =(ImageView) findViewById(R.id.image);
ClipDrawable drawable =(ClipDrawable) imageview.getDrawable();
drawable
.setLevel(drawable.getLevel()+1000);

资源显示效果如下图:

相关文章:

  • 查看 SELinux状态及关闭SELinux
  • Linux下Qt与mysql建立连接
  • poj 2192 Zipper
  • centos下查看tomcat的版本号
  • 浅谈UML中常用的几种图——用例图
  • [转]项目中Struts/Spring/Hibernate的基本流程
  • mac brew 安装 nginx fpm mysql 教程
  • 微软等公司数据结构+算法面试100题--链表
  • UIPickerView的使用
  • 目标板UBI工具交叉编译
  • 一个web项目web.xml的配置中context-param配置作用
  • Puppet安装dashboard
  • 非常有用的并发控制-循环栅栏CyclicBarrier
  • PHP简易的缓存实现思路
  • Ubuntu下安装Cacti+rrdtool监控Windows
  • 【vuex入门系列02】mutation接收单个参数和多个参数
  • Android开发 - 掌握ConstraintLayout(四)创建基本约束
  • github从入门到放弃(1)
  • HTTP传输编码增加了传输量,只为解决这一个问题 | 实用 HTTP
  • Java|序列化异常StreamCorruptedException的解决方法
  • javascript面向对象之创建对象
  • JavaScript实现分页效果
  • Kibana配置logstash,报表一体化
  • Nodejs和JavaWeb协助开发
  • PHP那些事儿
  • Python_OOP
  • React16时代,该用什么姿势写 React ?
  • 规范化安全开发 KOA 手脚架
  • 如何胜任知名企业的商业数据分析师?
  • 双管齐下,VMware的容器新战略
  • 温故知新之javascript面向对象
  • 一些基于React、Vue、Node.js、MongoDB技术栈的实践项目
  • 用 Swift 编写面向协议的视图
  • 教程:使用iPhone相机和openCV来完成3D重建(第一部分) ...
  • 摩拜创始人胡玮炜也彻底离开了,共享单车行业还有未来吗? ...
  • # 透过事物看本质的能力怎么培养?
  • #ubuntu# #git# repository git config --global --add safe.directory
  • (04)odoo视图操作
  • (10)STL算法之搜索(二) 二分查找
  • (zt)基于Facebook和Flash平台的应用架构解析
  • (草履虫都可以看懂的)PyQt子窗口向主窗口传递参数,主窗口接收子窗口信号、参数。
  • (附源码)spring boot校园拼车微信小程序 毕业设计 091617
  • (附源码)springboot青少年公共卫生教育平台 毕业设计 643214
  • (入门自用)--C++--抽象类--多态原理--虚表--1020
  • (学习日记)2024.01.19
  • (一)【Jmeter】JDK及Jmeter的安装部署及简单配置
  • (已解决)报错:Could not load the Qt platform plugin “xcb“
  • (转)利用ant在Mac 下自动化打包签名Android程序
  • (转)平衡树
  • *Django中的Ajax 纯js的书写样式1
  • .bat文件调用java类的main方法
  • .NET 8 编写 LiteDB vs SQLite 数据库 CRUD 接口性能测试(准备篇)
  • .NET Core使用NPOI导出复杂,美观的Excel详解
  • .net MVC中使用angularJs刷新页面数据列表
  • .net安装_还在用第三方安装.NET?Win10自带.NET3.5安装