116

Can anybody tell me the reason for failed binder transaction error? I can see this error message in logcat. I am getting this error while trying to put an bitmap dynamically in a widget...

Ciro Santilli OurBigBook.com
  • 347,512
  • 102
  • 1,199
  • 985
Eby
  • 2,769
  • 4
  • 23
  • 30

6 Answers6

92

This is caused because all the changes to the RemoteViews are serialised (e.g. setInt and setImageViewBitmap ). The bitmaps are also serialised into an internal bundle. Unfortunately this bundle has a very small size limit.

You can solve it by scaling down the image size this way:

 public static Bitmap scaleDownBitmap(Bitmap photo, int newHeight, Context context) {

 final float densityMultiplier = context.getResources().getDisplayMetrics().density;        

 int h= (int) (newHeight*densityMultiplier);
 int w= (int) (h * photo.getWidth()/((double) photo.getHeight()));

 photo=Bitmap.createScaledBitmap(photo, w, h, true);

 return photo;
 }

Choose newHeight to be small enough (~100 for every square it should take on the screen) and use it for your widget, and your problem will be solved :)

GalDude33
  • 7,071
  • 1
  • 28
  • 38
  • 1
    What I don't quite understand is what happens here exactly. I'm using a ViewPager with a fairly large dataset, yet it does remember everything between pages despite the binder error spam. Does the bundle get written to local storage and then prefetched or what? Can I possibly lose data if I add more pages? – G_V Dec 03 '14 at 08:18
  • 7
    But this will reduce the image quality – John Joe Dec 31 '15 at 04:16
65

You can compress the bitmap as an byte's array and then uncompress it in another activity, like this.

Compress!!

        ByteArrayOutputStream stream = new ByteArrayOutputStream();
        bmp.compress(Bitmap.CompressFormat.PNG, 100, stream);
        byte[] bytes = stream.toByteArray(); 
        setresult.putExtra("BMP",bytes);

Uncompress!!

        byte[] bytes = data.getByteArrayExtra("BMP");
        Bitmap bmp = BitmapFactory.decodeByteArray(bytes, 0, bytes.length);
Nicolás Loaiza
  • 1,015
  • 11
  • 11
38

The Binder transaction buffer has a limited fixed size, currently 1Mb, which is shared by all transactions in progress for the process. Consequently this exception can be thrown when there are many transactions in progress even when most of the individual transactions are of moderate size.

refer this link

dharmendra
  • 7,835
  • 5
  • 38
  • 71
13

See my answer in this thread.

intent.putExtra("Some string",very_large_obj_for_binder_buffer);

You are exceeding the binder transaction buffer by transferring large element(s) from one activity to another activity.

Community
  • 1
  • 1
Balaji Dubey
  • 446
  • 5
  • 10
8

I have solved this issue by storing images on internal storage and then using .setImageURI() rather than .setBitmap().

MartinC
  • 546
  • 11
  • 26
  • 1
    and don't pass the images through Parcelable from screen to screen or so, I guess that's worst in this case – MartinC Jun 05 '13 at 11:33
3

The right approach is to use setImageViewUri() (slower) or the setImageViewBitmap() and recreating RemoteViews every time you update the notification.

Baris Demiray
  • 1,539
  • 24
  • 35