0

我正在尝试将图像文件保存到我的应用程序的内部存储中。

为此,我编写了以下方法,该方法采用 id 和位图并创建图像文件,其中 directory 是 File 类型的类静态字段。

// Returns thumbnail
private static Bitmap saveBitmapWithThumbnail(long id, Bitmap bitmap) {
    Bitmap thumbnail;

    if(directory == null) {
        ContextWrapper cw = new ContextWrapper(Engine.getContext());
        directory = cw.getDir(DIRECTORY_NAME, Context.MODE_PRIVATE);
        if(!directory.exists()) directory.mkdir();
    }

    saveBitmap(getImageFileName(id), bitmap);
    saveBitmap(getThumbnailFileName(id), thumbnail=makeThumbnail(bitmap));
    return thumbnail;
}

此方法的作用是获取 id 和位图并将其保存为原始文件并创建缩略图到内部存储中。

原始文件的名称生成为 [id+".png"],缩略图文件的名称生成为 [id+"_tn.png"]。

saveBitmap() 方法是将位图写入内部存储的方法。

private static void saveBitmap(String fileName, Bitmap bitmap) {
    File imageFile = new File(directory, fileName);

    FileOutputStream fos = null;
    try {
        fos = new FileOutputStream(imageFile);
        bitmap.compress(Bitmap.CompressFormat.PNG, 100, fos);
        fos.close();
    } catch(Exception e) {}
}

它采用文件名 (11.png, 11_tn.png, ...) 和位图(无论是原始文件还是缩略图)并制作一个文件并压缩到它的输出流中。

奇怪的是,当我第一次运行我的应用程序保存图像时,它工作得很好。

它可以读取和写入存储在内部存储器中的图像。

但是,在我关闭我的应用程序并再次运行它之后,它会抛出 FileNotFoundException 并带有以下日志。

W/System.err: java.io.FileNotFoundException: /1.png: open failed: ENOENT (No such file or directory)
W/System.err:     at libcore.io.IoBridge.open(IoBridge.java:458)
W/System.err:     at java.io.FileInputStream.<init>(FileInputStream.java:78)
W/System.err:     at com.google.dotplace.dotplace.data.Image.parseCursor(Image.java:118)
W/System.err:     at com.google.dotplace.dotplace.data.Image.checkDebug(Image.java:74)
W/System.err:     at com.google.dotplace.dotplace.LoadActivity.debugDatabase(LoadActivity.java:77)
W/System.err:     at com.google.dotplace.dotplace.LoadActivity.onCreate(LoadActivity.java:25)
W/System.err:     at android.app.Activity.performCreate(Activity.java:5275)
W/System.err:     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087)
W/System.err:     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2167)
W/System.err:     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2253)
W/System.err:     at android.app.ActivityThread.access$800(ActivityThread.java:142)
W/System.err:     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1203)
W/System.err:     at android.os.Handler.dispatchMessage(Handler.java:102)
W/System.err:     at android.os.Looper.loop(Looper.java:136)
W/System.err:     at android.app.ActivityThread.main(ActivityThread.java:5120)
W/System.err:     at java.lang.reflect.Method.invokeNative(Native Method)
W/System.err:     at java.lang.reflect.Method.invoke(Method.java:515)
W/System.err:     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:792)
W/System.err:     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:608)
W/System.err:     at dalvik.system.NativeStart.main(Native Method)
W/System.err: Caused by: libcore.io.ErrnoException: open failed: ENOENT (No such file or directory)
W/System.err:     at libcore.io.Posix.open(Native Method)
W/System.err:     at libcore.io.BlockGuardOs.open(BlockGuardOs.java:110)
W/System.err:     at libcore.io.IoBridge.open(IoBridge.java:442)
W/System.err:   ... 19 more

我唯一能得出的结论是,在我的应用程序关闭后,内部存储发生变化或文件被删除,但我不知道为什么。

我现在猜测的是我的测试有问题。

我正在测试如下。

  1. 编译并运行带有文件插入和检查的项目。

  2. 在不插入文件的情况下编译并运行项目并检查 1 的数据是否剩余。

我这样做是因为我没有在我的应用程序中编写或读取文件的任何用户界面。

我唯一的猜测是,当我再次编译项目时,它会以某种方式改变我的应用程序上下文中的某些独特内容,从而导致内部存储发生变化,我认为这是非常无稽之谈。

我哪里错了??

4

2 回答 2

0

你必须给予runtime棉花糖及以上的许可:

<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />`
于 2017-04-06T04:23:14.340 回答
0

您可能做错了几件事。每当您想读/写内部/外部存储时,您必须确保执行以下操作;

  1. READ/WRITE存储权限放入您的清单中。
  2. 如果您Android VersionMarshmallow或更高,请询问运行时权限。您可以在此处获取有关此的信息
  3. 确保path正确。大多数情况下,硬编码路径会有所不同。请参阅此处了解更多详细信息。
  4. mkdirs()如果directory不存在,请确保调用。
  5. 确保filename正确。您之前说过它是11.png11_tn.png但后来您访问了1.png. 可能是这引起了问题。
于 2017-04-06T04:26:36.307 回答