Canva provides an SDK for adding the Canva Button to Android apps. You can use this SDK to launch the Canva editor from within your app.
Here's how it works:
Your app opens the Canva editor in a Custom Tab(opens in a new tab or window). The user then creates or edits a design. When the user clicks the Publish button, your app downloads the user's design as an image file.
This tutorial series explains how to add the Canva Button to an empty Android app. Once you understand the workflow, adapt the steps to add the Canva Button to your existing app.
Prerequisites
This tutorial assumes you have an API key to use the Canva Button. If you don't have one, sign up for an API key.
Step 1: Create a project in Android Studio
You can skip this step if you're adding the Canva Button to an existing app.
- Open Android Studio.
- Select Create New Project.
- Select Empty Activity.
- Select Next.
- (Optional) Choose a Name for the application.
- (Optional) Choose a Package name for the application.
- Select Language > Kotlin.
- Select Minimum SDK > API 16.
- Select Finish.
This is the default MainActivity.kt
file:
package com.example.myapplicationimport androidx.appcompat.app.AppCompatActivityimport android.os.Bundleclass MainActivity : AppCompatActivity() {override fun onCreate(savedInstanceState: Bundle?) {super.onCreate(savedInstanceState)setContentView(R.layout.activity_main)}}
Step 2: Add the Android SDK to the project
Maven
-
Add the repository source to the root's
build.gradle
file:allprojects {repositories {// ...maven { url "https://sdk.canva.com/nativebutton/android" }}}GRADLE -
Copy the following statement into the
dependencies
section of the app'sbuild.gradle
file:implementation 'com.canva:design-button:1.3.0'GRADLE
If you're using the china
version of the SDK, replace https://sdk.canva.com/nativebutton/android
with https://sdk.canva.cn/nativebutton/android
and com.canva:design-button:1.3.0
with cn.canva:design-button:1.3.0
.
Manual
- Download the the Android SDK. You should have received the SDK from Canva as a
.aar
file. There are two versions of the SDK:global
andchina
. Theglobal
version of the SDK connects to canva.com, while thechina
version of the SDK connects to canva.cn. These websites are separate environments, so user's accounts and designs are not shared between them. - Select File > New > New Module....
- Select Import .JAR/.AAR Package.
- Select Next.
- In the File name field, enter the path of the
.aar
file. - Select Finish.
The SDK appears in the Project pane.
- Copy the following statement into the
dependencies
section of the app'sbuild.gradle
file:
implementation project(path: ":canva-button-global-release")
If you're using the china
version of the SDK, replace :canva-button-global-release
with :canva-button-china-release
.
Step 3: Install the dependencies
-
Open the app's
build.gradle
file. -
Copy the following lines into the
dependencies
section:implementation "androidx.appcompat:appcompat:1.2.0"implementation "androidx.browser:browser:1.0.0"GRADLE -
Select Sync now.
Step 4: Set up a URL scheme
The Android SDK uses deep links(opens in a new tab or window) to send information from the Canva editor to the Android SDK. For the SDK to handle deep links, you need a URL scheme. This is a unique value that's tied to your Canva Button API key. Canva should have already provided you with this scheme.
Once you have a URL scheme:
-
Add the following
manifestPlaceholders
property to thedefaultConfig
section of the app'sbuild.gradle
file:manifestPlaceholders = [deeplinkScheme: "URL SCHEME GOES HERE"]GRADLE -
Replace
URL SCHEME GOES HERE
with the Canva-provided URL scheme.
Refer to the Example for a complete code sample.
The Android and iOS SDKs each have their own, distinct URL schemes.
Step 5: Configure the manifest
In the AndroidManifest.xml
file:
-
Add the following property to the
manifest
element:xmlns:tools="http://schemas.android.com/tools"XML -
Add an
android:allowBackup
property to theapplication
element:tools:replace="android:allowBackup"XML
Example
AndroidManifest.xml
<?xml version="1.0" encoding="utf-8"?><manifestxmlns:android="http://schemas.android.com/apk/res/android"xmlns:tools="http://schemas.android.com/tools"package="com.example.myapplication"><applicationandroid:allowBackup="true"android:icon="@mipmap/ic_launcher"android:label="@string/app_name"android:roundIcon="@mipmap/ic_launcher_round"android:supportsRtl="true"android:theme="@style/Theme.MyApplication"tools:replace="android:allowBackup"><activity android:name=".MainActivity"><intent-filter><action android:name="android.intent.action.MAIN" /><category android:name="android.intent.category.LAUNCHER" /></intent-filter></activity></application></manifest>
build.gradle
plugins {id 'com.android.application'id 'kotlin-android'}android {compileSdkVersion 30buildToolsVersion "30.0.2"defaultConfig {applicationId "com.example.myapplication"minSdkVersion 16targetSdkVersion 30versionCode 1versionName "1.0"testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"manifestPlaceholders = [deeplinkScheme: "URL SCHEME GOES HERE"]}buildTypes {release {minifyEnabled falseproguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'}}compileOptions {sourceCompatibility JavaVersion.VERSION_1_8targetCompatibility JavaVersion.VERSION_1_8}kotlinOptions {jvmTarget = '1.8'}}dependencies {implementation project(path: ":canva-button-global-release")implementation "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version"implementation 'androidx.core:core-ktx:1.3.2'implementation 'androidx.appcompat:appcompat:1.2.0'implementation "androidx.browser:browser:1.0.0"implementation 'com.google.android.material:material:1.2.1'implementation 'androidx.constraintlayout:constraintlayout:2.0.4'testImplementation 'junit:junit:4.+'androidTestImplementation 'androidx.test.ext:junit:1.1.2'androidTestImplementation 'androidx.test.espresso:espresso-core:3.3.0'}
MainActivity.kt
package com.example.myapplicationimport androidx.appcompat.app.AppCompatActivityimport android.os.Bundleclass MainActivity : AppCompatActivity() {override fun onCreate(savedInstanceState: Bundle?) {super.onCreate(savedInstanceState)setContentView(R.layout.activity_main)}}