Я пытаюсь преобразовать нормальное цветное изображение в изображение оттенков серого. Код действительно прост, но не знаю, почему я получаю ошибку. Я просто меняю значение цвета по пикселям, а затем сохраняю его в новый bitmap.Error подходит, когда я пытаюсь установить пиксели в новое растровое изображение.Преобразование простого изображения в оттенки серого
Bitmap c=BitmapFactory.decodeFile(Environment.getExternalStorageDirectory().getAbsolutePath() + "/1.jpg");
int width=c.getWidth();
int height=c.getHeight();
int A,B,R,G;
int pixel;
for(int x = 0; x < width; x++) {
for(int y = 0; y < height; y++) {
// get one pixel color
// pixel = c.getPixel(x, y);
// retrieve color of all channels
// A = Color.alpha(c.getPixel(x, y));
R = Color.red(c.getPixel(x, y));
G = Color.green(c.getPixel(x, y));
B = Color.blue(c.getPixel(x, y));
// take conversion up to one single value
R = G = B = (int)(0.299 * R + 0.587 * G + 0.114 * B);
// set new pixel color to output bitmap
h=String.valueOf(R);
bmOut.isMutable();
bmOut.setPixel(x, y, Color.argb(Color.alpha(c.getPixel(x, y)), R, G, B));
}
// Toast.makeText(getApplicationContext(), h, Toast.LENGTH_SHORT).show();
}
Вот мой LogCat
05-02 13:37:37.858: E/AndroidRuntime(19254): FATAL EXCEPTION: main
05-02 13:37:37.858: E/AndroidRuntime(19254): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.otsu/com.example.otsu.MainActivity}: java.lang.NullPointerException
05-02 13:37:37.858: E/AndroidRuntime(19254): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1872)
05-02 13:37:37.858: E/AndroidRuntime(19254): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1893)
05-02 13:37:37.858: E/AndroidRuntime(19254): at android.app.ActivityThread.access$1500(ActivityThread.java:135)
05-02 13:37:37.858: E/AndroidRuntime(19254): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1054)
05-02 13:37:37.858: E/AndroidRuntime(19254): at android.os.Handler.dispatchMessage(Handler.java:99)
05-02 13:37:37.858: E/AndroidRuntime(19254): at android.os.Looper.loop(Looper.java:150)
05-02 13:37:37.858: E/AndroidRuntime(19254): at android.app.ActivityThread.main(ActivityThread.java:4389)
05-02 13:37:37.858: E/AndroidRuntime(19254): at java.lang.reflect.Method.invokeNative(Native Method)
05-02 13:37:37.858: E/AndroidRuntime(19254): at java.lang.reflect.Method.invoke(Method.java:507)
05-02 13:37:37.858: E/AndroidRuntime(19254): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:849)
05-02 13:37:37.858: E/AndroidRuntime(19254): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:607)
05-02 13:37:37.858: E/AndroidRuntime(19254): at dalvik.system.NativeStart.main(Native Method)
05-02 13:37:37.858: E/AndroidRuntime(19254): Caused by: java.lang.NullPointerException
05-02 13:37:37.858: E/AndroidRuntime(19254): at com.example.otsu.MainActivity.onCreate(MainActivity.java:58)
05-02 13:37:37.858: E/AndroidRuntime(19254): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1072)
05-02 13:37:37.858: E/AndroidRuntime(19254): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1836)
05-02 13:37:37.858: E/AndroidRuntime(19254): ... 11 more
Что такое линия на 'MainActivity.java: 58'? – NINCOMPOOP
У вас есть объект Null в строке 58: at com.example.otsu.MainActivity.onCreate (MainActivity.java:58) Вы можете указать, в какую строку кода это? –
У вас есть NPE в методе onCreate, не связанный с приведенным выше кодом. С учетом этого [здесь представлено более простое решение для преобразования изображения в оттенки серого] (http://stackoverflow.com/a/3391061/312312) – Lefteris