文件未找到错误没有明显原因?

时间:2017-01-19 15:05:31

标签: java android image save storage

我的应用应该在piechart上将external storage保存为png。但是会出现此错误:

java.io.FileNotFoundException: /storage/emulated/0/SAVE IMAGE EXAMPLE/myimage.png (No such file or directory)

我按照说明非常密切地添加了这种功能(来自此tutorial),但是出现了错误。该应用程序具有写入外部存储的权限,我在android_manifest.xml中添加了权限。

你能发现错误吗?因为我不能。

如果您也找不到错误,是否可以推荐其他任何方式来执行此操作?

我正在使用MPAndroidChart,但我并不认为它与此有关,因为我可以尝试保存任何其他对象并且错误仍然存​​在。

代码

final PieChart piechart = (PieChart) findViewById(R.id.piechart);  

button2.setOnClickListener(new View.OnClickListener() {
  public void onClick (View v) {
    Toast.makeText(Main.this, "Chart Saved", Toast.LENGTH_SHORT).show();
    piechart.setCenterText("Test");
    Bitmap bitmap;
    OutputStream output;

    bitmap = BitmapFactory.decodeResource(getResources(),R.id.piechart);

    File filepath = Environment.getExternalStorageDirectory();

    File dir = new File(filepath.getAbsolutePath()+"/SAVE IMAGE EXAMPLE");
    dir.mkdirs();

    File file = new File(dir, "myimage.png");

    try {
       output = new FileOutputStream(file);

       bitmap.compress(Bitmap.CompressFormat.PNG, 100, output);
       output.flush();
       output.close();


    }catch(Exception e){
       e.printStackTrace();
    }
 } 
});

完全错误

    W/System.err: java.io.FileNotFoundException: /storage/emulated/0/SAVE IMAGE EXAMPLE/myimage.png (No such file or directory)
W/System.err:     at java.io.FileOutputStream.open(Native Method)
W/System.err:     at java.io.FileOutputStream.<init>(FileOutputStream.java:221)
W/System.err:     at java.io.FileOutputStream.<init>(FileOutputStream.java:169)
W/System.err:     at com.pies.quickpie.Main$1$3.onClick(Main.java:175)
W/System.err:     at android.view.View.performClick(View.java:5637)
W/System.err:     at android.view.View$PerformClick.run(View.java:22429)
W/System.err:     at android.os.Handler.handleCallback(Handler.java:751)
W/System.err:     at android.os.Handler.dispatchMessage(Handler.java:95)
W/System.err:     at android.os.Looper.loop(Looper.java:154)
W/System.err:     at android.app.ActivityThread.main(ActivityThread.java:6119)
W/System.err:     at java.lang.reflect.Method.invoke(Native Method)
W/System.err:     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:886)
W/System.err:     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:776)

1 个答案:

答案 0 :(得分:0)

您需要实施Runtime Permission model以获得来自marshmallow及以上用户的Storage许可。

See the example here for storage permission