XUtils开源项目---BitmapUtils图片处理

2024-08-31 23:38

本文主要是介绍XUtils开源项目---BitmapUtils图片处理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

项目地址项目地址。。。。。。。

最近搜了XUtils进行学习,该开源库是目前git上比较活跃 功能比较完善的一个框架,是基于afinal开发的,比afinal稳定性提高了不少,该框架包含

DbUtils模块:android中的orm框架,一行代码就可以进行增删改查;

ViewUtils模块:android中的ioc框架,完全注解方式就可以进行UI,资源和事件绑定。

HttpUtils模块:支持同步,异步方式的请求;支持大文件上传,上传大文件不会oom;返回文本内容的请求(默认只启用了GET请求)支持缓存

BitmapUtils模块:加载bitmap的时候无需考虑bitmap加载过程中出现的oom和android容器快速滑动时候出现的图片错位等现象;支持加载网络图片和本地图片;内存管理使用lru算法,更好的管理bitmap内存;可配置线程加载线程数量,缓存大小,缓存路径,加载显示动画等...

我讲GitHub上的demo,下载下来,这篇就先摘图片处理案例,所以这篇博客就是针对BitmapUtils进行说明的,后期在整理其他的功能--诸如HttpUtils

项目git地址https://github.com/wyouflf/xUtils

使用xUtils快速开发框架需要有以下权限:

<uses-permission android:name="android.permission.INTERNET" /> <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" /> 

BitmapUtils 使用方法

BitmapUtils bitmapUtils = new BitmapUtils(this);// 加载网络图片
bitmapUtils.display(testImageView, "http://bbs.lidroid.com/static/image/common/logo.png");// 加载本地图片(路径以/开头, 绝对路径)
bitmapUtils.display(testImageView, "/sdcard/test.jpg");// 加载assets中的图片(路径以assets开头)
bitmapUtils.display(testImageView, "assets/img/wallpaper.jpg");// 使用ListView等容器展示图片时可通过PauseOnScrollListener控制滑动和快速滑动过程中时候暂停加载图片
listView.setOnScrollListener(new PauseOnScrollListener(bitmapUtils, false, true));
listView.setOnScrollListener(new PauseOnScrollListener(bitmapUtils, false, true, customListener));

开始理理项目代码

bitmap_fragment.xml首先看主页面布局--布局只有一个展示数据的ListView

<span style="font-size:14px;"><?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="fill_parent"android:layout_height="fill_parent"android:orientation="vertical" ><ListViewandroid:id="@+id/img_list"android:layout_width="fill_parent"android:layout_height="fill_parent" /></RelativeLayout></span>

为了方便简单,listView的每一条Item的布局代码如下--有一个进度条和需要加载的图片视图

bitmap_item.xml

<span style="font-size:14px;"><?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="match_parent"android:orientation="vertical" ><ImageViewandroid:id="@+id/img_item"android:layout_width="wrap_content"android:layout_height="wrap_content"android:minHeight="50dp"android:minWidth="50dp" /><ProgressBarandroid:id="@+id/img_pb"style="?android:attr/progressBarStyleHorizontal"android:layout_width="fill_parent"android:layout_height="2dp" /></LinearLayout></span>

BitmapHelp这个是一个单例模式,获取BitmapUtils对象,用来操作加载网络图片


package com.example.xutilsbitmap;import android.content.Context;
import com.lidroid.xutils.BitmapUtils;public class BitmapHelp {private BitmapHelp() {}private static BitmapUtils bitmapUtils;/*** BitmapUtils不是单例的 根据需要重载多个获取实例的方法* * @param appContext*            application context* @return*/public static BitmapUtils getBitmapUtils(Context appContext) {if (bitmapUtils == null) {bitmapUtils = new BitmapUtils(appContext);}return bitmapUtils;}
}

MainActivity先将代码整体贴出来,一会在逐步理理思路

