在Android中因为不同像素手机的多样化,对于一张图片,放大不同的手机上因像素不同显示上也会有区别。
现有如下需求:将一张图片宽度充满整个屏幕并显示。
我们常常做的可能是如下两种方式对图片进行处理。
通过<ImageView>,定义属性layout_parent="match_parent"和layout_parent="wrap_content",同时利用<ImageView>的scaleType属性进行缩放。
- scaleType="fitXY":当设置为该属性时,会导致图片横向拉伸,导致图片变形,如果图片上有字体,那么这将是很糟的一件事。
- scaleType="centerCrop":等比缩放应该没问题了吧,可是很尴尬,还是不行。图片在处理的时候,首先会得到图片的大小,确定图片宽高之后再进行缩放。这样在图片显示的范围确定之后再以图片的中心点进行等比缩放,直到宽度完全充满了屏幕。这样很尴尬,图片的上下会被切掉,这样图片显示不全,仍然不是我们想要的。
我的做法是,在代码中通过缩放后得到图片,然后通过设置backgroud的方法将图片添加进去,这样就解决了,那么上代码:
//得到图片的分辨率,获取宽度 DisplayMetrics dm = new DisplayMetrics(); getWindowManager().getDefaultDisplay().getMetrics(dm); int mScreenWidth = dm.widthPixels;// 获取屏幕分辨率宽度 int mScreenHeight = dm.heightPixels; //加载图片 Bitmap bitmap = BitmapFactory.decodeResource(getResources(), R.drawable.bank_help); int bitmapWidth = bitmap.getWidth(); int bitmapHeight = bitmap.getHeight(); //得到图片宽度比 float num = mScreenWidth / (float)bitmapWidth; Matrix matrix = new Matrix(); matrix.postScale(num, num); // 产生缩放后的Bitmap对象 Bitmap resizeBitmap = Bitmap.createBitmap(bitmap, 0, 0, bitmapWidth, bitmapHeight, matrix, true);
以上代码,分为以下步骤
1. 获取屏幕分辨率。
2. 获取图片并测量宽高,获取图片的宽高
3. 通过屏幕宽度/图片宽度得到对应的缩放比
4. 创建Matrix对象,并确定缩放。(ps:这个东西很叼,在前面的渐变色中也用到了改对象)
5. 通过Bitmap.createBitmap()方法生成图片。(ps:最后一个参数必须传true,传入false的话,缩放的图片会显示不清楚)
以上就是java图片处理相关操作介绍,希望对大家的学习有所帮助。
本文向大家介绍Android 背景图片的缩放实现,包括了Android 背景图片的缩放实现的使用技巧和注意事项,需要的朋友参考一下 Android 背景图片的缩放 ONE Goal ,ONE Passion ! 我们看到一些效果,控件中的背景图片会慢慢变大,但是控件不会随着图片的放大而变大.效果如下: 分析: 想让图片变大,而且控件本身大小不能改变,那么就要改变图片自身大小,而不能改变控件大小.
使 UIScrollView 中的图片支持手势缩放。双击图片可以放大图片,或者pinch(捏合)手势可以缩放图片。基本原理是UIScrollView中嵌套UIScrollView,然后再嵌套UIImageView,可对UIImageView进行伸缩。 [Code4App.com]
本文向大家介绍基于jquery实现等比缩放图片,包括了基于jquery实现等比缩放图片的使用技巧和注意事项,需要的朋友参考一下 基于jquery的图片尺寸调整 resize.js 代码很简洁,使用起来也很简单,小伙伴们直接使用即可
本文向大家介绍Android 图片缩放实例详解,包括了Android 图片缩放实例详解的使用技巧和注意事项,需要的朋友参考一下 本文实现Android中的图片的缩放效果 首先设计布局: 逻辑代码如下: 如果你对矩阵的设置不清楚,还可以使用下列api提供的方法替换上面标记部分的代码: matrix.setScale(0.5f, 1); 注意: 新建矩阵并设置缩放值 M
问题内容: 我有三个问题: 当我尝试在较小尺寸的div中使用背景图像时,div只显示图像的一部分。如何显示图像的全部或特定部分? 我的图片较小,想在更大的div中使用。但是不想使用重复功能。 CSS中有什么方法可以处理图像的不透明度? 问题答案: 调整图像大小以适合div大小。 使用CSS3,您可以执行以下操作: 关于不透明度
本文向大家介绍jquery实现图片按比例缩放示例,包括了jquery实现图片按比例缩放示例的使用技巧和注意事项,需要的朋友参考一下
本文向大家介绍javascript实现获取图片大小及图片等比缩放的方法,包括了javascript实现获取图片大小及图片等比缩放的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了javascript实现获取图片大小及图片等比缩放的方法。分享给大家供大家参考,具体如下: 获取图片大小: 图片等比缩放: 更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《JavaScript
本文向大家介绍PHP图片处理之使用imagecopyresampled函数实现图片缩放例子,包括了PHP图片处理之使用imagecopyresampled函数实现图片缩放例子的使用技巧和注意事项,需要的朋友参考一下 网站优化不能只定在代码上,内容也是网站最需要优化的对象之一,而图像又是网站中最主要的内容。图像的优化最需要处理的就是将所有上传到网站中的大图片自动缩放称小图(在网页中大小够用就行),以