- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在使用 volley 图像加载器从服务器加载图像到我的项目中。但在某些情况下,我会收到以下错误和应用程序崩溃。
java.util.ConcurrentModificationException
at java.util.LinkedList$LinkIterator.next(LinkedList.java:124)
at com.android.volley.toolbox.ImageLoader$4.run(ImageLoader.java:440)
at android.os.Handler.handleCallback(Handler.java:739)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:135)
at android.app.ActivityThread.main(ActivityThread.java:5343)
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:905)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:700)
我找不到错误的原因和解决方法。请帮助我。
全局.java
import android.app.Application;
import android.text.TextUtils;
import com.android.volley.Request;
import com.android.volley.RequestQueue;
import com.android.volley.toolbox.ImageLoader;
import com.android.volley.toolbox.Volley;
import com.example.volley.LruBitmapCache;
import java.util.HashMap;
public class Global extends Application{
public static final String TAG = Global.class.getSimpleName();
private RequestQueue mRequestQueue;
private ImageLoader mImageLoader;
private static Global mInstance;
@Override
public void onCreate() {
super.onCreate();
mInstance = this;
}
public static synchronized Global getInstance() {
return mInstance;
}
public RequestQueue getRequestQueue() {
if (mRequestQueue == null) {
mRequestQueue = Volley.newRequestQueue(getApplicationContext());
}
return mRequestQueue;
}
public ImageLoader getImageLoader() {
getRequestQueue();
if (mImageLoader == null) {
mImageLoader = new ImageLoader(this.mRequestQueue,new LruBitmapCache());
}
return this.mImageLoader;
}
public <T> void addToRequestQueue(Request<T> req, String tag) {
req.setTag(TextUtils.isEmpty(tag) ? TAG : tag);
getRequestQueue().add(req);
}
public void cancelPendingRequests(Object tag) {
if (mRequestQueue != null) {
mRequestQueue.cancelAll(tag);
}
}
}
LruBitmapCache.java
import com.android.volley.toolbox.ImageLoader.ImageCache;
import android.graphics.Bitmap;
import android.support.v4.util.LruCache;
public class LruBitmapCache extends LruCache<String, Bitmap> implements ImageCache {
public static int getDefaultLruCacheSize() {
final int maxMemory = (int) (Runtime.getRuntime().maxMemory() / 1024);
final int cacheSize = maxMemory / 8;
return cacheSize;
}
public LruBitmapCache() {
this(getDefaultLruCacheSize());
}
public LruBitmapCache(int sizeInKiloBytes) {
super(sizeInKiloBytes);
}
@Override
protected int sizeOf(String key, Bitmap value) {
return value.getRowBytes() * value.getHeight() / 1024;
}
@Override
public Bitmap getBitmap(String url) {
return get(url);
}
@Override
public void putBitmap(String url, Bitmap bitmap) {
put(url, bitmap);
}
}
将图像加载到 WebView 中的代码
ImageLoader myLoader = Global.getInstance().getImageLoader();
networkImageView.setImageUrl(thumbnailURL, myLoader);
myLoader.get(thumbnailURL, new ImageLoader.ImageListener() {
@Override
public void onErrorResponse(VolleyError error) {
//Set Error image
}
@Override
public void onResponse(ImageLoader.ImageContainer response, boolean isImmediate) {
if (response.getBitmap() != null) {
//Set BitMap
}
else{
//Set Loading image
}
}
});
My Costume网络查看图片查看监听
public class NetworkImageViewListener {
private final String TAG_THUMBNAIL_ERROR = "THUMBNAIL_ERROR";
private final String TAG_THUMBNAIL_RECEIVED = "THUMBNAIL_RECEIVED";
private String TAG = getClass().getSimpleName();
private boolean original_image_loaded = false;
public void loadImage(final Context context,final String url,final NetworkImageView networkImageView, final int approx_width, final int approx_height,final boolean thumbnail, final ProgressBar progressBar, final boolean is_Store){
networkImageView.setAdjustViewBounds(true);
final int picture_not_found = R.drawable.ic_profile_picture_not_found;
final int picture_not_loaded = R.drawable.ic_profile_picture_not_loaded;
if (url != null && !url.equals("null")&& !url.equals("NULL")&& !url.equals("")) {
final String originalURL = getImageUrl(url, approx_width, approx_height);
final Bitmap cacheImage = getCacheImage(context, originalURL);
if (cacheImage==null) {
if(progressBar!=null){
progressBar.setVisibility(View.VISIBLE);
}
if (thumbnail) {
final String thumbnailURL = getImageThumbnailUrl(url, approx_width, approx_height);
ImageLoader thumbnailLoader = Global.getInstance().getImageLoader();
networkImageView.setImageUrl(thumbnailURL, thumbnailLoader);
thumbnailLoader.get(thumbnailURL, new ImageLoader.ImageListener() {
@Override
public void onErrorResponse(VolleyError error) {
if(progressBar==null){
networkImageView.setImageResource(picture_not_found);
}
networkImageView.setTag(TAG_THUMBNAIL_ERROR);
load_Original(context, originalURL, networkImageView, progressBar, is_Store, picture_not_loaded);
}
@Override
public void onResponse(ImageLoader.ImageContainer response, boolean isImmediate) {
if (response.getBitmap() != null) {
networkImageView.setImageBitmap(response.getBitmap());
networkImageView.setTag(TAG_THUMBNAIL_RECEIVED);
load_Original(context, originalURL, networkImageView, progressBar, is_Store, picture_not_loaded);
} else if (progressBar==null) {
networkImageView.setImageResource(picture_not_found);
}
}
});
}
else{
load_Original(context,originalURL,networkImageView,progressBar,is_Store,picture_not_loaded);
}
} else {
networkImageView.setImageBitmap(cacheImage);
}
} else {
networkImageView.setImageResource(picture_not_found);
}
}
private void load_Original(final Context context,final String originalURL,final NetworkImageView networkImageView, final ProgressBar progressBar, final boolean is_Store,final int picture_not_loaded){
final Drawable temp = networkImageView.getDrawable();
final String imageviewTag = (String) networkImageView.getTag();
ImageLoader imageLoader = Global.getInstance().getImageLoader();
networkImageView.setImageUrl(originalURL, imageLoader);
imageLoader.get(originalURL, new ImageLoader.ImageListener() {
@Override
public void onErrorResponse(VolleyError error) {
if (progressBar != null) {
progressBar.setVisibility(View.GONE);
}
if (temp != null && imageviewTag != null && !imageviewTag.equals(TAG_THUMBNAIL_ERROR)) {
networkImageView.setImageDrawable(temp);
} else if (temp != null && imageviewTag != null && imageviewTag.equals(TAG_THUMBNAIL_RECEIVED)) {
networkImageView.setImageDrawable(temp);
} else {
networkImageView.setImageResource(picture_not_loaded);
}
}
@Override
public void onResponse(ImageLoader.ImageContainer response, boolean shouldAnimate) {
if (response.getBitmap() != null) {
if (progressBar != null) {
progressBar.setVisibility(View.GONE);
}
networkImageView.setImageBitmap(response.getBitmap());
if (is_Store) {
setCacheImage(context, originalURL, response.getBitmap());
}
} else {
networkImageView.setImageDrawable(temp);
}
}
});
}
private static String getImageUrl(String url, int aprox_width, int aprox_height){
int index = url.lastIndexOf('/');
String path = url.substring(0, index);
String file_name = url.substring(index + 1);
String result = path+"/"+aprox_width+"/"+aprox_height+"/"+file_name;
return result;
}
private static String getImageThumbnailUrl(String url, int approx_width, int aprox_height){
int index = url.lastIndexOf('/');
String path = url.substring(0, index);
String file_name = url.substring(index + 1);
String result = path+"/"+approx_width+"/"+aprox_height+"/tbnil"+"/"+file_name;
return result;
}
private String profile_picture_folder_name = "PP";
private void setCacheImage(Context context, String url, Bitmap bitmap){
try {
if (!getCacheDirectory(context).equals("")) {
String filename = getFileName(url);
File folder = new File(getCacheDirectory(context)+"/"+profile_picture_folder_name+"/");
if (!folder.exists()) {
folder.mkdir();
}
if (folder.exists()) {
File dest = new File(folder, filename);
FileOutputStream out = new FileOutputStream(dest);
bitmap.compress(Bitmap.CompressFormat.JPEG, 40, out);
out.flush();
out.close();
}
}
} catch (Exception e) {
Log.developer(TAG,e.getMessage());
}
}
private Bitmap getCacheImage(Context context,String url){
try {
if (!getCacheDirectory(context).equals("")) {
String filename = getFileName(url);
File folder = new File(getCacheDirectory(context)+"/"+profile_picture_folder_name+"/");
if (folder.exists()) {
FileInputStream fis = null;
File imageFile = new File(folder, filename);
if (imageFile.exists()) {
fis = new FileInputStream(imageFile);
return BitmapFactory.decodeStream(fis);
}
}
}
} catch (FileNotFoundException e) {
Log.developer(TAG, e.getMessage());
}
return null;
}
private String getCacheDirectory(Context context){
String cachePath="";
if (Environment.MEDIA_MOUNTED.equals(Environment.getExternalStorageState()) || !Environment.isExternalStorageRemovable()) {
if (context.getExternalCacheDir() != null && context.getExternalCacheDir().exists()) {
cachePath = context.getExternalCacheDir().getPath(); // most likely your null value
}
else if (context.getCacheDir() != null && context.getCacheDir().exists()) {
cachePath = context.getCacheDir().getPath();
}
} else {
if (context.getCacheDir() != null && context.getCacheDir().exists()) {
cachePath = context.getCacheDir().getPath();
}
}
return cachePath;
}
public String getFileName(String urlStr) {
return urlStr.substring(urlStr.lastIndexOf('/') + 1, urlStr.length());
}
}
最佳答案
您必须实现两个 ImageLoader,一个用于缩略图,另一个用于全分辨率图像。修改您的 RequestQueue
单例,如下所示:
//..
private ImageLoader mImageLoader;
private ImageLoader mThumbLoader;
//...
// Then in constructor
mThumbLoader = new ImageLoader(mRequestQueue, new ImageLoader.ImageCache() { ... });
mImageLoader = new ImageLoader(mRequestQueue, new ImageLoader.ImageCache() { ... });
// And then you build two getters
protected ImageLoader getImageLoader() {
return mImageLoader;
}
protected ImageLoader getThumbLoader() {
return mThumbLoader;
}
如果您为缩略图调用 mThumbLoader
并为全分辨率图像调用 mImageLoader
,它将正常工作。
关于android - Volley 图像加载器并发修改异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35479128/
我正在尝试学习 Knockout 并尝试创建一个照片 uploader 。我已成功将一些图像存储在数组中。现在我想回帖。在我的 knockout 码(Javascript)中,我这样做: 我在 Jav
我正在使用 php 编写脚本。我的典型问题是如何在 mysql 中添加一个有很多替代文本和图像的问题。想象一下有机化学中具有苯结构的描述。 最有效的方法是什么?据我所知,如果我有一个图像,我可以在数据
我在两个图像之间有一个按钮,我想将按钮居中到图像高度。有人可以帮帮我吗? Entrar
下面的代码示例可以在这里查看 - http://dev.touch-akl.com/celebtrations/ 我一直在尝试做的是在 Canvas 上绘制 2 个图像(发光,然后耀斑。这些图像的链接
请检查此https://jsfiddle.net/rhbwpn19/4/ 图像预览对于第一篇帖子工作正常,但对于其他帖子则不然。 我应该在这里改变什么? function readURL(input)
我对 Canvas 有疑问。我可以用单个图像绘制 Canvas ,但我不能用单独的图像绘制每个 Canvas 。- 如果数据只有一个图像,它工作正常,但数据有多个图像,它不工作你能帮帮我吗? va
我的问题很简单。如何获取 UIImage 的扩展类型?我只能将图像作为 UIImage 而不是它的名称。图像可以是静态的,也可以从手机图库甚至文件路径中获取。如果有人可以为此提供一点帮助,将不胜感激。
我有一个包含 67 个独立路径的 SVG 图像。 是否有任何库/教程可以为每个路径创建单独的光栅图像(例如 PNG),并可能根据路径 ID 命名它们? 最佳答案 谢谢大家。我最终使用了两个答案的组合。
我想将鼠标悬停在一张图片(音乐专辑)上,然后播放一张唱片,所以我希望它向右移动并旋转一点,当它悬停时我希望它恢复正常动画片。它已经可以向右移动,但我无法让它随之旋转。我喜欢让它尽可能简单,因为我不是编
Retina iOS 设备不显示@2X 图像,它显示 1X 图像。 我正在使用 Xcode 4.2.1 Build 4D502,该应用程序的目标是 iOS 5。 我创建了一个测试应用(主/细节)并添加
我正在尝试从头开始以 Angular 实现图像 slider ,并尝试复制 w3school基于图像 slider 。 下面我尝试用 Angular 实现,谁能指导我如何使用 Angular 实现?
我正在尝试获取图像的图像数据,其中 w= 图像宽度,h = 图像高度 for (int i = x; i imageData[pos]>0) //Taking data (here is the pr
我的网页最初通过在 javascript 中动态创建图像填充了大约 1000 个缩略图。由于权限问题,我迁移到 suPHP。现在不用标准 标签本身 我正在通过这个 php 脚本进行检索 $file
我正在尝试将 python opencv 图像转换为 QPixmap。 我按照指示显示Page Link我的代码附在下面 img = cv2.imread('test.png')[:,:,::1]/2
我试图在这个 Repository 中找出语义分割数据集的 NYU-v2 . 我很难理解图像标签是如何存储的。 例如,给定以下图像: 对应的标签图片为: 现在,如果我在 OpenCV 中打开标签图像,
import java.util.Random; class svg{ public static void main(String[] args){ String f="\"
我有一张 8x8 的图片。 (位图 - 可以更改) 我想做的是能够绘制一个形状,给定一个 Path 和 Paint 对象到我的 SurfaceView 上。 目前我所能做的就是用纯色填充形状。我怎样才
要在页面上显示图像,你需要使用源属性(src)。src 指 source 。源属性的值是图像的 URL 地址。 定义图像的语法是: 在浏览器无法载入图像时,替换文本属性告诉读者她们失去的信息。此
**MMEditing是基于PyTorch的图像&视频编辑开源工具箱,支持图像和视频超分辨率(super-resolution)、图像修复(inpainting)、图像抠图(matting)、
我正在尝试通过资源文件将图像插入到我的程序中,如下所示: green.png other files 当我尝试使用 QImage 或 QPixm
我是一名优秀的程序员,十分优秀!