自从我升级了SDK/ADT到最新的Android 4.4更改以来,我就一直在我的应用程序中遇到这个错误。我不确定这是否与此相关,但这是自此错误开始以来唯一的重大更改。日志没有说出这是在我的应用程序中的哪个位置发生的。尽管有关于DrawerLayout的引用。而且它似乎在引用支持库v4,但我正在使用v13。
11-16 15:45:12.406: E/AndroidRuntime(1236): FATAL EXCEPTION: main
11-16 15:45:12.406: E/AndroidRuntime(1236): java.lang.RuntimeException: Canvas: trying to use a recycled bitmap android.graphics.Bitmap@41f1e4e8
11-16 15:45:12.406: E/AndroidRuntime(1236): at android.graphics.Canvas.throwIfRecycled(Canvas.java:1058)
11-16 15:45:12.406: E/AndroidRuntime(1236): at android.graphics.Canvas.drawBitmap(Canvas.java:1097)
11-16 15:45:12.406: E/AndroidRuntime(1236): at android.view.View.draw(View.java:13854)
11-16 15:45:12.406: E/AndroidRuntime(1236): at android.view.ViewGroup.drawChild(ViewGroup.java:3086)
11-16 15:45:12.406: E/AndroidRuntime(1236): at android.support.v4.widget.DrawerLayout.drawChild(DrawerLayout.java:804)
11-16 15:45:12.406: E/AndroidRuntime(1236): at android.view.ViewGroup.dispatchDraw(ViewGroup.java:2923)
11-16 15:45:12.406: E/AndroidRuntime(1236): at android.view.View.draw(View.java:13823)
11-16 15:45:12.406: E/AndroidRuntime(1236): at android.view.ViewGroup.drawChild(ViewGroup.java:3086)
11-16 15:45:12.406: E/AndroidRuntime(1236): at android.view.ViewGroup.dispatchDraw(ViewGroup.java:2923)
11-16 15:45:12.406: E/AndroidRuntime(1236): at android.view.View.draw(View.java:13823)
11-16 15:45:12.406: E/AndroidRuntime(1236): at android.view.ViewGroup.drawChild(ViewGroup.java:3086)
11-16 15:45:12.406: E/AndroidRuntime(1236): at android.view.ViewGroup.dispatchDraw(ViewGroup.java:2923)
11-16 15:45:12.406: E/AndroidRuntime(1236): at android.view.View.draw(View.java:13823)
11-16 15:45:12.406: E/AndroidRuntime(1236): at android.view.ViewGroup.drawChild(ViewGroup.java:3086)
11-16 15:45:12.406: E/AndroidRuntime(1236): at android.view.ViewGroup.dispatchDraw(ViewGroup.java:2923)
11-16 15:45:12.406: E/AndroidRuntime(1236): at android.view.View.draw(View.java:13947)
11-16 15:45:12.406: E/AndroidRuntime(1236): at android.widget.FrameLayout.draw(FrameLayout.java:467)
11-16 15:45:12.406: E/AndroidRuntime(1236): at com.android.internal.policy.impl.PhoneWindow$DecorView.draw(PhoneWindow.java:2224)
11-16 15:45:12.406: E/AndroidRuntime(1236): at android.view.ViewRootImpl.drawSoftware(ViewRootImpl.java:2482)
11-16 15:45:12.406: E/AndroidRuntime(1236): at android.view.ViewRootImpl.draw(ViewRootImpl.java:2395)
11-16 15:45:12.406: E/AndroidRuntime(1236): at android.view.ViewRootImpl.performDraw(ViewRootImpl.java:2239)
11-16 15:45:12.406: E/AndroidRuntime(1236): at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:1872)
11-16 15:45:12.406: E/AndroidRuntime(1236): at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:1004)
11-16 15:45:12.406: E/AndroidRuntime(1236): at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:5481)
11-16 15:45:12.406: E/AndroidRuntime(1236): at android.view.Choreographer$CallbackRecord.run(Choreographer.java:749)
11-16 15:45:12.406: E/AndroidRuntime(1236): at android.view.Choreographer.doCallbacks(Choreographer.java:562)
11-16 15:45:12.406: E/AndroidRuntime(1236): at android.view.Choreographer.doFrame(Choreographer.java:532)
11-16 15:45:12.406: E/AndroidRuntime(1236): at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:735)
11-16 15:45:12.406: E/AndroidRuntime(1236): at android.os.Handler.handleCallback(Handler.java:730)
11-16 15:45:12.406: E/AndroidRuntime(1236): at android.os.Handler.dispatchMessage(Handler.java:92)
11-16 15:45:12.406: E/AndroidRuntime(1236): at android.os.Looper.loop(Looper.java:137)
11-16 15:45:12.406: E/AndroidRuntime(1236): at android.app.ActivityThread.main(ActivityThread.java:5103)
11-16 15:45:12.406: E/AndroidRuntime(1236): at java.lang.reflect.Method.invokeNative(Native Method)
11-16 15:45:12.406: E/AndroidRuntime(1236): at java.lang.reflect.Method.invoke(Method.java:525)
11-16 15:45:12.406: E/AndroidRuntime(1236): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:737)
11-16 15:45:12.406: E/AndroidRuntime(1236): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
11-16 15:45:12.406: E/AndroidRuntime(1236): at dalvik.system.NativeStart.main(Native Method)
这是我唯一使用BitMap
的代码,在一个异步任务中;这与我的抽屉listView
标题中的图像有关:
static class GetProfileImageURL extends AsyncTask<String, String, Void> {
private Bitmap b;
private Context mContext;
public GetProfileImageURL(Context c) {
mContext = c;
}
@Override
protected Void doInBackground(String... params) {
URL url;
try {
String profImage = String.valueOf(Rateit.userId);
url = new URL(Rateit.PROFILE_PIC_URL + profImage + ".jpg");
b = BitmapFactory.decodeStream(url.openConnection()
.getInputStream());
} catch (MalformedURLException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
return null;
}
protected void onPostExecute(Void v) {
if (mContext != null) {
if (b != null) {
userIcon.setImageBitmap(ImageHelper.getRoundedCornerBitmap(
b, 50));
}
}
}
}
只有在 Activity
创建时才会调用此 AsyncTask
。
根据请求,这是 ImageHelper
类:
public class ImageHelper {
public static Bitmap getRoundedCornerBitmap(Bitmap bitmap, int pixels) {
Bitmap output = Bitmap.createBitmap(bitmap.getWidth(), bitmap
.getHeight(), Config.ARGB_8888);
Canvas canvas = new Canvas(output);
final int color = 0xff424242;
final Paint paint = new Paint();
final Rect rect = new Rect(0, 0, bitmap.getWidth(), bitmap.getHeight());
final RectF rectF = new RectF(rect);
final float roundPx = pixels;
final Rect topRightRect = new Rect(bitmap.getWidth()/2, 0, bitmap.getWidth(), bitmap.getHeight()/2);
final Rect bottomRect = new Rect(0, bitmap.getHeight()/2, bitmap.getWidth(), bitmap.getHeight());
paint.setAntiAlias(true);
canvas.drawARGB(0, 0, 0, 0);
paint.setColor(color);
canvas.drawRoundRect(rectF, roundPx, roundPx, paint);
// Fill in upper right corner
canvas.drawRect(topRightRect, paint);
// Fill in bottom corners
canvas.drawRect(bottomRect, paint);
paint.setXfermode(new PorterDuffXfermode(Mode.SRC_IN));
canvas.drawBitmap(bitmap, rect, rect, paint);
return output;
userIcon
在导航抽屉的listView
的header
中。看了我的代码,它只在Activity
创建时设置。 - TheLettuceMaster