无法找到包含/storage/emulated/0/Android/data/com.example

时间:2017-03-31 11:50:33

标签: android android-intent camera root

我知道这个问题有很多问题,但我无法用其他帖子解决我的问题。

我不明白为什么会看到这条消息。

MainActivity

alert = RingtoneManager
                .getDefaultUri(RingtoneManager.TYPE_NOTIFICATION);

public class MainActivity extends AppCompatActivity {

    ImageView iv_foto;
    static final int REQUEST_TAKE_PHOTO = 1;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        iv_foto = (ImageView) findViewById(R.id.iv_foto);



    }

    public void sacarFoto(View v){
        dispatchTakePictureIntent();
    }
    String mCurrentPhotoPath;

    private File createImageFile() throws IOException {
        // Create an image file name
        String timeStamp = new SimpleDateFormat("yyyyMMdd_HHmmss").format(new Date());
        String imageFileName = "JPEG_" + timeStamp + "_";
        File storageDir = getExternalFilesDir(Environment.DIRECTORY_PICTURES);
        File image = File.createTempFile(
                imageFileName,  /* prefix */
                ".jpg",         /* suffix */
                storageDir      /* directory */
        );

        // Save a file: path for use with ACTION_VIEW intents
        mCurrentPhotoPath = image.getAbsolutePath();
        return image;
    }


    private void dispatchTakePictureIntent() {
        Intent takePictureIntent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE);
        // Ensure that there's a camera activity to handle the intent
        if (takePictureIntent.resolveActivity(getPackageManager()) != null) {
            // Create the File where the photo should go
            File photoFile = null;
            try {
                photoFile = createImageFile();
            } catch (IOException ex) {
                // Error occurred while creating the File
            }
            // Continue only if the File was successfully created
            if (photoFile != null) {
                Uri photoURI = FileProvider.getUriForFile(this,
                        "com.example.josemiguelrodriguez.fileprovider",
                        photoFile);
                takePictureIntent.putExtra(MediaStore.EXTRA_OUTPUT, photoURI);
                startActivityForResult(takePictureIntent, REQUEST_TAKE_PHOTO);
            }
        }
    }

    @Override
    protected void onActivityResult(int requestCode, int resultCode, Intent data) {
        super.onActivityResult(requestCode, resultCode, data);
        if (requestCode == REQUEST_TAKE_PHOTO){
            iv_foto.setImageURI(Uri.parse(mCurrentPhotoPath));
        }
    }
}

AndroidManifest

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.josemiguelrodriguez.pruebacamara">

    <uses-feature android:name="android.hardware.camera"
        android:required="true"
        />
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />

    <application
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:roundIcon="@mipmap/ic_launcher_round"
        android:supportsRtl="true"
        android:theme="@style/AppTheme">

        <provider
            android:name="android.support.v4.content.FileProvider"
            android:authorities="com.example.josemiguelrodriguez.fileprovider"
            android:exported="false"
            android:grantUriPermissions="true">
            <meta-data
                android:name="android.support.FILE_PROVIDER_PATHS"
                android:resource="@xml/file_paths"></meta-data>
        </provider>


        <activity android:name=".MainActivity">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>

</manifest>

file_paths.xml

<?xml version="1.0" encoding="utf-8"?>
<paths xmlns:android="http://schemas.android.com/apk/res/android">
    <external-file-path name="my_images" path="Pictures" />
</paths>

错误:

