Android 更改图像亮度并将亮度值传递给其他用户时,无法消除NullPointerException

Android 更改图像亮度并将亮度值传递给其他用户时,无法消除NullPointerException,android,android-intent,nullpointerexception,brightness,Android,Android Intent,Nullpointerexception,Brightness,在我的应用程序中,我在活动B的ImageView中更改图像的亮度,并将图像和更改的亮度传递给活动A。但在活动A中接收结果时,我收到NullPointerException 以下是活动A中的部分代码: 在按钮上单击: btn_Edit.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { I

在我的应用程序中,我在活动B的ImageView中更改图像的亮度,并将图像和更改的亮度传递给活动A。但在活动A中接收结果时,我收到NullPointerException

以下是活动A中的部分代码:

在按钮上单击:

btn_Edit.setOnClickListener(new View.OnClickListener() {

        @Override
        public void onClick(View v) {               
            Intent editIntent = new Intent(HowItWorksActivity.this,
                    EditPhotoActivity.class);
            if (current_working_image_filename != null) {
                editIntent.putExtra("current_image_filename",
                        current_working_image_filename);
                startActivityForResult(editIntent, EDITED_PICTURE);                 

            }
                       }
在onActivityResult中:

if(resultCode==RESULT_OK && requestCode == EDITED_PICTURE){
        Log.e("EDITED_PIC", "IN onactivityresult");
        imageWithBorder = data.getStringExtra("ImageWithBorder");
        metrics = getResources().getDisplayMetrics();
        postcard_image = decodeSampledBitmapFromFileString(imageWithBorder,
                metrics.widthPixels, metrics.heightPixels);
        rl.setBackgroundDrawable(drawable);
        brightness = data.getIntExtra("Image_Brightness", 0);
        Log.e("brightness level", "IN onactivityresult "+brightness);
        if(brightness!=0){
        postcard_image = EditPhotoActivity.doBrightness(postcard_image,
                    brightness);
        }           
        putGestureImageOnScreen(postcard_image);

    }
在活动B中:

在单击按钮时:

btn_filter.setOnClickListener(new View.OnClickListener() {

        @Override
        public void onClick(View v) {
          Log.e("EditPhoto", "counter value = " + counter);
          counter++;
          sbarBrightness = (SeekBar) 
                             findViewById(R.id.seekBarForBrightness);
          if (counter % 2 == 0) {
            sbarBrightness.setVisibility(View.INVISIBLE);
          } else {
            sbarBrightness.setVisibility(View.VISIBLE);
         }

sbarBrightness.setOnSeekBarChangeListener(new OnSeekBarChangeListener() {

    @Override
    public void onProgressChanged(SeekBar seekBar,int progress, boolean 
                            fromUser) {                             
      brightness = progress;
      putGestureImageOnScreen(doBrightness(imageBitmap, brightness));
    }
      });

     }
  });

public static Bitmap doBrightness(Bitmap src, int value) {

    int width = src.getWidth();
    int height = src.getHeight();
    Bitmap bmout = Bitmap.createBitmap(width, height, src.getConfig());
    int A, R, G, B;
    int pixel;
    for (int i = 0; i < width; ++i) {
        for (int j = 0; j < height; ++j) {
            pixel = src.getPixel(i, j);
            A = Color.alpha(pixel);
            R = Color.red(pixel);
            G = Color.green(pixel);
            B = Color.blue(pixel);
            R += value;
            if (R > 255) {
                R = 255;
            } else if (R < 0) {
                R = 0;
            }
            G += value;
            if (G > 255) {
                G = 255;
            } else if (G < 0) {
                G = 0;
            }
            B += value;
            if (B > 255) {
                B = 255;
            } else if (B < 0) {
                B = 0;
            }
            bmout.setPixel(i, j, Color.argb(A, R, G, B));
        }
    }
    return bmout;

}
请帮助我解决NullpointerException问题


谢谢。

请从您的LogCat发布堆栈跟踪。在doBrightness中位图src上方添加的LogCat输出为空,请检查Null@ThanhLe但是如果我不改变亮度并将其传递给活动A,那么在这种情况下,成为dobrightness源的位图就不是空的。
02-26 13:57:07.442: E/SEnding brightness(12750): br = 37
02-26 13:57:07.492: E/EDITED_PIC(12750): IN onactivityresult
02-26 13:57:07.492: E/brightness level(12750): IN onactivityresult 37
02-26 13:57:07.502: E/AndroidRuntime(12750): FATAL EXCEPTION: main
02-26 13:57:07.502: E/AndroidRuntime(12750): java.lang.RuntimeException: Failure
delivering result ResultInfo{who=null, request=300, result=-1, data=Intent {  
cmp=com.sample.postcare2/.HowItWorksActivity (has extras) }} to activity
{com.sample.postcare2/com.sample.postcare2.HowItWorksActivity}: 
 java.lang.NullPointerException
02-26 13:57:07.502: E/AndroidRuntime(12750):    at  
android.app.ActivityThread.deliverResults(ActivityThread.java:3387)
02-26 13:57:07.502: E/AndroidRuntime(12750):    at  
android.app.ActivityThread.handleSendResult(ActivityThread.java:3437)
02-26 13:57:07.502: E/AndroidRuntime(12750):    at
android.app.ActivityThread.access$1100(ActivityThread.java:139)
02-26 13:57:07.502: E/AndroidRuntime(12750):    at 
android.app.ActivityThread$H.handleMessage(ActivityThread.java:1291)
02-26 13:57:07.502: E/AndroidRuntime(12750):    at
android.os.Handler.dispatchMessage(Handler.java:99)
02-26 13:57:07.502: E/AndroidRuntime(12750):    at 
android.os.Looper.loop(Looper.java:154)
02-26 13:57:07.502: E/AndroidRuntime(12750):    at 
android.app.ActivityThread.main(ActivityThread.java:4944)
02-26 13:57:07.502: E/AndroidRuntime(12750):    at 
java.lang.reflect.Method.invokeNative(Native Method)
02-26 13:57:07.502: E/AndroidRuntime(12750):    at   
java.lang.reflect.Method.invoke(Method.java:511)
02-26 13:57:07.502: E/AndroidRuntime(12750):    at 
com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
02-26 13:57:07.502: E/AndroidRuntime(12750):    at 
com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
02-26 13:57:07.502: E/AndroidRuntime(12750):    at 
dalvik.system.NativeStart.main(Native Method)
02-26 13:57:07.502: E/AndroidRuntime(12750): Caused by: java.lang.NullPointerException
02-26 13:57:07.502: E/AndroidRuntime(12750):    at 
com.sample.postcare2.EditPhotoActivity.doBrightness(EditPhotoActivity.java:393)
02-26 13:57:07.502: E/AndroidRuntime(12750):    at 
com.sample.postcare2.HowItWorksActivity.onActivityResult(HowItWorksActivity.java:533)
02-26 13:57:07.502: E/AndroidRuntime(12750):    at 
android.app.Activity.dispatchActivityResult(Activity.java:4740)
02-26 13:57:07.502: E/AndroidRuntime(12750):    at 
android.app.ActivityThread.deliverResults(ActivityThread.java:3383)
02-26 13:57:07.502: E/AndroidRuntime(12750):    ... 11 more