I was getting the following exception while Saving bitmap from fragment to internal/external storage
11-28 12:09:18.667: W/System.err(2620): java.io.FileNotFoundException: /storage/sdcard0/req_images/Image-296.jpg: open failed: ENOENT (No such file or directory)
11-28 12:09:18.717: W/System.err(2620): at libcore.io.IoBridge.open(IoBridge.java:427)
11-28 12:09:18.717: W/System.err(2620): at java.io.FileOutputStream.<init>(FileOutputStream.java:88)
11-28 12:09:18.717: W/System.err(2620): at java.io.FileOutputStream.<init>(FileOutputStream.java:73)
11-28 12:09:18.717: W/System.err(2620): at com.example.multipletab5.AnswerFragment.saveimage(AnswerFragment.java:133)
11-28 12:09:18.717: W/System.err(2620): at com.example.multipletab5.AnswerFragment.access$0(AnswerFragment.java:112)
11-28 12:09:18.717: W/System.err(2620): at com.example.multipletab5.AnswerFragment$2.onClick(AnswerFragment.java:81)
11-28 12:09:18.717: W/System.err(2620): at android.view.View.performClick(View.java:4147)
11-28 12:09:18.717: W/System.err(2620): at android.view.View$PerformClick.run(View.java:17161)
11-28 12:09:18.717: W/System.err(2620): at android.os.Handler.handleCallback(Handler.java:615)
11-28 12:09:18.717: W/System.err(2620): at android.os.Handler.dispatchMessage(Handler.java:92)
11-28 12:09:18.717: W/System.err(2620): at android.os.Looper.loop(Looper.java:213)
11-28 12:09:18.717: W/System.err(2620): at android.app.ActivityThread.main(ActivityThread.java:4787)
11-28 12:09:18.717: W/System.err(2620): at java.lang.reflect.Method.invokeNative(Native Method)
11-28 12:09:18.717: W/System.err(2620): at java.lang.reflect.Method.invoke(Method.java:511)
11-28 12:09:18.717: W/System.err(2620): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:789)
11-28 12:09:18.717: W/System.err(2620): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:556)
11-28 12:09:18.717: W/System.err(2620): at dalvik.system.NativeStart.main(Native Method)
11-28 12:09:18.727: W/System.err(2620): Caused by: libcore.io.ErrnoException: open failed: ENOENT (No such file or directory)
11-28 12:09:18.727: W/System.err(2620): at libcore.io.Posix.open(Native Method)
11-28 12:09:18.727: W/System.err(2620): at libcore.io.BlockGuardOs.open(BlockGuardOs.java:110)
11-28 12:09:18.727: W/System.err(2620): at libcore.io.IoBridge.open(IoBridge.java:411)
11-28 12:09:18.727: W/System.err(2620): ... 16 more
My aim is to save a drawing from my fragment to my android device. I have been trying to use the same approach in Activity class and it work. However when i try to use it in fragment class, it does not worked.
The app didn't crash it just display this error log.
Here is the code:
View content = v;
content.setDrawingCacheEnabled(true);
bitmap = content.getDrawingCache();
File file;
String root = Environment.getExternalStorageDirectory().toString();
File myDir = new File(root + "/req_images");
myDir.mkdirs();
Random generator = new Random();
int n = 10000;
n = generator.nextInt(n);
String fname = "Image-" + n + ".jpg";
file = new File(myDir, fname);
//Log.i(TAG, "" + file);
if (file.exists())
file.delete();
try {
FileOutputStream out = new FileOutputStream(file);
bitmap.compress(Bitmap.CompressFormat.JPEG, 90, out);
out.flush();
out.close();
} catch (Exception e) {
e.printStackTrace();
}