03-31 13:39:14.292 30787-30787/com.example.josemiguelrodriguez.pruebacamara E/AndroidRuntime: FATAL EXCEPTION: main
                                                                                              Process: com.example.josemiguelrodriguez.pruebacamara, PID: 30787
                                                                                              java.lang.IllegalStateException: Could not execute method for android:onClick
                                                                                                  at android.support.v7.app.AppCompatViewInflater$DeclaredOnClickListener.onClick(AppCompatViewInflater.java:293)
                                                                                                  at android.view.View.performClick(View.java:4438)
                                                                                                  at android.view.View$PerformClick.run(View.java:18422)
                                                                                                  at android.os.Handler.handleCallback(Handler.java:733)
                                                                                                  at android.os.Handler.dispatchMessage(Handler.java:95)
                                                                                                  at android.os.Looper.loop(Looper.java:136)
                                                                                                  at android.app.ActivityThread.main(ActivityThread.java:5001)
                                                                                                  at java.lang.reflect.Method.invokeNative(Native Method)
                                                                                                  at java.lang.reflect.Method.invoke(Method.java:515)
                                                                                                  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:785)
                                                                                                  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:601)
                                                                                                  at dalvik.system.NativeStart.main(Native Method)
                                                                                               Caused by: java.lang.reflect.InvocationTargetException
                                                                                                  at java.lang.reflect.Method.invokeNative(Native Method)
                                                                                                  at java.lang.reflect.Method.invoke(Method.java:515)
                                                                                                  at android.support.v7.app.AppCompatViewInflater$DeclaredOnClickListener.onClick(AppCompatViewInflater.java:288)
                                                                                                  at android.view.View.performClick(View.java:4438) 
                                                                                                  at android.view.View$PerformClick.run(View.java:18422) 
                                                                                                  at android.os.Handler.handleCallback(Handler.java:733) 
                                                                                                  at android.os.Handler.dispatchMessage(Handler.java:95) 
                                                                                                  at android.os.Looper.loop(Looper.java:136) 
                                                                                                  at android.app.ActivityThread.main(ActivityThread.java:5001) 
                                                                                                  at java.lang.reflect.Method.invokeNative(Native Method) 
                                                                                                  at java.lang.reflect.Method.invoke(Method.java:515) 
                                                                                                  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:785) 
                                                                                                  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:601) 
                                                                                                  at dalvik.system.NativeStart.main(Native Method) 
                                                                                               Caused by: java.lang.IllegalArgumentException: Failed to find configured root that contains /storage/emulated/0/Android/data/com.example.josemiguelrodriguez.pruebacamara/files/Pictures/JPEG_20170331_133914_-2001489715.jpg
                                                                                                  at android.support.v4.content.FileProvider$SimplePathStrategy.getUriForFile(FileProvider.java:711)
                                                                                                  at android.support.v4.content.FileProvider.getUriForFile(FileProvider.java:400)
                                                                                                  at com.example.josemiguelrodriguez.pruebacamara.MainActivity.dispatchTakePictureIntent(MainActivity.java:67)
                                                                                                  at com.example.josemiguelrodriguez.pruebacamara.MainActivity.sacarFoto(MainActivity.java:33)
                                                                                                  at java.lang.reflect.Method.invokeNative(Native Method) 
                                                                                                  at java.lang.reflect.Method.invoke(Method.java:515) 
                                                                                                  at android.support.v7.app.AppCompatViewInflater$DeclaredOnClickListener.onClick(AppCompatViewInflater.java:288) 
                                                                                                  at android.view.View.performClick(View.java:4438) 
                                                                                                  at android.view.View$PerformClick.run(View.java:18422) 
                                                                                                  at android.os.Handler.handleCallback(Handler.java:733) 
                                                                                                  at android.os.Handler.dispatchMessage(Handler.java:95) 
                                                                                                  at android.os.Looper.loop(Looper.java:136) 
                                                                                                  at android.app.ActivityThread.main(ActivityThread.java:5001) 
                                                                                                  at java.lang.reflect.Method.invokeNative(Native Method) 
                                                                                                  at java.lang.reflect.Method.invoke(Method.java:515) 
                                                                                                  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:785) 
                                                                                                  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:601) 
                                                                                                  at dalvik.system.NativeStart.main(Native Method) 

非常感谢!! :d

更新 错误是通过@CommonsWare的第一个响应解决的,但现在我有以下错误:

错误

resolveUri failed on bad bitmap uri: /storage/emulated/0/Android/data/com.example.josemiguelrodri‌​guez.pruebacamara/fi‌​les/Pictures/JPEG_20‌​170331_140455_-20014‌​89715.png

3 个答案:

答案 0 :(得分:1)

在file_paths.xml中,它要求输入根。

    <?xml version="1.0" encoding="utf-8"?>
<resources>
    <paths xmlns:android="http://schemas.android.com/apk/res/android">
        <root-path name="root" path="." />
    </paths>
</resources>

答案 1 :(得分:0)

external-file-path更改为external-files-path(请注意s)。

答案 2 :(得分:0)

this.data

更改为

File storageDir = getExternalFilesDir(Environment.DIRECTORY_PICTURES);

和/或将File storageDir = getExternalStoragePublicDirectory(Environment.DIRECTORY_PICTURES); 更改为path="Pictures"