解决android:background背景图片被拉伸问题

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

android:layout_height="wrap_content" android:background="@drawable/toolbar_bg"/>

实际情况是,我们得到的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的形式定义,如下:

android:id="@id/toolbar_bg_bmp"

android:src="@drawable/toolbar_bg"

android:tileMode="disabled" android:gravity="top" >

调用如下:

imageButton.setBackgroundResource(R.drawable.toolbar_bg_bmp)

或者

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

android:tileMode="disabled" android:gravity="top" />

android:tileMode="disabled" android:gravity="top" />

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

android背景图拉伸,解决android:background背景图片被拉伸问题相关推荐

  1. html内容被背景图片遮住怎么办_定义BODY背景图后,DIV的背景图片显示不全(已解决)...

    你的位置: 问答吧 -> WEB标准 -> 问题详情 定义BODY背景图后,DIV的背景图片显示不全(已解决) 一个有趣的问题,当BODY有背景图片的时候,BODY里的DIV一旦也有背景图 ...

  2. CSS实现背景图毛玻璃效果和如何保持图片上的文字显示正常

    说明 因为我的底子特别的差(大佬勿喷),今天想让文字在图片上方显示,并且给图片模糊,结果当图片模糊之后也就是实现毛玻璃效果后,发现图片上的文字也模糊掉了,这个问题当然可以用伪元素的方式解决,但是由于某 ...

  3. Android矢量图动画特效,Android使用SVG矢量图打造酷炫动画效果

    一个真正Android使用SVG矢量图打造酷炫动效往往让人虎躯一震,话不多说,咱们先看看效果: 这个效果我们需要考虑以下几个问题: 1. 这是图片还是文字: 2. 如果是图片该如何拿到图形的边沿线坐标 ...

  4. android自定义控件不显示,解决Android Studio Design界面不显示layout控件的问题

    Android Studio更新到3.1.3后,发现拖到Design中的控件在预览界面中不显示: 解决办法: 在Styles.xml中的parent="..."中的Theme前添加 ...

  5. Java语言为excel添加水印,使用原生POI, (XSSFWorkbook, XSSFSheet), 真正背景图水印效果,非普通图片张贴

    前言 首先致敬以下我参考的博客 https://www.jianshu.com/p/4332f5feab2e 最近接到一个所谓给导出文件excel加水印的需求,但是一番搜索百度之后意识到一个现实:ex ...

  6. 百度css3背景图代码,CSS3 实现花式背景图案

    CSS3 gradient介绍一文中介绍了用渐变画实线条纹背景,事实上用渐变配合background背景图层可以创造出各种奇妙的背景效果,例如参照css3patterns.本篇就举几个例子介绍一下它们 ...

  7. vuejs中html2canvas使用 背景图和二维码海报图片保存到一张图片上 生成一张海报并下载

    不少的项目中都用到了二维码加背景图片生成海报的宣传图片,实现方法就是canvas绘制到一张上后进行下载.html2canvas的技巧在这里不在讲解. 二维码和背景图片进行定位. 在传统场合,这类功能往 ...

  8. div自适应背景图的尺寸:设置背景图的方式;img作为div元素的方式

    目录 零.问题描述和基本情况介绍 案例: 问题及疑问: 一.background-size:cover;和background-size:100%;的区别: 1.background-size:100 ...

  9. 微信背景图太大了怎么缩小?图片大小转换的方法

    很多小伙伴都还不了解微信背景图太大了怎么缩小,下面给大家介绍一下修改图片尺寸的相关内容,如何利用图片大小转换工具来改图片大小(https://www.yasuotu.com/size),一起来看看吧. ...

最新文章

  1. 一份不错的vue.js基础笔记!!!!
  2. kamctl start
  3. 学python入门书-如何学习Python,以及新手如何入门?
  4. 服务端 I/O 性能大比拼:Node、PHP、Java、Go哪家强?
  5. SVM分类算法的基本理论问题
  6. ABP入门系列(14)——应用BootstrapTable表格插件
  7. vue_props div赋值props定义变量 templete获取
  8. .net byte转java byte_CVE20200688的武器化与.net反序列化漏洞那些事
  9. Swift中类的使用
  10. 服务器端配置nodejs环境(使用pm2进程管理运行)
  11. Spring boot CommandLineRunner接口使用例子
  12. 打印学生选课清单(25分) c++实现
  13. 【LeetCode】75. 颜色分类,使得相同颜色的元素相邻
  14. IOS应用在iPhone5和iPhone5s上不能全屏显示,应用画面上下各有1条黑色的解决方案
  15. HTML编辑器-Bluefish 2.0.1 发布
  16. 六、银行会计核算(全是重点)
  17. 吐血整理C++书单,萌新到大牛,要看哪些书?
  18. java双冒号_jdk8新特性之双冒号 :: 用法及详解
  19. Python Scipy 显著性检验
  20. android局部布局刷新,Android RecyclerView 局部刷新分析

热门文章

  1. 大数据分析师工资待遇
  2. filezilla 无法启动传输
  3. 2.2 DP: Value Iteration Gambler‘s Problem
  4. PHPExcel设置单元格值下拉选择
  5. c#模拟看板控件_C#TIPTOP电子看板
  6. 关于Ubuntu多显卡服务器,掉显卡的问题
  7. android接口调试工具
  8. 从零开始自制实现WebServer(十九)---- 正式系统的学习一下Git 捣鼓捣鼓github以及一些其他的小组件
  9. 自动控制理论开环与闭环思考(从飞行控制角度)
  10. 【洛谷】P1359 租用游艇