Skip to main content

How to Capture or Upload Image from Gallery using File Provider

We often Pick images from Gallery to upload in android app but sometime when tried in Android version greater than Marshmallow it throw an error that it does not have permission to Uri. So here i am telling you how to use concept of File provider in Android Version after Android Marshmallow .So lets Start from beginning :-


Step 1:

in AndroidManifest.xml add these Permissions

<uses-permission android:name="android.permission.CAMERA" />
<uses-feature android:name="android.hardware.camera" />
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />


Step 2:

in Same AndroidManifest.xml file add

 <provider
            android:name="android.support.v4.content.FileProvider"
            android:authorities="${applicationId}.provider"
            android:exported="false"
            android:grantUriPermissions="true">
            <meta-data
                android:name="android.support.FILE_PROVIDER_PATHS"
                android:resource="@xml/provider_path" />
        </provider>


Step 3:

Create an xml Folder Under res and create a file  provider_path.xml and paste this code inside

<?xml version="1.0" encoding="utf-8"?>
<paths>
    <external-path
        name="external_files"
        path="." />
</paths>

Step 4:

in  Java file add these code to upload image from gallery or capture from camera

 Button btproof;  
 btproof.setOnClickListener(new View.OnClickListener() {  
   @Override  
   public void onClick(View v) {  
     selectImage();  
   }  
 });  
 private void selectImage() {  
   if (ContextCompat.checkSelfPermission(ctx, android.Manifest.permission.READ_EXTERNAL_STORAGE) != PackageManager.PERMISSION_GRANTED) {  
     if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {  
       givePermission(); // Take Real time permission from user to access camera and media files  
     }  
   } else {  
     final CharSequence[] options = {  
       "Take From Camera",  
       "Choose from Gallery",  
       "Cancel"  
     };  
     AlertDialog.Builder builder = new AlertDialog.Builder(this);  
     builder.setTitle("Pick a Proof !");  
     builder.setItems(options, new DialogInterface.OnClickListener() {  
       @Override  
       public void onClick(DialogInterface dialog, int item) {  
         if (options[item].equals("Take From Camera"))  
         {  
           Intent intent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE);  
           File f = new File(Environment.getExternalStorageDirectory(), "temp.jpg");  
           if (Build.VERSION.SDK_INT > Build.VERSION_CODES.M) {  
             intent.putExtra(MediaStore.EXTRA_OUTPUT, FileProvider.getUriForFile(ctx, ctx.getApplicationContext().getPackageName() + ".provider", f));  
             intent.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP | Intent.FLAG_ACTIVITY_NEW_TASK);  
             intent.addFlags(Intent.FLAG_GRANT_READ_URI_PERMISSION);  
             startActivityForResult(intent, 1);  
           } else {  
             intent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE);  
             f = new File(Environment.getExternalStorageDirectory(), "temp.jpg");  
             intent.putExtra(MediaStore.EXTRA_OUTPUT, Uri.fromFile(f));  
             startActivityForResult(intent, 1);  
           }  
         } else if (options[item].equals("Choose from Gallery"))  
         {  
           Intent intent = new Intent(Intent.ACTION_PICK, MediaStore.Images.Media.EXTERNAL_CONTENT_URI);  
           startActivityForResult(intent, 2);  
         } else if (options[item].equals("Cancel")) {  
           btproof.setText("Select Photo ");  
           dialog.dismiss();  
         }  
       }  
     });  
     builder.show();  
   }  
 }  
 public String getStringImage(Bitmap bmp) {  
   ByteArrayOutputStream baos = new ByteArrayOutputStream();  
   bmp.compress(Bitmap.CompressFormat.JPEG, 100, baos);  
   byte[] imageBytes = baos.toByteArray();  
   String encodedImage = Base64.encodeToString(imageBytes, Base64.DEFAULT);  
   return encodedImage;  
 }  
 public void givePermission() {  
   //tedpermission library for real time android permissions  
   PermissionListener permissionlistener = new PermissionListener() {  
     @Override  
     public void onPermissionGranted() {  
     }  
     @Override  
     public void onPermissionDenied(ArrayList deniedPermissions) {  
       Toast.makeText(this, "Permission Denied\n" + deniedPermissions.toString(), Toast.LENGTH_SHORT).show();  
     }  
   };  
   new TedPermission(this)  
     .setPermissionListener(permissionlistener)  
     .setDeniedMessage("If you reject permission,you can not use this service\n\nPlease turn on permissions at [Setting] > [Permission]")  
     .setPermissions(Manifest.permission.READ_EXTERNAL_STORAGE, Manifest.permission.CAMERA)  
     .check();  
 }  
 @Override  
 public void onActivityResult(int requestCode, int resultCode, Intent data) {  
     super.onActivityResult(requestCode, resultCode, data);  
     if (data != null) {  
       if (requestCode == 1) {  
         File f = new File(Environment.getExternalStorageDirectory().toString());  
         for (File temp: f.listFiles()) {  
           if (temp.getName().equals("temp.jpg")) {  
             f = temp;  
             break;  
           }  
         }  
         try {  
           Bitmap bitmap;  
           BitmapFactory.Options bitmapOptions = new BitmapFactory.Options();  
           bitmap = BitmapFactory.decodeFile(f.getAbsolutePath(), bitmapOptions);  
           ivproof.setImageBitmap(bitmap);  
           imageString = getStringImage(bitmap);  
           Toast.makeText(ctx, "Image=" + imageString, Toast.LENGTH_SHORT).show();  
           btproof.setText("Uploaded");  
         } catch (Exception e) {  
           e.printStackTrace();  
         }  
       }  
       if (requestCode == 2) {  
         Uri selectedImage = data.getData();  
         String[] filePath = {  
           MediaStore.Images.Media.DATA  
         };  
         Cursor c = this.getContentResolver().query(selectedImage, filePath, null, null, null);  
         c.moveToFirst();  
         int columnIndex = c.getColumnIndex(filePath[0]);  
         String picturePath = c.getString(columnIndex);  
         c.close();  
         Bitmap thumbnail = (BitmapFactory.decodeFile(picturePath));  
         Log.d("path of image", picturePath + "");  
         imageString = getStringImage(thumbnail);  
         ivproof.setImageBitmap(thumbnail);  
         // Toast.makeText(ctx,"Image="+imageString,Toast.LENGTH_SHORT).show();  
         btproof.setText("Uploaded");  
       } else {  
         Toast.makeText(this, "Something went wrong...", Toast.LENGTH_SHORT).show();  
       }  
     }  
     @Override  
     protected void onPause() {  
       super.onPause();  
       if (camera != null) {  
         camera.release(); // release the camera for other applications  
         camera = null;  
       }  
     }  

that 's all .





Comments

Popular posts from this blog

How to Download Apk file from Url and Install Programmatically

In this post we learn about download apk file from server or website and then install it Programmatically in Phone. Sometimes we have to download external apk file from server and then install if downloading successfully finished.For this we use AsyncTask class  for background process. So here is Code Snippet for this task.Lets Start :- Before this we have to add these Permissions in Manifest.xml file : <uses-permission android:name="android.permission.INTERNET" /> <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" /> <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" /> DownloadNewVersion.java class DownloadNewVersion extends AsyncTask<String,Integer,Boolean> { @Override protected void onPreExecute() { super.onPreExecute(); bar = new ProgressDialog(getActivity()); bar.setCancelable(false); bar.setMessage("Downl...

Working with Android 11 (Changes and Security Features)

 Hello everyone , I am here with new article which is hot topic nowadays "Android 11" .The stable version of Android.  Android 11 is the eleventh major release and 18th version of Android, the mobile operating system developed by the Open Handset Alliance led by Google. It was released on September 8, 2020.It is comes with many security features and other features as well . And it is now compulsory in play store  to upload new apps with API lavel 30 which is compatible with Android 11 and from November onwards old apps also have to update with API 30 .Some other guidelines you can check out from here . Play Store Guidelines So its clear that we have to update our apps with API level 30 .But Android 11 comes with some changes as well which we have to do in our projects. For example from Android developer site "Android 11 (API level 30) further enhances the platform, giving better protection to app and user data on external storage. ". Scoped storage enforcement: Apps...

How to sort a list in ascending order and Add header by the first letter in the RecyclerView in Android

Hello Forks ! Hope you are doing well. In this tutorial we will understand how to sort a list of data, it could be any data like bank names , places names etc. in ascending order with a header which grouped the same type of data under it. For example we have a list of banks data and we want to group all banks starting with 'A' character in single unit and so on. So without taking too much time  let's move to the coding part and understand how we can achieve this. Step 1 : Create a Model class Named Bank.java public class Bank { private String name; public Bank (String name) { this .name = name; } public String getName () { return name; } } Step 2 : Sort the List of Banks with this Method import java.util.Collections; import java.util.Comparator; import java.util.List; public void sortBankList (List<Bank> bankList) { Collections.sort(bankList, new Comparator <Bank>() { @Override pub...