ImageView显示图像控件

一、简介

1、

2、

  ImageView,图像视图,直接继承自View类,它的主要功能是用于显示图片,实际上它不仅仅可以用来显示图片,任何Drawable对象都可以使用ImageView来显示。ImageView可以适用于任何布局中,并且Android为其提供了缩放和着色的一些操作。

  ImageView的一些常用属性,并且这些属性都有与之对应的getter、setter方法:

  • android:adjustViewBounds:设置ImageView是否调整自己的边界来保持所显示图片的长宽比。
  • android:maxHeight:设置ImageView的最大高度。
  • android:maxWidth:设置ImageView的最大宽度。
  • android:scaleType:设置所显示的图片如何缩放或移动以适应ImageView的大小。
  • android:src:设置ImageView所显示的Drawable对象的ID。

  对于android:scaleType属性,因为关于图像在ImageView中的显示效果,所以有如下属性值可以选择:

  • matrix:使用matrix方式进行缩放。
  • fitXY:横向、纵向独立缩放,以适应该ImageView。
  • fitStart:保持纵横比缩放图片,并且将图片放在ImageView的左上角。
  • fitCenter:保持纵横比缩放图片,缩放完成后将图片放在ImageView的中央。
  • fitEnd:保持纵横比缩放图片,缩放完成后将图片放在ImageView的右下角。
  • center:把图片放在ImageView的中央,但是不进行任何缩放。
  • centerCrop:保持纵横比缩放图片,以使图片能完全覆盖ImageView。
  • centerInside:保持纵横比缩放图片,以使得ImageView能完全显示该图片。

3、

属性名称

描述

android:adjustViewBounds

是否保持宽高比。需要与maxWidth、MaxHeight一起使用,否则单独使用没有效果。

android:cropToPadding

是否截取指定区域用空白代替。单独设置无效果,需要与scrollY一起使用,效果如下,实现代码见代码部分:

android:maxHeight

设置View的最大高度,单独使用无效,需要与setAdjustViewBounds一起使用。如果想设置图片固定大小,又想保持图片宽高比,需要如下设置:

1) 设置setAdjustViewBounds为true;

2) 设置maxWidth、MaxHeight;

3) 设置设置layout_width和layout_height为wrap_content。

android:maxWidth

设置View的最大宽度。同上。

android:scaleType

设置图片的填充方式。

matrix

0

用矩阵来绘图

fitXY

1

拉伸图片(不按比例)以填充View的宽高

layout_

height

:30px

layout_

width

:120px

fitStart

2

按比例拉伸图片,拉伸后图片的高度为View的高度,且显示在View的左边

fitCenter

3

按比例拉伸图片,拉伸后图片的高度为View的高度,且显示在View的中间

fitEnd

4

按比例拉伸图片,拉伸后图片的高度为View的高度,且显示在View的右边

center

5

按原图大小显示图片,但图片宽高大于View的宽高时,截图图片中间部分显示

layout_

height

:60px

layout_

width

:80px

padding

:10px

centerCrop

6

按比例放大原图直至等于某边View的宽高显示。

centerInside

7

当原图宽高或等于View的宽高时,按原图大小居中显示;反之将原图缩放至View的宽高居中显示。

android:src

设置View的drawable(如图片,也可以是颜色,但是需要指定View的大小)

android:tint

将图片渲染成指定的颜色。见下图:

左边为原图,右边为设置后的效果,见后面代码。

二、使用方法

三、代码实例

效果图:

代码:

/iamgeViewDemo1/res/layout/activity01.xml

 <?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" > <ImageView
android:layout_width="210dp"
android:layout_height="364dp"
android:src="@drawable/ic_launcher" /> </LinearLayout>

四、收获

最新文章

  1. CSS3 -webkit-transform
  2. I535卡刷土豆修改4.1.2版本ROMV4過程
  3. 使用WIF实现单点登录Part II —— Windows Identity Foundation基本原理
  4. Android的快速开发框架afinal
  5. Jmeter使用——参数化
  6. hdu 1251 统计拼图
  7. 在 WindowMobile 上的模拟LED 显示屏插件(转)
  8. 【解决方案】纯js动态克隆表一行元素
  9. POJ 1426 Find The Multiple(数论——中国同余定理)
  10. android studio 开发免安装的app之目录结构
  11. Linux基础命令--date
  12. 如何将云原生工作负载映射到 Kubernetes 中的控制器
  13. 老男孩python学习自修【第一天】文件IO用法
  14. &lt;记录&gt; PHP监控进程状态,完成掉线自动重启
  15. jquery-validae
  16. MVC缺点总结
  17. VB.NET文件读写(C#可以改写)
  18. JS DOM操作(四) Window.docunment对象——操作内容
  19. Spring中使用属性文件properties的两种方式
  20. bzoj 2038 小Z的袜子 莫队算法

热门文章

  1. 棣小天儿的第一个python程序
  2. 怎样优雅的管理ActionBar
  3. CNN结构
  4. Struts 2 类型转换器 输入校验 拦截器
  5. position学习终结者(二)
  6. docker镜像制作---jdk7+tomcat7基础镜像
  7. Hazelcast 内存数据网格
  8. yum安装mysql5.6
  9. 第一课Linux系统安装知识(1)
  10. Oracle事务和锁机制