博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
解决android:background背景图片被拉伸问题
阅读量:6618 次
发布时间:2019-06-25

本文共 1971 字,大约阅读时间需要 6 分钟。

  hot3.png

ImageView中XML属性src和background的区别:

background会根据ImageView组件给定的长宽进行拉伸,而src就存放的是原图的大小,不会进行拉伸。src是图片内容(前景),bg是背景,可以同时使用。

此外:scaleType只对src起作用;bg可设置透明度,比如在ImageButton中就可以用android:scaleType控制图片的缩放方式

 

如上所述,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,布局代码如下:

 

  1. <LinearLayout android:gravity="center" android:layout_width="96px" android:layout_height="75px"  >  
  2.     <ImageButton android:layout_width="wrap_content" 
  3.     android:layout_height="wrap_content" android:background="@drawable/toolbar_bg"/>      
  4. </LinearLayout>  

 

实际情况是,我们得到的ImageButton的大小是 33x27,很明显width被拉伸了,这是我们不想看到的情况。

解决方案一:

代码中动态显式设置ImageButton的layout_width和layout_width,如下 

  1. LinearLayout.LayoutParams layoutParam = new LinearLayout.LayoutParams(27, 27);  
  2. layout.addView(imageButton, layoutParam);  
不过,事实上我们并不希望在代码存在“硬编码”的情况。

 

解决方案二:

在你通过setBackgroundResource()或者在xml设置android:background属性时,将你的background以XML Bitmap的形式定义,如下:

 

  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <bitmap xmlns:android="http://schemas.android.com/apk/res/android"  
  3.     android:id="@id/toolbar_bg_bmp"  
  4.     android:src="@drawable/toolbar_bg"  
  5.     android:tileMode="disabled" android:gravity="top" >  
  6. </bitmap>  
调用如下:

 

    imageButton.setBackgroundResource(R.drawable.toolbar_bg_bmp)

或者

    <ImageButton ...  android:background="@drawable/toolbar_bg_bmp" ... />

若背景图片有多种状态,还可参照toolbar_bg_selector.xml:

 

  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <selector xmlns:android="http://schemas.android.com/apk/res/android" >  
  3.     <item android:state_pressed="true" >  
  4.         <bitmap android:src="@drawable/toolbar_bg_sel" 
  5.         android:tileMode="disabled" android:gravity="top" />  
  6.     </item>  
  7.     <item >  
  8.         <bitmap android:src="@drawable/toolbar_bg"
  9.         android:tileMode="disabled" android:gravity="top" />  
  10.     </item>  
  11. </selector>  

 

如此,不管是通过代码方式setBackgroundResource()或XML android:background方式设置背景,均不会产生被拉伸的情况。

转载于:https://my.oschina.net/huqiji/blog/800558

你可能感兴趣的文章
Qt的Script、Quick、QML的关系与总结
查看>>
vue 路由demo
查看>>
Nexus设备升级5.0方法
查看>>
最简单 NDK 样例
查看>>
No.4 PyQt学习(页面跳转)
查看>>
洛谷P1311 选择客栈
查看>>
Oracle参数设置之set与reset的实际案例
查看>>
Python 字典 copy()方法
查看>>
判断是否是爬虫在访问网站
查看>>
将TIMESTAMP类型的差值转化为秒的方法
查看>>
java程序员必须要学会的linux命令总结
查看>>
Java代码规范和质量检查插件-Checkstyle(官方资源)
查看>>
chrome设置书签默认显示
查看>>
Golang的字符编码介绍
查看>>
无法卸载软件? 卸载有残留
查看>>
SpringMVC(三):@RequestMapping中的URL中设定通配符,可以使用@PathVariable映射URL绑定的占位符...
查看>>
21-spring学习-springMVC实现CRUD
查看>>
Hibernate与IBatis的优缺点及可行性分析
查看>>
IDEA:将WEB-INF\lib下的Jar包添加到项目中
查看>>
【大型网站技术实践】初级篇:借助Nginx搭建反向代理服务器
查看>>