Android Development: Making Image Capture Easy

Dive into the world of Android development with our latest blog post! Learn how to effortlessly integrate and display images from both the camera and gallery into your app. From permission management to displaying images in various views, our guide takes you through the process step by step. Dive in and explore the possibilities of image capture in Android!

Introduction

In today’s tutorial, we’ll develop an application that selects an image from either the camera or the gallery and displays it in an ImageView. Note: The code below works flawlessly for versions before Android Nougat.

Permissions

With the advent of Android Marshmallow, permissions need to be implemented at runtime. Add the following permissions to the AndroidManifest.xml file above the application tag.

<uses-feature
android:name="android.hardware.camera"
android:required="false" />
<uses-feature
android:name="android.hardware.camera.autofocus"
android:required="false" />
<uses-feature
android:name="android.hardware.camera.flash"
android:required="false" />
<uses-permission android:name="android.permission.CAMERA" />
<uses-permission android:name="ANDROID.PERMISSION.READ_EXTERNAL_STORAGE" />

By adding android.hardware.camera, the Play Store recognizes and prevents the installation of the application on devices without a camera. Intent is the standard way to delegate actions to another application. To launch the native camera, the Intent requires android.provider.MediaStore.ACTION_IMAGE_CAPTURE. To select an image from the gallery, the Intent requires the following argument: Intent.ACTION_GET_CONTENT. In this tutorial, we invoke an image selector that allows us to choose an image from the camera or gallery and display it in a circular ImageView and a normal ImageView. Add the following dependency in the build.gradle file: ‘compile ‘de.hdodenhof:circleimageview:2.1.0’.

Project Structure for Android Image Capture

Android Image Capture Code

Layout

The layout for the activity_main.xml remains the same, except for the icon change for the FAB button to @android:drawable/ic_menu_camera. The content_main.xml content is as follows:

<!-- Insert your XML code here -->

MainActivity.java

The code for MainActivity.java is as follows:

Conclusions

Here are some conclusions that can be drawn from the above code:

  • We need to request camera permissions at runtime when the user starts the activity.
  • Since we’re starting the Intent to get a result, we need to call startActivityForResult with the relevant arguments.
  • Instead of using a dialog to separately invoke the camera and gallery intents, we’ve used a method getPickImageChooserIntent()that creates a single selection intent for all camera and gallery intents (note the document intent). Intent.EXTRA_INITIAL_INTENTS is used to add the various application intents in one place.
  • For the camera intent, MediaStore.EXTRA_OUTPUT is passed as an extra to specify the image storage path. Without this, you’ll only get a low-resolution image back.
  • The URI path for the image returned by the camera is obtained in the getCaptureImageOutputUri() method.
  • TheonActivityResult essentially returns a URI for the image. Some devices return the bitmap as data.getExtras().get(“data”).
  • When an image is captured, returning to the camera screen restarts the activity, nullifying the URI stored from the getCaptureImageOutputUri() method. Therefore, it’s important that we save and restore this URI using onSaveInstanceState() and onRestoreInstanceState().
  • The bitmap is retrieved from the URI in the following code line: myBitmap = MediaStore.Images.Media.getBitmap(this.getContentResolver(), picUri);
  • Devices like the Samsung Galaxy are known to capture the image in landscape mode. If the image is retrieved and displayed without modifications, it may appear in the wrong orientation. Hence, we’ve called the rotateImageIfRequired(myBitmap, picUri) method.
  • ExifInterface is a class for reading and writing Exif tags in a JPEG file or a RAW image file.
  • Finally, we call the getResizedBitmap() method to scale the bitmap according to width or height (whichever is larger) and set the image to the ImageView using setImageBitmap.

Source: digitalocean.com

Create a Free Account

Register now and get access to our Cloud Services.

Posts you might be interested in:

Moderne Hosting Services mit Cloud Server, Managed Server und skalierbarem Cloud Hosting für professionelle IT-Infrastrukturen

How to Manage User Groups in Linux Step-by-Step

Linux file permissions with this comprehensive guide. Understand how to utilize chmod and chown commands to assign appropriate access rights, and gain insights into special permission bits like SUID, SGID, and the sticky bit to enhance your system’s security framework.

Moderne Hosting Services mit Cloud Server, Managed Server und skalierbarem Cloud Hosting für professionelle IT-Infrastrukturen

Apache Airflow on Ubuntu 24.04 with Nginx and SSL

Apache, Tutorial

This guide provides step-by-step instructions for installing and configuring the Cohere Toolkit on Ubuntu 24.04. It includes environment preparation, dependency setup, and key commands to run language models and implement Retrieval-Augmented Generation (RAG) workflows. Ideal for developers building AI applications or integrating large language models into their existing projects.