package com.example.xutilsbitmap;import java.util.ArrayList;
import java.util.List;
import java.util.regex.Matcher;
import java.util.regex.Pattern;import android.app.Activity;
import android.content.Context;
import android.content.Intent;
import android.graphics.Bitmap;
import android.graphics.drawable.BitmapDrawable;
import android.graphics.drawable.ColorDrawable;
import android.graphics.drawable.Drawable;
import android.graphics.drawable.TransitionDrawable;
import android.os.Bundle;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.BaseAdapter;
import android.widget.ImageView;
import android.widget.ListView;
import android.widget.ProgressBar;import com.lidroid.xutils.BitmapUtils;
import com.lidroid.xutils.HttpUtils;
import com.lidroid.xutils.bitmap.BitmapCommonUtils;
import com.lidroid.xutils.bitmap.BitmapDisplayConfig;
import com.lidroid.xutils.bitmap.PauseOnScrollListener;
import com.lidroid.xutils.bitmap.callback.BitmapLoadFrom;
import com.lidroid.xutils.bitmap.callback.DefaultBitmapLoadCallBack;
import com.lidroid.xutils.exception.HttpException;
import com.lidroid.xutils.http.ResponseInfo;
import com.lidroid.xutils.http.callback.RequestCallBack;
import com.lidroid.xutils.http.client.HttpRequest;public class MainActivity extends Activity {/***  获取bitmapUtils单例*/public static BitmapUtils bitmapUtils;private String[] imgSites = { "http://image.baidu.com/","http://www.22mm.cc/", "http://www.moko.cc/","http://eladies.sina.com.cn/photo/", "http://www.youzi4.com/" };private ListView imageListView;private ImageListAdapter imageListAdapter;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.bitmap_fragment);// 获取listView控件imageListView = (ListView) findViewById(R.id.img_list);// 获取bitmapUtils单例bitmapUtils = BitmapHelp.getBitmapUtils(this);/*** 设置默认的图片展现、加载失败的图片展现*/bitmapUtils.configDefaultLoadingImage(R.drawable.ic_launcher);bitmapUtils.configDefaultLoadFailedImage(R.drawable.bitmap);bitmapUtils.configDefaultBitmapConfig(Bitmap.Config.RGB_565);// 设置最大宽高, 不设置时根据控件属性自适应.bitmapUtils.configDefaultBitmapMaxSize(BitmapCommonUtils.getScreenSize(this).scaleDown(3));/*** 滑动时加载图片,快速滑动时不加载图片 com.lidroid.xutils.bitmap.PauseOnScrollListener.* PauseOnScrollListener(TaskHandler taskHandler, boolean pauseOnScroll,* boolean pauseOnFling)*/imageListView.setOnScrollListener(new PauseOnScrollListener(bitmapUtils, false, true));imageListAdapter = new ImageListAdapter(this);imageListView.setAdapter(imageListAdapter);// 加载url请求返回的图片连接给listview// 这里只是简单的示例,并非最佳实践,图片较多时,最好上拉加载更多...for (String url : imgSites) {loadImgList(url);}imageListView.setOnItemClickListener(new OnItemClickListener() {@Overridepublic void onItemClick(AdapterView<?> parent, View view,int position, long id) {Intent intent = new Intent(MainActivity.this, ImageActivity.class);intent.putExtra("url",imageListAdapter.getItem(position).toString());startActivity(intent);}});}/*** 进行网络加载 (HttpMethod method, String url, RequestCallBack<String> callBack)* */private void loadImgList(String url) {new HttpUtils().send(HttpRequest.HttpMethod.GET, url,new RequestCallBack<String>() {@Overridepublic void onSuccess(ResponseInfo<String> responseInfo) {// 得到的是已打算html内容Log.e("TAG", "" + responseInfo.result);// 通过正则来获取图片的url地址,并且添加到adapter中imageListAdapter.addSrc(getImgSrcList(responseInfo.result));// 通知listview更新数据imageListAdapter.notifyDataSetChanged();}@Overridepublic void onFailure(HttpException error, String msg) {Log.e("TAG", "加载失败。。。");}});}/*** 得到网页中图片的地址 http://image.baidu.com/*/public static List<String> getImgSrcList(String htmlStr) {List<String> pics = new ArrayList<String>();String regEx_img = "<img.*?src=\"http://(.*?).jpg\""; // 图片链接地址Pattern p_image = Pattern.compile(regEx_img, Pattern.CASE_INSENSITIVE);Matcher m_image = p_image.matcher(htmlStr);while (m_image.find()) {String src = m_image.group(1);if (src.length() < 100) {pics.add("http://" + src + ".jpg");}}return pics;}private class ImageListAdapter extends BaseAdapter {private Context mContext;private final LayoutInflater mInflater;private ArrayList<String> imgSrcList;public ImageListAdapter(Context context) {super();this.mContext = context;mInflater = LayoutInflater.from(context);imgSrcList = new ArrayList<String>();}/*** 将获取的url地址,添加进来*/public void addSrc(List<String> imgSrcList) {this.imgSrcList.addAll(imgSrcList);}@Overridepublic int getCount() {return imgSrcList.size();}@Overridepublic Object getItem(int position) {return imgSrcList.get(position);}@Overridepublic long getItemId(int i) {return i;}@Overridepublic View getView(final int position, View view, ViewGroup parent) {ImageItemHolder holder = null;if (view == null) {view = mInflater.inflate(R.layout.bitmap_item, null);holder = new ImageItemHolder();holder.imgItem = (ImageView) view.findViewById(R.id.img_item);holder.imgPb = (ProgressBar) view.findViewById(R.id.img_pb);view.setTag(holder);} else {holder = (ImageItemHolder) view.getTag();}// 初始值进度为0holder.imgPb.setProgress(0);/*** display参数 (ImageView container, String uri,* BitmapLoadCallBack<ImageView> callBack)*/bitmapUtils.display(holder.imgItem, imgSrcList.get(position),new CustomBitmapLoadCallBack(holder));return view;}}private class ImageItemHolder {private ImageView imgItem;private ProgressBar imgPb;}/*** 接口* * @author Administrator* */public class CustomBitmapLoadCallBack extendsDefaultBitmapLoadCallBack<ImageView> {private final ImageItemHolder holder;public CustomBitmapLoadCallBack(ImageItemHolder holder) {this.holder = holder;}/*** 加载过程中,进行进度展示*/@Overridepublic void onLoading(ImageView container, String uri,BitmapDisplayConfig config, long total, long current) {// 百分比展示进度this.holder.imgPb.setProgress((int) (current * 100 / total));}/*** 加载图片完毕*/@Overridepublic void onLoadCompleted(ImageView imageview, String uri,Bitmap bitmap, BitmapDisplayConfig config, BitmapLoadFrom from) {// 设置图片到listviewfadeInDisplay(imageview, bitmap);// 加载完毕,修改进度值this.holder.imgPb.setProgress(100);}}/*** 动画效果--渐变效果展示* * @param imageView* @param bitmap*/private void fadeInDisplay(ImageView imageView, Bitmap bitmap) {final TransitionDrawable transitionDrawable = new TransitionDrawable(new Drawable[] { TRANSPARENT_DRAWABLE,new BitmapDrawable(imageView.getResources(), bitmap) });imageView.setImageDrawable(transitionDrawable);transitionDrawable.startTransition(500);}private static final ColorDrawable TRANSPARENT_DRAWABLE = new ColorDrawable(android.R.color.transparent);}

