前言:
因为项目中显示图片是用Picasso,设置placeholder和error图片的时候发现,本地图片的大小无法满足我的需求,需要先对图片大小改变再显示。
Picasso的placeholder和error的参数也只有int resId和Drawable drawable
于是打算将改变过大小的Drawable传进入显示,咦,效果很满意!
整个过程的思路:
将本地图片(R.drawable.image)变成Drawable对象
将Drawable对象转换成Bitmap对象
将Bitmap对象根据指定大小创建一个新的Bitmap对象
将Bitmap对象转换成Drawable对象
代码:
1. 将本地图片(R.drawable.image)变成Drawable对象
Drawable drawable = ContextCompat.getDrawable(context, R.drawable.image);
2. 将Drawable对象转换成Bitmap对象
/** * 将Drawable转换为Bitmap * @param drawable * @return */ private Bitmap drawableToBitmap(Drawable drawable) { //取drawable的宽高 int width = drawable.getIntrinsicWidth(); int height = drawable.getIntrinsicHeight(); //取drawable的颜色格式 Bitmap.Config config = drawable.getOpacity() != PixelFormat.OPAQUE ? Bitmap.Config.ARGB_8888 : Bitmap.Config.RGB_565; //创建对应的bitmap Bitmap bitmap = Bitmap.createBitmap(width, height, config); //创建对应的bitmap的画布 Canvas canvas = new Canvas(bitmap); drawable.setBounds(0, 0, width, height); //把drawable内容画到画布中 drawable.draw(canvas); return bitmap; }
3. 整个流程的执行
后来发现一个更简洁的方法
/** * 将本地资源图片大小缩放 * @param resId * @param w * @param h * @return */ public Drawable zoomImage(int resId, int w, int h){ Resources res = mContext.getResources(); Bitmap oldBmp = BitmapFactory.decodeResource(res, resId); Bitmap newBmp = Bitmap.createScaledBitmap(oldBmp,w, h, true); Drawable drawable = new BitmapDrawable(res, newBmp); return drawable; }
原来复杂的思路
/** * 缩放Drawable *@drawable 原来的Drawable *@w 指定的宽 *@h 指定的高 */ public Drawable zoomDrawable(Drawable drawable, int w, int h){ //获取原来Drawable的宽高 int width = drawable.getIntrinsicWidth(); int height = drawable.getIntrinsicHeight(); //将Drawable转换成Bitmap Bitmap oldbmp = drawableToBitmap(drawable); //计算scale Matrix matrix = new Matrix(); float scaleWidth = ((float)w/width); float scaleHeight = ((float)h/height); matrix.postScale(scaleWidth, scaleHeight); //生成新的Bitmap Bitmap newbmp = Bitmap.createBitmap(oldbmp, 0, 0, width, height, matrix, true); //设置bitmap转成drawable后尺寸不变 //这个很关键后面解释!! DisplayMetrics metrics = new DisplayMetrics(); manager.getDefaultDisplay().getMetrics(metrics); Resources resources = new Resources(mContext.getAssets(), metrics, null); return new BitmapDrawable(resources, newbmp); }
学习中遇到的问题
看网上的教程是没有下面
DisplayMetrics metrics = new DisplayMetrics(); manager.getDefaultDisplay().getMetrics(metrics); Resources resources = new Resources(mContext.getAssets(), metrics, null);
这段代码的。
假如我指定的宽高是200,生成的Drawable的宽高却只有100。
原来Bitmap转换成Drawable的尺寸是会变小的。
那段代码就能解决尺寸变小的问题。
如果路过的大神有更好的方法,希望能指点一下小白。
补充知识:Android中如何将res里的图片转换成Bitmap.
1.复制代码即可:
Resources res = MainActivity.this.getResources();
Bitmap bmp= BitmapFactory.decodeResource(res, R.mipmap.flower);
以上这篇Android 将本地资源图片转换成Drawable,进行设置大小操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持小牛知识库。
我想设计下面的UI。为了达到同样的效果,我试着使用拖拉。但问题是:在不同的屏幕尺寸上,可绘制图像的显示方式不同。屏幕尺寸为6.0时:可抽片呈椭圆形,下方为圆形。 用户界面设计尝试实现: 内容和布局: 线性布局可绘制: bg_布局: 主要的类别:
我正在尝试创建字符串及其长度的映射。是,是。
我试图将一个可绘制资源转换为位图,但每个代码段和每个自己的尝试都返回null或空字符串。 我尝试了一些基本的方法,比如Bitmapfactory。decodeResource(在这里,我尝试了活动上下文、应用程序上下文等,以及各种可绘制资源(png、vector、xml),我尝试了转换中的不同代码段,它总是返回null或“”。我还尝试更改可绘制文件夹而不是可绘制文件夹-24我尝试了基本的可绘制文件
本文向大家介绍python 将dicom图片转换成jpg图片的实例,包括了python 将dicom图片转换成jpg图片的实例的使用技巧和注意事项,需要的朋友参考一下 主要原理:调整dicom的窗宽,使之各个像素点上的灰度值缩放至[0,255]范围内。 使用到的python库:SimpleITK 下面是一个将dicom(.dcm)图片转换成jpg图片的demo: 以上这篇python 将dicom
问题内容: 我如何将一个小的Endian二进制文件转换为大Endian二进制文件。我有一个用C编写的二进制二进制文件,我正在用Java的DataInputStream读取此文件,该文件以大端字节格式读取。我也看过ByteBuffer类,但不知道如何使用它来获得我想要的结果。请帮忙。 非常感谢 问题答案: 谷歌搜索了很多之后,我发现了一个具有SwappedDataInputStream类的Apach
对于国际化的程序,往往有如下的需求: 在某一时区A的用户向系统提交的数据被保存在了服务端的数据库中。同时,系统也保存了时区A的用户提交请求时的GMT。而在另一个时区B的用户要浏览时区A的用户录入的信息。但时间要显示成时区B的本地时间。 对于上面的需求,最简单的方法是将服务端保存的GMT直接转换成时区B的本地时间。对于Web系统。这个工作可以交给JavaScript来完成。也就是说,服务端将服务端保