Android ImageView&ImageButton 显示图片的一些总结
2017-09-11 18:19
696 查看
ImageView中XML属性src和background的区别
background会根据ImageView组件给定的长宽进行拉伸,而src就存放的是原图的大小,不会进行拉伸 。src是图片内容(前景),bg是背景,可以同时使用。此外: scaleType只对src起作用;bg可设置透明度,比如在ImageButton中就可以用android:scaleType控制图片的缩放方式
设置ImageView图片的一些方法
首先设置布局中的imageView如下<ImageView android:id="@+id/imge2" android:layout_width="match_parent" android:layout_height="wrap_content" android:contentDescription="测试2" />
image2.setBackground(getResources().getDrawable(R.drawable.blackk));//变形 image2.setBackgroundResource(R.drawable.blackk);//变形 image2.setBackgroundDrawable(getResources().getDrawable(R.drawable.blackk));////变形
说明上面3种方法实现同样的功能及效果
image2.setImageDrawable(getResources().getDrawable(R.drawable.blackk)); //不会变形 String path=Environment.getExternalStorageDirectory()+File.separator+"test1.jpg"; Bitmap bm = BitmapFactory.decodeFile(path); image2.setImageBitmap(bm);//不会变形 image2.setImageResource(R.drawable.blackk);//不会变形
setBackground,setBackgroundResource,setBackgroundDrawable对应属性background,会根据ImageView组件给定的长宽进行拉伸。
setImageBitmap,setImageResource对应属性src,存放的是原图的大小,不会进行拉伸。如果想改变src的大小,应该使用属性scaleType。
ScaleType
CENTER 居中,不执行缩放 CENTER_CROP 按原始比例缩放, 裁剪中间部 CENTER_INSIDE 按原始比例缩放, 居中,不裁剪 FIT_CENTER 居中缩放 FIT_START 上对齐缩放 FIT_END 下对齐缩放 FIT_XY 不按比例拉伸缩放 MATRIX 用矩阵来绘制
解决android:background背景图片被拉伸问题
如上所述,background设置的图片会跟View组件给定的长宽比例进行拉伸。举个例子, 36x36 px的图标放在 xhdpi 文件夹中,在854x480(FWVGA,对应hdpi)环境下,按照xhdpi : hdpi : mdpi: ldip = 2 : 1.5 : 1 : 0.75
的比例计算,在FWVGA下,图标的实际大小应该是 27x27。
但是当我把它放到一个 layout_width = 96px, layout_height = 75px 的 LinearLayout,布局代码如下:
<LinearLayout android:gravity="center" android:layout_width="96px" android:layout_height="75px" > <ImageButton android:layout_width="wrap_content" android:layout_height="wrap_content" android:background="@drawable/toolbar_bg" /> </LinearLayout>
实际情况是,我们得到的ImageButton的大小是 33x27,很明显width被拉伸了,这是我们不想看到的情况。
解决方案一:
代码中动态显式设置ImageButton的layout_width和layout_width,如下
LinearLayout.LayoutParams layoutParam = new LinearLayout.LayoutParams(27, 27); layout.addView(imageButton, layoutParam);
不过,事实上我们并不希望在代码存在“硬编码”的情况。
解决方案二:
在你通过setBackgroundResource()或者在xml设置android:background属性时,将你的background以XML Bitmap的形式定义,如下:
<?xml version="1.0" encoding="utf-8"?> <bitmap xmlns:android="http://schemas.android.com/apk/res/android" android:id="@id/toolbar_bg_bmp" android:src="@drawable/toolbar_bg" android:tileMode="disabled" android:gravity="top" > </bitmap>
调用如下:
imageButton.setBackgroundResource(R.drawable.toolbar_bg_bmp)
或者
<ImageButton ... android:background="@drawable/toolbar_bg_bmp" ... />
若背景图片有多种状态,还可参照toolbar_bg_selector.xml:
<?xml version="1.0" encoding="utf-8"?> <selector xmlns:android="http://schemas.android.com/apk/res/android" > <item android:state_pressed="true" > <bitmap android:src="@drawable/toolbar_bg_sel" android:tileMode="disabled" android:gravity="top" /> </item> <item > <bitmap android:src="@drawable/toolbar_bg" android:tileMode="disabled" android:gravity="top" /> </item> </selector>
如此,不管是通过代码方式setBackgroundResource()或XML android:background方式设置背景,均不会产生被拉伸的情况。
ImageButton 使用透明图片
在Android上有很多不规则按钮。这个时候,我们如果想做成不规则按钮的话,第一步就是搞一张边缘透明的png图片,然后用src指定到他,这个时候我们会发现,还没有达到要的效果,还有图片周围还是有一层渲染。此时还要搞第二步:需要对ImageButton设置背景属性
android:background="#00000000",就实现了不规则按钮的效果了。如图:
有朋友可能会说, 直接用background指定该图片就ok啦, 可是,如果用 background指定,会使图片填充整个imageButton.比如imageButton长宽200,而图片长款只有50,那么图片就会被拉伸4倍变模糊。而我们要达到的效果不是为了填充。
参考资料
http://blog.csdn.net/qq_27376951/article/details/51810829
相关文章推荐
- Android深入浅出系列之实例应用—简单的手指拖动图片,图片滑来滑去显示应用Gallery和BaseAdapter以及ImageView的使用
- Android的TextView/EditText使用CharacterStyle&SpannableString来处理图片显示、字体样式、超链接等
- Android中利用OnTouchListener在ImageView中框选显示图片
- Android的TextView/EditText使用CharacterStyle&SpannableString来处理图片显示、字体样式、超链接等
- android 怎么把网络图片生成一个Bitmap显示在ImageView中
- Android用ImageView显示本地和网上的图片
- Android开发:同一ImageView显示不同图片
- android-ImageView显示选择本地图片或拍照
- Android中 在显示ImageView时图片上面和下面都出现一段空白区间的解决办法
- Android之ImageView既能普通图片又能显示gif的方法
- Android的TextView/EditText使用CharacterStyle&SpannableString来处理图片显示、字体样式、超链接等
- Android的TextView/EditText使用CharacterStyle&SpannableString来处理图片显示、字体样式、超链接等
- Android用ImageView显示本地和网上的图片
- 同一个ImageView显示不同的图片--->level-list
- Android手机开发:ImageView使用和从内存读取图片显示
- Android深入浅出系列之实例应用—简单的手指拖动图片,图片滑来滑去显示应用Gallery和BaseAdapter以及ImageView的使用
- Android用ImageView显示本地和网上的图片
- Android用ImageView显示本地和网上的图片(转)
- 【Android】用ImageView显示本地和网上的图片
- Android中利用OnTouchListener在ImageView中框选显示图片