点击item进行跳转

image.xml

<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:orientation="vertical"android:layout_width="match_parent"android:layout_height="match_parent"><ImageView android:id="@+id/big_img"android:layout_width="wrap_content"android:layout_height="fill_parent"android:layout_gravity="center"/></LinearLayout>

代码如下

ImageActivity

package com.example.xutilsbitmap;import android.app.Activity;
import android.graphics.Bitmap;
import android.os.Bundle;
import android.widget.ImageView;
import android.widget.Toast;
import com.lidroid.xutils.BitmapUtils;
import com.lidroid.xutils.bitmap.BitmapCommonUtils;
import com.lidroid.xutils.bitmap.BitmapDisplayConfig;
import com.lidroid.xutils.bitmap.callback.BitmapLoadCallBack;
import com.lidroid.xutils.bitmap.callback.BitmapLoadFrom;
import com.lidroid.xutils.bitmap.callback.DefaultBitmapLoadCallBack;/*** Author: wyouflf* Date: 13-10-9* Time: 下午5:26*/
public class ImageActivity extends Activity {private ImageView bigImage;private BitmapUtils bitmapUtils;private BitmapDisplayConfig bigPicDisplayConfig;public void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.image);bigImage = (ImageView) findViewById(R.id.big_img);String imgUrl = getIntent().getStringExtra("url");if (bitmapUtils == null) {bitmapUtils = BitmapHelp.getBitmapUtils(this);}bigPicDisplayConfig = new BitmapDisplayConfig();// 显示原始图片,不压缩, 尽量不要使用, 图片太大时容易OOM。//bigPicDisplayConfig.setShowOriginal(true);bigPicDisplayConfig.setBitmapConfig(Bitmap.Config.RGB_565);bigPicDisplayConfig.setBitmapMaxSize(BitmapCommonUtils.getScreenSize(this));BitmapLoadCallBack<ImageView> callback = new DefaultBitmapLoadCallBack<ImageView>() {@Overridepublic void onLoadStarted(ImageView container, String uri, BitmapDisplayConfig config) {super.onLoadStarted(container, uri, config);Toast.makeText(getApplicationContext(), uri, 300).show();}@Overridepublic void onLoadCompleted(ImageView container, String uri, Bitmap bitmap, BitmapDisplayConfig config, BitmapLoadFrom from) {super.onLoadCompleted(container, uri, bitmap, config, from);Toast.makeText(getApplicationContext(), bitmap.getWidth() + "*" + bitmap.getHeight(), 300).show();}};bitmapUtils.display(bigImage, imgUrl, bigPicDisplayConfig, callback);}
}

