2017-02-13 13 views
2

간단한 해결책으로 질문이 될 수 있다면 매우 유감스럽게 생각합니다.이미지 캡처, Firebase에 업로드 및 Java Android Studio 검색

나는 무엇을하려고합니까?

  • 캡처의 Button
  • 에서 이미지 중포 기지 저장
  • 에 해당 이미지를 업로드는 이미지 뷰

내 문제는 지금까지 무엇인가에 해당 이미지를 검색?

  • 진드기를 클릭하면 사진이 찍히지 만 충돌합니다.
  • 따라서 아무 것도 업로드되거나 달성되지 않습니다. 나는 다른 포럼 및 비디오 자습서 아무것도하지만, 많은 살펴 보았다

내 코드

P.N가 작동하는 것 같군. 희망을 갖고 누군가가 도울 수 있기를 바랍니다. 이것이 내가 같은 문제를 가지고 다른 사람들을 보았다

02-13 02:30:32.693 2133-2133/com.example.rikhi.chores E/AndroidRuntime: FATAL EXCEPTION: main 
Process: com.example.rikhi.chores, PID: 2133 
    java.lang.RuntimeException: Failure delivering result ResultInfo{who=null, request=1, result=-1, data=Intent { act=inline-data (has extras) }} to activity {com.example.rikhi.chores/com.example.rikhi.chores.LoginRegister.InsideMainActivity.LeaderboardActivity}: java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.String android.net.Uri.getLastPathSegment()' on a null object reference 
    at android.app.ActivityThread.deliverResults(ActivityThread.java:4089) 
    at android.app.ActivityThread.handleSendResult(ActivityThread.java:4132) 
    at android.app.ActivityThread.-wrap20(ActivityThread.java) 
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1533) 
    at android.os.Handler.dispatchMessage(Handler.java:102) 
    at android.os.Looper.loop(Looper.java:154) 
    at android.app.ActivityThread.main(ActivityThread.java:6119) 
    at java.lang.reflect.Method.invoke(Native Method) 
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:886) 
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:776) 
Caused by: java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.String android.net.Uri.getLastPathSegment()' on a null object reference 
    at com.example.rikhi.chores.LoginRegister.InsideMainActivity.LeaderboardActivity.onActivityResult(LeaderboardActivity.java:74) 
    at android.app.Activity.dispatchActivityResult(Activity.java:6932) 
    at android.app.ActivityThread.deliverResults(ActivityThread.java:4085) 
    at android.app.ActivityThread.handleSendResult(ActivityThread.java:4132)  
    at android.app.ActivityThread.-wrap20(ActivityThread.java)  
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1533)  
    at android.os.Handler.dispatchMessage(Handler.java:102)  
    at android.os.Looper.loop(Looper.java:154)  
    at android.app.ActivityThread.main(ActivityThread.java:6119)  
    at java.lang.reflect.Method.invoke(Native Method)  
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:886)  
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:776)  

도움이 될 것입니다 경우 안드로이드 모니터에서

public class LeaderboardActivity extends AppCompatActivity { 

    private static final int CAMERA_REQUEST_CODE = 1; 
    private static final int REQUEST_TAKE_PHOTO = 1; 
    private StorageReference mStorage; 

    private ProgressDialog mProgress; 

    String mCurrentPhotoPath; 




    @Override 
    protected void onCreate(Bundle savedInstanceState) { 
     super.onCreate(savedInstanceState); 
     setContentView(R.layout.activity_leaderboard); 

     mStorage = FirebaseStorage.getInstance().getReference(); 

     final Button bImage = (Button) findViewById(R.id.bCamera); 
     final ImageView ivPic = (ImageView) findViewById(R.id.ivPic); 

     mProgress = new ProgressDialog(this); 

     bImage.setOnClickListener(new View.OnClickListener() { 
      @Override 
      public void onClick(View v) { 
       Intent intent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE); 
       startActivityForResult(intent, CAMERA_REQUEST_CODE); 


      } 
     }); 
    } 

    @Override 
    protected void onActivityResult(int requestCode, int resultCode, Intent data) { 
     super.onActivityResult(requestCode, resultCode, data); 

     if (requestCode == CAMERA_REQUEST_CODE && resultCode == RESULT_OK) { 

      mProgress.setMessage("Uploading Image"); 
      mProgress.show(); 

      Uri uri = data.getData(); 
      StorageReference filepath = mStorage.child("Photo").child(uri.getLastPathSegment()); 
      filepath.putFile(uri).addOnSuccessListener(new OnSuccessListener <UploadTask.TaskSnapshot>() { 
       @Override 
       public void onSuccess(UploadTask.TaskSnapshot taskSnapshot) { 
        mProgress.dismiss(); 
        Toast.makeText(LeaderboardActivity.this, "Uploading Complete...", Toast.LENGTH_LONG); 

       } 
      }); 
     } 
    } 

    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.android.fileprovider", 
        photoFile); 
       takePictureIntent.putExtra(MediaStore.EXTRA_OUTPUT, photoURI); 
       startActivityForResult(takePictureIntent, REQUEST_TAKE_PHOTO); 
      } 
     } 
    } 
} 

오류

확실하지, 그들은 아무것도 다음에 무슨 일이 생긴없는 말을 이어 이것과 다시 같은 문제에 대한 구글 안드로이드 지침.

+0

Firebase는 사용하지 않지만 AsyncHttpClient를 사용하여 HTTP 멀티 파트 요청을 사용하여 사진을 업로드하는 것은 매우 간단합니다. –

+0

아쉽게도 안드로이드 스튜디오에서 시작하여 로그인 용 데이터베이스를 이미 만들었습니다 이 작업을 수행하려고하는 사용자가 마지막 단계 인 XD이지만, 고맙습니다. –

답변

1
  1. 버튼에, 그 의도를 제거 클릭하고 바로 확인

  2. 또한 온 클릭 버튼 리스너에 당신의 dispatchTakePictureIntetnt() 메소드를 호출 에뮬레이터 설정으로 이동하고, 권한 당신이에 대해 당신의 카메라를 확인 응용 프로그램은 또한 중포 기지 콘솔 로 이동 규칙이 !=null 규칙에만 작동하기 때문에 앱에 인증 방법이 때 그들과 동일한 다음 널 (null) 귀하의 응용 프로그램을 실행하기 위해 만든 null로 동일하지, 경우 규칙을 확인

관련 문제