Reputation:
Hey I want to pass a bitmap to another activity. To avoid a "Failed binder transaction" exception I compressed the bitmap. But now I get a nullpointer exception although I can display the image in an imageview so it contains data. For testing I passed just a string and that worked fine. Thanks for any answer.
MainActivity.java
//Here I want to pass the bitmap
topBitmap = BitmapFactory.decodeByteArray(data, 0, data.length);
camera.release();
bottomBitmap=MainActivity.scaleDownBitmap(bottomBitmap, 100,getApplicationContext());
Intent intent = new Intent(getApplicationContext(), DetailActivity.class);
intent.putExtra("bottomBitmap", bottomBitmap);
startActivity(intent);
//Method to compress bitmap
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;
}
DetailActivity.java
private Bitmap bottomBitmap;
private ImageView bottomImage;
//Receive Data
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.detail_activity);
Intent intent = getIntent();
this.bottomBitmap = (Bitmap) intent.getParcelableExtra("bottomBitmap");
this.bottomImage.setImageBitmap(this.bottomBitmap);
}
Log:
04-28 21:56:13.317: E/AndroidRuntime(19456): FATAL EXCEPTION: main
04-28 21:56:13.317: E/AndroidRuntime(19456): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.campic/com.example.campic.DetailActivity}: java.lang.NullPointerException
04-28 21:56:13.317: E/AndroidRuntime(19456): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2517)
04-28 21:56:13.317: E/AndroidRuntime(19456): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2574)
04-28 21:56:13.317: E/AndroidRuntime(19456): at android.app.ActivityThread.access$600(ActivityThread.java:162)
04-28 21:56:13.317: E/AndroidRuntime(19456): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1413)
04-28 21:56:13.317: E/AndroidRuntime(19456): at android.os.Handler.dispatchMessage(Handler.java:99)
04-28 21:56:13.317: E/AndroidRuntime(19456): at android.os.Looper.loop(Looper.java:158)
04-28 21:56:13.317: E/AndroidRuntime(19456): at android.app.ActivityThread.main(ActivityThread.java:5789)
04-28 21:56:13.317: E/AndroidRuntime(19456): at java.lang.reflect.Method.invokeNative(Native Method)
04-28 21:56:13.317: E/AndroidRuntime(19456): at java.lang.reflect.Method.invoke(Method.java:525)
04-28 21:56:13.317: E/AndroidRuntime(19456): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1027)
04-28 21:56:13.317: E/AndroidRuntime(19456): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:843)
04-28 21:56:13.317: E/AndroidRuntime(19456): at dalvik.system.NativeStart.main(Native Method)
04-28 21:56:13.317: E/AndroidRuntime(19456): Caused by: java.lang.NullPointerException
04-28 21:56:13.317: E/AndroidRuntime(19456): at com.example.campic.DetailActivity.onCreate(DetailActivity.java:22)
04-28 21:56:13.317: E/AndroidRuntime(19456): at android.app.Activity.performCreate(Activity.java:5195)
04-28 21:56:13.317: E/AndroidRuntime(19456): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1111)
04-28 21:56:13.317: E/AndroidRuntime(19456): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2473)
04-28 21:56:13.317: E/AndroidRuntime(19456): ... 11 more
Upvotes: 0
Views: 232
Reputation: 5022
In DetailActivity
:
private ImageView bottomImage;
...
this.bottomImage.setImageBitmap(this.bottomBitmap);
bottomImage
is never initialized. You probably need to use findViewById
to initialize the variable before calling setImageBitmap
on it.
Upvotes: 1