android bitmap compress(图片压缩),2024年最新美团测试面试题

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Android开发知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以添加V获取:vip204888 (备注Android)
img

正文

/**

  • Created by a on 2016/3/31.

*/

public class ImageUtils {

/**

  • 从本地path中获取bitmap,压缩后保存小图片到本地

  • @param context

  • @param path 图片存放的路径

*/

public static String saveBitmap(Context context, String path) {

String compressdPicPath=“”;

// ★★★★★★★★★★★★★★重点★★★★★★★★★★★★★

/* //★如果不压缩直接从path获取bitmap,这个bitmap会很大,下面在压缩文件到100kb时,会循环很多次,

// ★而且会因为迟迟达不到100k,options一直在递减为负数,直接报错

//★ 即使原图不是太大,options不会递减为负数,也会循环多次,UI会卡顿,所以不推荐不经过压缩,直接获取到bitmap

Bitmap bitmap=BitmapFactory.decodeFile(path);*/

// ★★★★★★★★★★★★★★重点★★★★★★★★★★★★★

// 建议先将图片压缩到控件所显示的尺寸大小后,再压缩图片质量

// 首先得到手机屏幕的高宽,根据此来压缩图片,当然想要获取跟精确的控件显示的高宽(更加节约内存),可以使用getImageViewSize();

DisplayMetrics displayMetrics = context.getResources().getDisplayMetrics();

int width = displayMetrics.widthPixels; // 屏幕宽度(像素)

int height = displayMetrics.heightPixels; // 屏幕高度(像素)

// 获取按照屏幕高宽压缩比压缩后的bitmap

Bitmap bitmap = decodeSampledBitmapFromPath(path, width, height);

String oldName=path.substring(path.lastIndexOf(“/”), path.lastIndexOf(“.”));

String name=oldName+“_compress.jpg”;//★很奇怪oldName之前不能拼接字符串,只能拼接在后面,否则图片保存失败

String saveDir = Environment.getExternalStorageDirectory()

  • “/compress”;

File dir = new File(saveDir);

if (!dir.exists()) {

dir.mkdir();

}

// 保存入sdCard

File file = new File(saveDir, name);

ByteArrayOutputStream baos = new ByteArrayOutputStream();

/* options表示 如果不压缩是100,表示压缩率为0。如果是70,就表示压缩率是70,表示压缩30%; */

int options = 100;

bitmap.compress(Bitmap.CompressFormat.JPEG, 100, baos);

while (baos.toByteArray().length / 1024 > 500) {

// 循环判断如果压缩后图片是否大于500kb继续压缩

baos.reset();

options -= 10;

if (options < 11) {//为了防止图片大小一直达不到500kb,options一直在递减,当options<0时,下面的方法会报错

// 也就是说即使达不到500kb,也就压缩到10了

bitmap.compress(Bitmap.CompressFormat.JPEG, options, baos);

break;

}

// 这里压缩options%,把压缩后的数据存放到baos中

bitmap.compress(Bitmap.CompressFormat.JPEG, options, baos);

}

try {

FileOutputStream out = new FileOutputStream(file);

out.write(baos.toByteArray());

out.flush();

out.close();

compressdPicPath=file.getAbsolutePath();

} catch (IOException e) {

e.printStackTrace();

}

return compressdPicPath;

}

/**

  • 根据ImageView获取适当的压缩的宽和高

  • 尽可能得到ImageView的精确的宽高

  • @param imageView

  • @return

*/

public static ImageSize getImageViewSize(ImageView imageView) {

// 得到屏幕的宽度

DisplayMetrics displayMetrics = imageView.getContext().getResources().getDisplayMetrics();

ImageSize imageSize = new ImageSize();

ViewGroup.LayoutParams lp = imageView.getLayoutParams();

// ------------------------------------尽可能得到ImageView的精确的宽高-------------------------------------------------------------

// 得到imageView的实际宽度(为了压缩图片,这里一定要得到imageview的宽高)必须压缩!,否则OOM!!!!!!!!!!

int width = imageView.getWidth();

if (width <= 0) {//可能imageView刚new出来还没有添加到容器当中,width可能为0

width = lp.width;//获取imageView在layout中声明的宽度

}

if (width <= 0) {//如果imageView设置的是WRAP_CONTENT=-1或者MATHC_PARENT=-2,得到的width还是0

// TODO: 2016/3/19 此方法在API16以上才可以使用,为了兼容低版本,一会用反射获取,已解决

// width = imageView.getMaxWidth();//检查最大值(此方法在API16以上才可以使用,为了兼容低版本,一会用反射获取)

width = getImageViewFieldValue(imageView, “mMaxWidth”);//检查最大值(此方法在API16以上才可以使用,为了兼容低版本,一会用反射获取)

}

if (width <= 0) {//如果还是得不到width,就设置为屏幕的宽度

width = displayMetrics.widthPixels;

}

// ----------------------------------------

// 得到imageView的实际高度(为了压缩图片,这里一定要得到imageview的宽高)必须压缩!,否则OOM!!!!!!!!!!

int height = imageView.getHeight();

if (height <= 0) {//可能imageView刚new出来还没有添加到容器当中,width可能为0

height = lp.height;//获取imageView在layout中声明的高度

}

if (height <= 0) {//如果imageView设置的是WRAP_CONTENT=-1或者MATHC_PARENT=-2,得到的width还是0

// TODO: 2016/3/19 此方法在API16以上才可以使用,为了兼容低版本,一会用反射获取,已解决

// height = imageView.getMaxHeight();//检查最大值(此方法在API16以上才可以使用,为了兼容低版本,一会用反射获取)

height = getImageViewFieldValue(imageView, “mMaxHeight”);//检查最大值(此方法在API16以上才可以使用,为了兼容低版本,一会用反射获取)

}

if (height <= 0) {//如果还是得不到width,就设置为屏幕的高度

height = displayMetrics.heightPixels;

}

// --------------------------------尽可能得到ImageView的精确的宽高------------------------------------------------------------------

imageSize.width = width;

imageSize.height = height;

return imageSize;

}

/**

  • 通过反射获取imageview的某个属性值(imageView.getMaxWidth()这个方法在api16以上才可以用,所以使用反射得到这个width属性值)

  • @param object

  • @param fieldName

  • @return

*/

private static int getImageViewFieldValue(Object object, String fieldName) {

int value = 0;

try {

Field field = ImageView.class.getDeclaredField(fieldName);

field.setAccessible(true);

最后,面试前该准备哪些资源复习?

其实客户端开发的知识点就那么多,面试问来问去还是那么点东西。所以面试没有其他的诀窍,只看你对这些知识点准备的充分程度。so,出去面试时先看看自己复习到了哪个阶段就好。

这里再分享一下我面试期间的复习路线:(以下体系的复习资料是我从各路大佬收集整理好的)

《Android开发七大模块核心知识笔记》

面试字节两轮后被完虐,字节面试官给你的技术面试指南,请查收

面试字节两轮后被完虐,字节面试官给你的技术面试指南,请查收

《960全网最全Android开发笔记》

面试字节两轮后被完虐,字节面试官给你的技术面试指南,请查收

《379页Android开发面试宝典》

历时半年,我们整理了这份市面上最全面的安卓面试题解析大全
包含了腾讯、百度、小米、阿里、乐视、美团、58、猎豹、360、新浪、搜狐等一线互联网公司面试被问到的题目。熟悉本文中列出的知识点会大大增加通过前两轮技术面试的几率。

《507页Android开发相关源码解析》

只要是程序员,不管是Java还是Android,如果不去阅读源码,只看API文档,那就只是停留于皮毛,这对我们知识体系的建立和完备以及实战技术的提升都是不利的。

真正最能锻炼能力的便是直接去阅读源码,不仅限于阅读各大系统源码,还包括各种优秀的开源库。

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip204888 (备注Android)
img

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

知识体系的建立和完备以及实战技术的提升都是不利的。

真正最能锻炼能力的便是直接去阅读源码,不仅限于阅读各大系统源码,还包括各种优秀的开源库。

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip204888 (备注Android)
[外链图片转存中…(img-Zk5Bsxnf-1713642296573)]

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 21
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值