ImageView图片控件
ImageView显示任意图像,例如图标。ImageView类可以加载各种来源的图片(如资源或图片库),需要计算图像的尺寸,比便它可以在其他布局中使用,并提供例如缩放和着色(渲染)各种显示选项。
1.常用属性
演示代码:
<ImageView
//控件id
android:id = "@+id/xxx" @+id/xxx表示新增控件命名为xxx
//宽度与高度
android:layout_width="wrap_content" //wrap_content或者match_parent
android:layout_height="wrap_content" //wrap_content或者match_parent
//此外,可以具体设置高度和宽度显示的像素,不过这样设置如果图片尺寸大于设置的显示的尺寸,则图片是显示不全的,这是可以配合android:scaleType属性。
android:layout_width="200dp"
android:layout_height="200dp"
//把原图按照指定的大小在View中显示,拉伸显示图片,不保持原比例,填满ImageButton.
android:scaleType="fitXY"
//其他的关于android:scaleType的参数解释,也可以参考下面的直观图
//android:scaleType="center" 在视图中心显示图片,并且不缩放图片
//android:scaleType="centercrop" 按比例缩放图片,使得图片长 (宽)的大于等于视图的相应维度
//android:scaleType="centerinside" 按比例缩放图片,使得图片长 (宽)的小于等于视图的相应维度
//android:scaleType="fitcenter" 按比例缩放图片到视图的最小边,居中显示
//android:scaleType="fitend" 按比例缩放图片到视图的最小边,显示在视图的下部分位置
//android:scaleType="fitstart" 把图片按比例扩大/缩小到视图的最小边,显示在视图的上部分位置
//android:scaleType="matrix" 用矩阵来绘制
//图片来源,需要将图片复制放到res/drawable文件夹里面,引用的时候不需要写图片的后缀
android:src ="@drawable/beautiful">
2.android:scaleType图片的缩放和位置演示图:
01.图比ImageView小
02.图片比ImageView大
3.ImageView常用的方法
setAlpha设置透明度
setColorFilter为图片应用任意颜色滤镜
setImageBitmap (Bitmap bm)设置位图作为该 ImageView 的内容
//设置透明度
img_gril.setImageAlpha(aple);
//调用方法
public void add(View view){
aple+=20;
if(aple>255){
aple=255;
Toast.makeText(this, "很高清了兄嘚", Toast.LENGTH_SHORT).show();
}
img_gril.setImageAlpha(aple);
}
public void del(View view){
aple-=20;
if(aple<0){
aple=0;
Toast.makeText(this, "眼花么兄嘚", Toast.LENGTH_SHORT).show();
}
img_gril.setImageAlpha(aple);
}
调用内存卡中的图片
manifests/AndroidManifests.xml中设置读取内存卡的权限
<!--读取内存卡的权限-->
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"></uses-permission>
Activity中获取内存中图片
//获取手机内存卡中的图片
if(Environment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED)){
//获取内存卡的路径
String sdcardPath=Environment.getExternalStorageDirectory().getAbsolutePath();
File file=new File(sdcardPath+"/images");
files = file.listFiles();
}
//设置默认图片要从内存文件中获取了
bitmap = BitmapFactory.decodeFile(files[index].getAbsolutePath());
img_gril.setImageBitmap(bitmap);
抠图及局部放大
img_gril.setOnTouchListener(new View.OnTouchListener() {
@Override
public boolean onTouch(View v, MotionEvent event) {
//获取手指坐标
float x=event.getX();
float y=event.getY();
//抠图
Bitmap nb=Bitmap.createBitmap(bitmap,(int)x,(int)y,30,30);
jb_fd.setImageBitmap(nb);
jb_fd.setX(b);
jb_fd.setY(a);
return true;
}
});