——————————————————————分割线是代码说明————————————————————

如下的代码是设置加载图片之前默认的显示图片,加载失败的图片,以及图片的质量参数

/*** 设置默认的图片展现、加载失败的图片展现*/bitmapUtils.configDefaultLoadingImage(R.drawable.ic_launcher);bitmapUtils.configDefaultLoadFailedImage(R.drawable.bitmap);bitmapUtils.configDefaultBitmapConfig(Bitmap.Config.RGB_565);

如下的代码是通过new HttpUtils().send(method, url, callBack);进行下载url地址的json或者xml内容,一旦请求成功,就进行onSuccess回调操作

	/*** 进行网络加载 (HttpMethod method, String url, RequestCallBack<String> callBack)*/private void loadImgList(String url) {new HttpUtils().send(HttpRequest.HttpMethod.GET, url,new RequestCallBack<String>() {@Overridepublic void onSuccess(ResponseInfo<String> responseInfo) {// 得到的是已打算html内容Log.e("TAG", "" + responseInfo.result);// 通过正则来获取图片的url地址,并且添加到adapter中imageListAdapter.addSrc(getImgSrcList(responseInfo.result));// 通知listview更新数据imageListAdapter.notifyDataSetChanged();}@Overridepublic void onFailure(HttpException error, String msg) {Log.e("TAG", "加载失败。。。");}});}

请求完毕,json或则xml内容后,就利用下面的方法,获取图片地址,并创建集合对象--利用了正则表达式

	/*** 得到网页中图片的地址 http://image.baidu.com/*/public static List<String> getImgSrcList(String htmlStr) {List<String> pics = new ArrayList<String>();String regEx_img = "<img.*?src=\"http://(.*?).jpg\""; // 图片链接地址Pattern p_image = Pattern.compile(regEx_img, Pattern.CASE_INSENSITIVE);Matcher m_image = p_image.matcher(htmlStr);while (m_image.find()) {String src = m_image.group(1);if (src.length() < 100) {pics.add("http://" + src + ".jpg");}}return pics;}

在看adapter里面的内容,当获取图片的url集合后,进行添加

imageListAdapter .addSrc(getImgSrcList(responseInfo.result));

	/*** 将获取的url地址,添加进来*/public void addSrc(List<String> imgSrcList) {this.imgSrcList.addAll(imgSrcList);}

进行初始化listView的数据

在adapter里面关键的地方是

/*** display参数 (ImageView container, String uri,* BitmapLoadCallBack<ImageView> callBack)*/bitmapUtils.display(holder.imgItem, imgSrcList.get(position),new CustomBitmapLoadCallBack(holder));

上面的最后一个参数如下,是真正获取图片进行填充ListView界面操作的,里面的onLoading是一些加载过程中的友好提示,比如进度条,onLoadCompleted这个是加载完毕后,进行的操作


	/*** 接口* * @author Administrator* */public class CustomBitmapLoadCallBack extendsDefaultBitmapLoadCallBack<ImageView> {private final ImageItemHolder holder;public CustomBitmapLoadCallBack(ImageItemHolder holder) {this.holder = holder;}/*** 加载过程中,进行进度展示*/@Overridepublic void onLoading(ImageView container, String uri,BitmapDisplayConfig config, long total, long current) {// 百分比展示进度this.holder.imgPb.setProgress((int) (current * 100 / total));}/*** 加载图片完毕*/@Overridepublic void onLoadCompleted(ImageView imageview, String uri,Bitmap bitmap, BitmapDisplayConfig config, BitmapLoadFrom from) {// 设置图片到listviewfadeInDisplay(imageview, bitmap);// 加载完毕,修改进度值this.holder.imgPb.setProgress(100);}}

onLoadCompleted这个是加载完毕后,进行的操作是fadeInDisplay(imageview, bitmap);

这个是用的一个渐变的效果代码如下

/*** 动画效果--渐变效果展示* * @param imageView* @param bitmap*/private void fadeInDisplay(ImageView imageView, Bitmap bitmap) {final TransitionDrawable transitionDrawable = new TransitionDrawable(new Drawable[] { TRANSPARENT_DRAWABLE,new BitmapDrawable(imageView.getResources(), bitmap) });imageView.setImageDrawable(transitionDrawable);transitionDrawable.startTransition(500);}private static final ColorDrawable TRANSPARENT_DRAWABLE = new ColorDrawable(android.R.color.transparent);

点击每一条进行跳转的代码大同小异。。。。





这篇关于XUtils开源项目---BitmapUtils图片处理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1125325

相关文章

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

无人叉车3d激光slam多房间建图定位异常处理方案-墙体画线地图切分方案

墙体画线地图切分方案 针对问题:墙体两侧特征混淆误匹配,导致建图和定位偏差,表现为过门跳变、外月台走歪等 ·解决思路:预期的根治方案IGICP需要较长时间完成上线,先使用切分地图的工程化方案,即墙体两侧切分为不同地图,在某一侧只使用该侧地图进行定位 方案思路 切分原理:切分地图基于关键帧位置,而非点云。 理论基础:光照是直线的,一帧点云必定只能照射到墙的一侧,无法同时照到两侧实践考虑:关

如何用Docker运行Django项目

本章教程,介绍如何用Docker创建一个Django,并运行能够访问。 一、拉取镜像 这里我们使用python3.11版本的docker镜像 docker pull python:3.11 二、运行容器 这里我们将容器内部的8080端口,映射到宿主机的80端口上。 docker run -itd --name python311 -p

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

阿里开源语音识别SenseVoiceWindows环境部署

SenseVoice介绍 SenseVoice 专注于高精度多语言语音识别、情感辨识和音频事件检测多语言识别: 采用超过 40 万小时数据训练,支持超过 50 种语言,识别效果上优于 Whisper 模型。富文本识别:具备优秀的情感识别,能够在测试数据上达到和超过目前最佳情感识别模型的效果。支持声音事件检测能力,支持音乐、掌声、笑声、哭声、咳嗽、喷嚏等多种常见人机交互事件进行检测。高效推

在cscode中通过maven创建java项目

在cscode中创建java项目 可以通过博客完成maven的导入 建立maven项目 使用快捷键 Ctrl + Shift + P 建立一个 Maven 项目 1 Ctrl + Shift + P 打开输入框2 输入 "> java create"3 选择 maven4 选择 No Archetype5 输入 域名6 输入项目名称7 建立一个文件目录存放项目,文件名一般为项目名8 确定

【生成模型系列(初级)】嵌入(Embedding)方程——自然语言处理的数学灵魂【通俗理解】

【通俗理解】嵌入(Embedding)方程——自然语言处理的数学灵魂 关键词提炼 #嵌入方程 #自然语言处理 #词向量 #机器学习 #神经网络 #向量空间模型 #Siri #Google翻译 #AlexNet 第一节:嵌入方程的类比与核心概念【尽可能通俗】 嵌入方程可以被看作是自然语言处理中的“翻译机”,它将文本中的单词或短语转换成计算机能够理解的数学形式,即向量。 正如翻译机将一种语言

金融业开源技术 术语

金融业开源技术  术语 1  范围 本文件界定了金融业开源技术的常用术语。 本文件适用于金融业中涉及开源技术的相关标准及规范性文件制定和信息沟通等活动。

安全管理体系化的智慧油站开源了。

AI视频监控平台简介 AI视频监控平台是一款功能强大且简单易用的实时算法视频监控系统。它的愿景是最底层打通各大芯片厂商相互间的壁垒,省去繁琐重复的适配流程,实现芯片、算法、应用的全流程组合,从而大大减少企业级应用约95%的开发成本。用户只需在界面上进行简单的操作,就可以实现全视频的接入及布控。摄像头管理模块用于多种终端设备、智能设备的接入及管理。平台支持包括摄像头等终端感知设备接入,为整个平台提

Vue3项目开发——新闻发布管理系统(六)

文章目录 八、首页设计开发1、页面设计2、登录访问拦截实现3、用户基本信息显示①封装用户基本信息获取接口②用户基本信息存储③用户基本信息调用④用户基本信息动态渲染 4、退出功能实现①注册点击事件②添加退出功能③数据清理 5、代码下载 八、首页设计开发 登录成功后,系统就进入了首页。接下来,也就进行首页的开发了。 1、页面设计 系统页面主要分为三部分,左侧为系统的菜单栏,右侧