Add PDF functionality in Android
This guide helps you integrate Nutrient Android SDK into either a new or existing Android project, using Gradle or manual AAR integration. It also shows how to display a PDF using either PdfActivity or Jetpack Compose’s DocumentView.
Prefer to jump straight to code? View the example repo on GitHub.
Explore SDK capabilities through our interactive demos.
Creating or opening your project
If you already have an Android project, open it in Android Studio. Otherwise, create a new one by following the steps below.
- Open Android Studio, select File > New > New Project.
- Choose the Empty Views Activity or Empty Activity (Jetpack Compose) template.
- Set your app name (for example, Nutrient Demo), desired save location, language (for example, Kotlin), and minimum SDK (21+ recommended).
- Click Finish to create the project.
Adding Nutrient to your project
You can add the SDK using Gradle (recommended) or manually using an AAR file. The Gradle method is outlined below.
- In the - settings.gradle.ktsfile at the root of your project, add the Nutrient Maven repository:dependencyResolutionManagement {repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS)repositories {google()mavenCentral()maven {url = uri("https://my.nutrient.io/maven")}}}
- In your - app/build.gradle.ktsfile, add the Nutrient dependency:dependencies {implementation("io.nutrient:nutrient:10.7.0")}
Configuring your build
Ensure the following configuration in app/build.gradle.kts. Note that compileSdk and targetSdk should be set to the latest available versions:
android {    compileSdk = <latest>
    defaultConfig {        applicationId = "com.example.app"        minSdk = 21        targetSdk = <latest>    }
    compileOptions {        sourceCompatibility = JavaVersion.VERSION_17        targetCompatibility = JavaVersion.VERSION_17    }
    kotlinOptions {        jvmTarget = "17"    }}With
minSdkset to21, your app is available on more than 99.4 percent(opens in a new tab) of Android devices (as of June 2025).
Displaying a PDF
You can display PDFs using either PdfActivity (classic view system) or DocumentView (Jetpack Compose).
- Copy a PDF file to - src/main/assets/my-document.pdf.
- Add - PdfActivityto- AndroidManifest.xml:<application>...<activityandroid:name="com.pspdfkit.ui.PdfActivity"android:windowSoftInputMode="adjustNothing" /></application>
- Launch it in your - MainActivity.kt:class MainActivity : AppCompatActivity() {override fun onCreate(savedInstanceState: Bundle?) {super.onCreate(savedInstanceState)setContentView(R.layout.activity_main)val uri = Uri.parse("file:///android_asset/my-document.pdf")val config = PdfActivityConfiguration.Builder(this).build()PdfActivity.showDocument(this, uri, config)}}
- Ensure you’re using - AppCompatActivityand a compatible Compose theme:...<activityandroid:name=".MainActivity"...android:theme="@style/Theme.AppCompat.NoActionBar"></activity><application>
- Launch - DocumentViewinside your Compose user interface (UI):class MainActivity : AppCompatActivity() {override fun onCreate(savedInstanceState: Bundle?) {super.onCreate(savedInstanceState)setContent {Surface {val uri = Uri.parse("file:///android_asset/my-document.pdf")DocumentView(documentUri = uri,modifier = Modifier.fillMaxSize())}}}}
The assets folder is read-only. For writing capabilities, copy PDFs to a writable directory. For more information, refer to our guide on opening PDFs from URLs.
Next steps
- Customize PdfActivity to match your UI
- Use PdfFragmentfor modular PDF display
- Load PDFs from custom sources
- Add collaboration with Instant
- Add OCR support
- Use DocumentStatewithDocumentViewfor interaction hooks.
 
  
  
  
 