A1: 在应用程序中,我加载了我的服务器的 4 base64字符串,并在应用程序中创建缩略图。 为它们创建视图并将它们添加到滚动布局。 到目前为止没有任何问题。
A1-A1-A1 ++ 如果我一次又一次地重复A1 - 在布局中添加5个图像和5个图像...... - 没问题。
A2: 仍然在应用程序内 - 与主要活动相反。 进入一项新的活动 - 图片选择活动。 从库中加载选择应用程序部分的图像。 创建图像预览。 到目前为止没有任何问题。
A2-A2-A2 ++ 如果我在此之后一次又一次地重复A2 - 没有问题。
A1-A2-A2-A2 ++ 如果我做A1并反复重复A2 - 没问题。
A1-A2-A1-A2 如果我从A1开始并执行A2并返回A1然后返回A2,则应该在创建预览图像时崩溃。
A1:
int count = 1;
while (count < 5)
{
try {
TelephonyManager mngr = (TelephonyManager)getSystemService(Context.TELEPHONY_SERVICE);
String imei = mngr.getDeviceId();
String image_count = String.valueOf(count);
String user_image = new GetUserImagesActivity().execute(imei,image_count).get();
byte[] decodedString = Base64.decode(user_image, Base64.DEFAULT);
Bitmap decodedByte = BitmapFactory.decodeByteArray(decodedString, 0, decodedString.length);
/*BitmapDrawable ob = new BitmapDrawable(decodedByte);*/
//ImageView Setup
ImageView imageView1 = new ImageView(this);
imageView1.setTag(count);
imageView1.setOnTouchListener(this);
//setting image resource
imageView1.setImageBitmap(decodedByte);
//setting image position
LinearLayout.LayoutParams params2 = new LinearLayout.LayoutParams(
LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT);
params2.gravity=Gravity.CENTER_HORIZONTAL;
params2.gravity=Gravity.CENTER_VERTICAL;
imageView1.setLayoutParams(params2);
imageView1.setAdjustViewBounds(true);
imageView1.setMaxHeight(240);
imageView1.setMaxWidth(180);
/*imageView.setMinimumHeight(180);
imageView.setMinimumWidth(240);*/
imageView1.setId(110011);
imageView1.setPadding(5, 0, 5, 0);
//adding view to layout
top_container.addView(imageView1);
count++;
//Tried this to solve the problem//
imageView1.setDrawingCacheEnabled(true);
imageView1.buildDrawingCache();
//Causes images to get black//
/*decodedByte.recycle();*/
} catch (InterruptedException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
Toast.makeText( getApplicationContext(), "problem 1" , Toast.LENGTH_LONG ).show();
} catch (ExecutionException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
Toast.makeText( getApplicationContext(), "problem 2" , Toast.LENGTH_LONG ).show();
}
}
A2: - 服务器的新图像(预览时失败)
cursor.moveToFirst();
int idx = cursor.getColumnIndex(ImageColumns.DATA);
String fileSrc = cursor.getString(idx);
bitmap = BitmapFactory.decodeFile(fileSrc);
// load // preview // image
bitmap = Bitmap.createScaledBitmap(bitmap, 480, 640, false);
// bmpDrawable = new BitmapDrawable(bitmapPreview);
img_logo.setImageBitmap(bitmap);
日志:
11-08 16:44:58.293: D/dalvikvm(22771): GC_BEFORE_OOM freed 44K, 34% free 22390K/33571K, paused 23ms
11-08 16:44:58.293: E/dalvikvm-heap(22771): Out of memory on a 36000016-byte allocation.
11-08 16:44:58.303: W/dalvikvm(22771): threadid=1: thread exiting with uncaught exception (group=0x40a9f210)
11-08 16:44:58.303: E/AndroidRuntime(22771): FATAL EXCEPTION: main
11-08 16:44:58.303: E/AndroidRuntime(22771): java.lang.OutOfMemoryError
11-08 16:44:58.303: E/AndroidRuntime(22771): at android.graphics.BitmapFactory.nativeDecodeStream(Native Method)
11-08 16:44:58.303: E/AndroidRuntime(22771): at android.graphics.BitmapFactory.decodeStream(BitmapFactory.java:499)
11-08 16:44:58.303: E/AndroidRuntime(22771): at android.graphics.BitmapFactory.decodeFile(BitmapFactory.java:305)
答案 0 :(得分:0)
使用WeakReference类,而不是使用位图类;
像 而不是这一行。
bitmap = BitmapFactory.decodeFile(fileSrc);
使用它。
WeakReference<Bitmap> bitmap=new WeakReference<Bitmap>(BitmapFactory.decodeFile(fileSrc));
WeakReference是android中的特殊类型,可以快速从内存中清除w.r.t其他对象。
答案 1 :(得分:0)
内存不足错误意味着:您没有足够的内存来加载更多位图。
可能的解决方案:
只保留最多照片的缓存。
和/或通过BitmapFactory
加载图片时减少inSampleSize答案 2 :(得分:0)
解决方案是:
BitmapFactory.Options options = new BitmapFactory.Options();
options.inDither = false;
options.inSampleSize = 6;
bitmap = BitmapFactory.decodeFile(fileSrc,options);
img_logo.setImageBitmap(bitmap);
我还添加了bao.close();和bitmap.recycle();这在制作base64图像字符串并关闭活动时:代码如下:
ByteArrayOutputStream bao = new ByteArrayOutputStream();
bitmap.compress(Bitmap.CompressFormat.JPEG, 30, bao);
byte[] ba = bao.toByteArray();
String text = Base64.encodeToString(ba,0);
try {
bao.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
bitmap.recycle();