私はアンドロイドの初心者で、基本的にネイティブのカメラアプリケーションを起動し、写真を撮ってデバイスに保存する最初のアプリを最近開発していました。しかし、私はカメラアプリを起動しようとすると、アプリケーションがクラッシュし続けます。私はこの並べ替えを手伝ってください。ありがとう。Camera_intentが停止しました
logcatのログ:
は03-22 15:13:35.143: D/AndroidRuntime(17395): Shutting down VM
03-22 15:13:35.144: E/AndroidRuntime(17395): FATAL EXCEPTION: main
03-22 15:13:35.144: E/AndroidRuntime(17395): Process: com.example.vivek.camera_intent, PID: 17395
03-22 15:13:35.144: E/AndroidRuntime(17395): java.lang.IllegalStateException: Could not execute method for android:onClick
03-22 15:13:35.144: E/AndroidRuntime(17395): at android.support.v7.app.AppCompatViewInflater$DeclaredOnClickListener.onClick(AppCompatViewInflater.java:293)
03-22 15:13:35.144: E/AndroidRuntime(17395): at android.view.View.performClick(View.java:5612)
03-22 15:13:35.144: E/AndroidRuntime(17395): at android.view.View$PerformClick.run(View.java:22285)
03-22 15:13:35.144: E/AndroidRuntime(17395): at android.os.Handler.handleCallback(Handler.java:751)
03-22 15:13:35.144: E/AndroidRuntime(17395): at android.os.Handler.dispatchMessage(Handler.java:95)
03-22 15:13:35.144: E/AndroidRuntime(17395): at android.os.Looper.loop(Looper.java:154)
03-22 15:13:35.144: E/AndroidRuntime(17395): at android.app.ActivityThread.main(ActivityThread.java:6123)
03-22 15:13:35.144: E/AndroidRuntime(17395): at java.lang.reflect.Method.invoke(Native Method)
03-22 15:13:35.144: E/AndroidRuntime(17395): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:867)
03-22 15:13:35.144: E/AndroidRuntime(17395): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:757)
03-22 15:13:35.144: E/AndroidRuntime(17395): Caused by: java.lang.reflect.InvocationTargetException
03-22 15:13:35.144: E/AndroidRuntime(17395): at java.lang.reflect.Method.invoke(Native Method)
03-22 15:13:35.144: E/AndroidRuntime(17395): at android.support.v7.app.AppCompatViewInflater$DeclaredOnClickListener.onClick(AppCompatViewInflater.java:288)
03-22 15:13:35.144: E/AndroidRuntime(17395): ... 9 more
03-22 15:13:35.144: E/AndroidRuntime(17395): Caused by: android.os.FileUriExposedException: file:///storage/emulated/0/Pictures/I_20170322_151335_1517517949.jpg exposed beyond app through ClipData.Item.getUri()v
03-22 15:13:35.144: E/AndroidRuntime(17395): at android.os.StrictMode.onFileUriExposed(StrictMode.java:1813)
03-22 15:13:35.144: E/AndroidRuntime(17395): at android.net.Uri.checkFileUriExposed(Uri.java:2360)
03-22 15:13:35.144: E/AndroidRuntime(17395): at android.content.ClipData.prepareToLeaveProcess(ClipData.java:832)
03-22 15:13:35.144: E/AndroidRuntime(17395): at android.content.Intent.prepareToLeaveProcess(Intent.java:8957)
03-22 15:13:35.144: E/AndroidRuntime(17395): at android.content.Intent.prepareToLeaveProcess(Intent.java:8942)
03-22 15:13:35.144: E/AndroidRuntime(17395): at android.app.Instrumentation.execStartActivity(Instrumentation.java:1583)
03-22 15:13:35.144: E/AndroidRuntime(17395): at android.app.Activity.startActivityForResult(Activity.java:4228)
03-22 15:13:35.144: E/AndroidRuntime(17395): at android.support.v4.app.BaseFragmentActivityJB.startActivityForResult(BaseFragmentActivityJB.java:48)
03-22 15:13:35.144: E/AndroidRuntime(17395): at android.support.v4.app.FragmentActivity.startActivityForResult(FragmentActivity.java:75)
03-22 15:13:35.144: E/AndroidRuntime(17395): at android.app.Activity.startActivityForResult(Activity.java:4187)
03-22 15:13:35.144: E/AndroidRuntime(17395): at android.support.v4.app.FragmentActivity.startActivityForResult(FragmentActivity.java:856)
03-22 15:13:35.144: E/AndroidRuntime(17395): at com.example.vivek.camera_intent.CameraIntentActivity.callCameraApp(CameraIntentActivity.java:102)
03-22 15:13:35.144: E/AndroidRuntime(17395): at com.example.vivek.camera_intent.CameraIntentActivity.takePhoto(CameraIntentActivity.java:50)
03-22 15:13:35.144: E/AndroidRuntime(17395): ... 11 more
MainActivityファイルが含まれています:
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.vivek.camera_intent">
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-feature android:name="android.hardware.camera"
android:required="true" />
<uses-sdk android:minSdkVersion="23" />
<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:supportsRtl="true"
android:theme="@style/AppTheme">
<activity android:name=".CameraIntentActivity">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>
:
package com.example.vivek.camera_intent;
import android.Manifest;
import android.annotation.TargetApi;
import android.content.Intent;
import android.content.pm.PackageManager;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.net.Uri;
import android.os.Build;
import android.os.Bundle;
import android.os.Environment;
import android.provider.MediaStore;
import android.support.v4.content.ContextCompat;
import android.support.v7.app.AppCompatActivity;
import android.view.View;
import android.widget.ImageView;
import android.widget.Toast;
import java.io.File;
import java.io.IOException;
import java.text.SimpleDateFormat;
import java.util.Date;
public class CameraIntentActivity extends AppCompatActivity {
private static final int REQUEST_IMAGE_CAPTURE = 911;
private ImageView mImageView;
private String mCurrentPhotoPath;
private static final int REQUEST_EXTERNAL_STORAGE_RESULT = 1;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_camera_intent);
mImageView = (ImageView) findViewById(R.id.imageView);
}
@TargetApi(Build.VERSION_CODES.M)
public void takePhoto(View view)
{
//Toast.makeText(this, "Camera Button Clicked", Toast.LENGTH_SHORT).show();
if (ContextCompat.checkSelfPermission(this,
Manifest.permission.WRITE_EXTERNAL_STORAGE) == PackageManager.PERMISSION_GRANTED)
{
callCameraApp();
}
else
{
if (shouldShowRequestPermissionRationale(Manifest.permission.WRITE_EXTERNAL_STORAGE))
{
Toast.makeText(this, "Need external storage permission", Toast.LENGTH_SHORT).show();
}
requestPermissions(new String[] {Manifest.permission.WRITE_EXTERNAL_STORAGE}, REQUEST_EXTERNAL_STORAGE_RESULT);
}
}
@Override
public void onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults)
{
if (requestCode == REQUEST_EXTERNAL_STORAGE_RESULT)
{
if (grantResults[0] == PackageManager.PERMISSION_GRANTED)
{
callCameraApp();
}
else
{
Toast.makeText(this, "Request permission not granted", Toast.LENGTH_SHORT).show();
}
}
else
{
super.onRequestPermissionsResult(requestCode, permissions, grantResults);
}
}
private void callCameraApp()
{
Intent takePictureIntent = new Intent();
takePictureIntent.setAction(MediaStore.ACTION_IMAGE_CAPTURE);
File photoFile = null;
try
{
photoFile = createImageFile();
}
catch (IOException ex)
{
ex.printStackTrace();
}
takePictureIntent.putExtra(MediaStore.EXTRA_OUTPUT, Uri.fromFile(photoFile));
startActivityForResult(takePictureIntent, REQUEST_IMAGE_CAPTURE);
}
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data)
{
if (requestCode == REQUEST_IMAGE_CAPTURE && resultCode == RESULT_OK)
{
//Toast.makeText(this, "Photograph Captured Successfully", Toast.LENGTH_SHORT).show();
//Bundle extras = data.getExtras();
//Bitmap imageBitmap = (Bitmap) extras.get("data");
//mImageView.setImageBitmap(imageBitmap);
Bitmap imageBitmap = BitmapFactory.decodeFile(mCurrentPhotoPath);
mImageView.setImageBitmap(imageBitmap);
}
}
File createImageFile() throws IOException
{
String timestamp = new SimpleDateFormat("yyyyMMdd_HHmmss").format(new Date());
String imageFileName = "I_" + timestamp + "_";
File storageDirectory = Environment.getExternalStoragePublicDirectory(Environment.DIRECTORY_PICTURES);
File image = File.createTempFile(imageFileName, ".jpg", storageDirectory);
mCurrentPhotoPath = image.getAbsolutePath();
return image;
}
}
は私もManifest.xmlファイルにアクセス権を追加しました
fileUriExposed errror –
ので、私はそれを実行するために何をすべきかを持っています:menifestプットで、
今:provider_paths.xmlという名前のファイルを食べましたandroid 7.0 – inquiindian
FileProviderを使用 –