很难为你的应用程序获得正确的图像缩放吗?是你的图片过大,形成内存问题?仍是图片不正确缩放形成不良用户体验的结果?为了寻求一个好的解决方案,咱们咨询了Andreas Agvard(索尼爱立信软件部门),让他分享一些关于这方面的经验。 css
注意:本文没有完整显示出代码示例。你能够下载本文的PDF,来看完整的代码示例。 android
在索尼爱立信软件部门工做,我常常遇到须要图片缩放的应用,例如:当处理别人或者网络上提供的图片。缩放是必要的,由于一般状况下的图片不是你想要呈现的那样。 网络
典型的例子,若是你正在为你的应用开发一个LiveView™扩展。大多数人开发应用利用LiveView™和其余第二屏幕设备,可能须要从新调整图片,重要的是要保持适当的缩放比例和图像质量。固然,在不少状况下,改变图片尺寸是一个有点困难,可是颇有效的途径。 性能
ImageView解决了许多的图片缩放问题,首先,至少你在设置完一个图片源后,不用去解码或缩放图片。但有时须要你本身去解码控制,这是本教程的用武之地。随着本教程,我写了一个代码示例,下载图片缩放代码示例。在文本中呈现的效果,能够经过编译和运行该项目来看到。 spa
孤立的问题
我作这个教程,是由于我已经有一些实用方法来实现图片的缩放,为了不最多见的图片缩放问题。以下面的例子: .net
1 |
Bitmap unscaledBitmap = BitmapFactory.decodeResource(getResources(), mSourceId); |
2 |
Bitmap scaledBitmap = Bitmap.createScaledBitmap(unscaledBitmap, wantedWidth, wantedHeight, true ); |
那么在上面的代码中,什么是正确的,什么是错的?让咱们来看看在不一样的代码行。 code
行1:整个源图像解码到一个位图。 orm
行2:解码的位图缩放到想要的大小。 blog
左边的图片:原始图像。右边的图片:缩放后图片。能够看出明显的失真问题,如原图的眼睛很是的鲜明,缩放后就没有了。高度出现拉伸。 教程
建立一个解决方案
咱们的解决方案,将有一个结构相似上述代码,其中的一部分将取代行1,这样为缩放作准备。另外一部分将取代行2,作最后的缩放。咱们将开始替换行2的部分代码,引入两个新的概念,裁剪和合适。
替换行2
在这一部分,咱们将缩放位图到咱们所须要的。这一步很必要,由于以前的解码能力是有限的。此外,在这一步为了不拉伸,咱们可能要从新调整图片到想要的大小。
有两种可能性能够避免拉伸。不论是那种,咱们都要调整尺寸,以确保他们有相同的宽高比;即缩放图像做为源图像,直到它适合想要的尺寸,或裁剪具备相同的宽高比的源图像为想要的尺寸。
左边的图片:图像经过fit方法缩放。图片已被缩小到适合的尺寸和高度,结果是小于想要的高度。右边的图像:图像crop方法缩放。图像已被缩放到适应至少想要的尺寸。所以原图已被裁剪,切割了成左边和右边二部分。
为了缩放这样的效果,咱们的实现代码以下: