web-dev-qa-db-ja.com

Android Javaバインダーがバインダートランザクションに失敗しましたか?

サービスから画像をダウンロードし、アクティビティで表示しようとしていますが、取得し続けます

 Java binder FAILED BINDER TRANSACTION

これは私のサービスコードです

public class DownloadImageService extends Service {

@Override
public int onStartCommand(Intent intent, int flags, int startId) {
    new LoadImageAsync().execute(intent.getStringExtra("type"));
    return Service.START_NOT_STICKY;
}

@Override
public IBinder onBind(Intent intent) {
    return null;
}

private class LoadImageAsync extends AsyncTask<String, Void, String> {
    byte[] compressedImage;
    Bitmap bmp;
    String img;

    @Override
    protected void onPreExecute() {
        super.onPreExecute();
    }

    @Override
    protected String doInBackground(String... params) {

        try {
            URL url = new URL(imgUrl);
            bmp = BitmapFactory.decodeStream(url.openConnection().getInputStream());
            compressedImage = CompressBitmap.compresssImage(bmp);
            img = Base64.encodeToString(compressedImage, Base64.DEFAULT);

        } catch (IOException e) {
            compressedImage = null;
            bmp = null;
            e.printStackTrace();
        }
        return null;
    }

    @Override
    protected void onPostExecute(String s) {
        super.onPostExecute(s);
        if (compressedImage != null) {
            Intent i = new Intent(getApplicationContext(), OtherCampaignActivity.class);
            i.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
            i.putExtra("image_byte", img);
            startActivity(i);
        }
        stopService(new Intent(getApplicationContext(), DownloadImageService.class));
    }
}

}

圧縮機能

public static byte[] compresssImage(Bitmap b) {
    ByteArrayOutputStream stream = new ByteArrayOutputStream();
    b.compress(Bitmap.CompressFormat.PNG, 100, stream);
    byte[] compressedByteArray = stream.toByteArray();
    return compressedByteArray;
}

私の活動

public class OtherActivity extends AppCompatActivity {
private ImageView iv;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_other);
    iv = (ImageView) findViewById(R.id.imageViewCam);
    byte[] byteArray =      Base64.decode(getIntent().getStringExtra("image_byte"), Base64.DEFAULT);
    //        byte[] byteArray = getIntent().getExtras().getByteArray("image_byte");
    Bitmap bitmap = BitmapFactory.decodeByteArray(byteArray, 0, byteArray.length);
    iv.setImageBitmap(bitmap);

}

@Override
public void onBackPressed() {
    super.onBackPressed();
    finish();
}
}

コードの問題は何ですか。アクティビティは開始されていません。

アプリはクラッシュしていません。私はlogcatでこれを取得します:

06-30 12:38:36.800 29992-29992/com.vt.enit E/JavaBinder﹕ !!! FAILED BINDER TRANSACTION !!!

おそらく、ビットマップが大きいためだと思います。

17
WISHY

画像のキャッシュを作成すると問題が解決します

private LruCache<String, Bitmap> mMemoryCache;

@Override
protected void onCreate(Bundle savedInstanceState) {
...
// Get max available VM memory, exceeding this amount will throw an
// OutOfMemory exception. Stored in kilobytes as LruCache takes an
// int in its constructor.
final int maxMemory = (int) (Runtime.getRuntime().maxMemory() / 1024);

// Use 1/8th of the available memory for this memory cache.
final int cacheSize = maxMemory / 8;

mMemoryCache = new LruCache<String, Bitmap>(cacheSize) {
    @Override
    protected int sizeOf(String key, Bitmap bitmap) {
        // The cache size will be measured in kilobytes rather than
        // number of items.
        return bitmap.getByteCount() / 1024;
    }
};
...
}

public void addBitmapToMemoryCache(String key, Bitmap bitmap) {
if (getBitmapFromMemCache(key) == null) {
    mMemoryCache.put(key, bitmap);
}
 }

public Bitmap getBitmapFromMemCache(String key) {
return mMemoryCache.get(key);
}

参照: キャッシュビットマップ

12
WISHY

画像をインテントエキストラとして送信しようとしており、画像に対して大きすぎるため失敗します。 IPCインテントやサービス/バインダーなどの通信技術を使用して画像を送信することはできません。Androidのバージョンに応じて1MB/10MBの制限があります。

7
Yuriy