Android SDK for ImageKit.io which implements client-side upload and URL generation for use inside an Android application.
ImageKit is a complete image optimization and transformation solution that comes with an image CDN and media storage. It can be integrated with your existing infrastructure - storages like AWS S3, web servers, your CDN and custom domain names, allowing you to deliver optimized images in minutes with minimal code changes.
ImageKit Android SDK allows you to use real-time image resizing, optimization, and file uploading in the client-side.
The library requires Android version 5.0.0 (API level 21 - Lollipop) or above.
In your root build.gradle file, add:
allprojects {
repositories {
...
maven { url "https://jitpack.io" }
}
}
In the module build.gradle file, add:
implementation 'com.github.imagekit-developer:imagekit-android:<VERSION>'
urlEndpoint
is the required parameter. You can get the value of URL-endpoint from your ImageKit dashboard - https://imagekit.io/dashboard#url-endpoints.
publicKey
and authenticationEndpoint
parameters are optional and only needed if you want to use the SDK for client-side file upload. You can get these parameters from the developer section in your ImageKit dashboard - https://imagekit.io/dashboard#developers.
transformationPosition
is optional. The default value for this parameter is TransformationPosition.PATH
. Acceptable values are TransformationPosition.PATH
& TransformationPosition.QUERY
Note: Do not include your Private Key in any client side code, including this SDK or its initialization.
// In kotlin
import com.imagekit.android.ImageKit;
ImageKit.init(
context = applicationContext,
publicKey = "your_public_api_key",
urlEndpoint = "https://ik.imagekit.io/your_imagekit_id",
transformationPosition = TransformationPosition.PATH,
authenticationEndpoint = "your_authentication_endpoint"
)
// In Java
import com.imagekit.android.ImageKit;
ImageKit.Companion.init(
getApplicationContext(),
"your_public_api_key",
"https://ik.imagekit.io/your_imagekit_id",
TransformationPosition.PATH,
"your_authentication_endpoint"
);
// Kotlin
// https://ik.imagekit.io/your_imagekit_id/default-image.jpg?tr=h-400.00,ar-3-2
ImageKit.getInstance()
.url(
path = "default-image.jpg",
transformationPosition = TransformationPosition.QUERY
)
.height(400f)
.aspectRatio(3, 2)
.create()
// Java
// https://ik.imagekit.io/your_imagekit_id/default-image.jpg?tr=h-400.00,ar-3-2
ImageKit.Companion.getInstance()
.url(
"default-image.jpg",
TransformationPosition.QUERY
)
.height(400f)
.aspectRatio(3, 2)
.create()
// https://ik.imagekit.io/your_imagekit_id/medium_cafe_B1iTdD0C.jpg?tr=oi-logo-white_SJwqB4Nfe.png,ox-10,oy-20
ImageKit.getInstance()
.url(
src = https://ik.imagekit.io/your_imagekit_id/medium_cafe_B1iTdD0C.jpg",
transformationPosition = TransformationPosition.PATH
)
.overlayImage("logo-white_SJwqB4Nfe.png")
.overlayPosX(10)
.overlayPosY(20)
.create()
// https://ik.imagekit.io/your_imagekit_id/medium_cafe_B1iTdD0C.jpg?tr=oi-logo-white_SJwqB4Nfe.png,ox-10,oy-20
ImageKit.Companion.getInstance()
.url(
"https://ik.imagekit.io/your_imagekit_id/medium_cafe_B1iTdD0C.jpg",
TransformationPosition.PATH
)
.overlayImage("logo-white_SJwqB4Nfe.png")
.overlayPosX(10)
.overlayPosY(20)
.create()
// https://ik.imagekit.io/your_imagekit_id/plant.jpeg?tr=w-400,ot-Hand with a green plant,otc-264120,ots-30,ox-10,oy-10
ImageKit.getInstance()
.url(src = "https://ik.imagekit.io/your_imagekit_id/plant.jpeg?tr=oi-logo-white_SJwqB4Nfe.png,ox-10,oy-20")
.addCustomTransformation("w", "400")
.overlayText("Hand with a green plant")
.overlayTextColor("264120")
.overlayTextSize(30)
.overlayPosX(10)
.overlayPosY(10)
.create()
// Java
// https://ik.imagekit.io/your_imagekit_id/plant.jpeg?tr=w-400,ot-Hand with a green plant,otc-264120,ots-30,ox-10,oy-10
ImageKit.Companion.getInstance()
.url("https://ik.imagekit.io/your_imagekit_id/plant.jpeg?tr=oi-logo-white_SJwqB4Nfe.png,ox-10,oy-20")
.addCustomTransformation("w", "400")
.overlayText("Hand with a green plant")
.overlayTextColor("264120")
.overlayTextSize(30)
.overlayPosX(10)
.overlayPosY(10)
.create()
// Kotlin
ImageKit.getInstance().uploader().uploadImage(
file = bitmap!!
, fileName = filename
, useUniqueFilename = false
, tags = arrayOf("nice", "copy", "books")
, folder = "/dummy/folder/"
, imageKitCallback = this
)
// Java
ImageKit.Companion.getInstance().uploader().uploadImage(
bitmap,
filename,
false, // useUniqueFilename
new String[]{"nice", "copy", "books"}, // tags,
"/dummy/folder/",
imageKitCallback
)
// Kotlin
ImageKit.getInstance().uploader().upload(
file = "https://ik.imagekit.io/demo/img/default-image.jpg"
, fileName = filename
, useUniqueFilename = false
, tags = arrayOf("nice", "copy", "books")
, folder = "/dummy/folder/"
, imageKitCallback = this
)
// Java
ImageKit.Companion.getInstance().uploader().upload(
"https://ik.imagekit.io/demo/img/default-image.jpg",
filename,
false, // useUniqueFilename
new String[]{"nice", "copy", "books"}, // tags,
"/dummy/folder/",
imageKitCallback
)
// Kotlin
ImageKit.getInstance().uploader().upload(
file = file!!
, fileName = file!!.name
, useUniqueFilename = true
, tags = arrayOf("nice", "copy", "books")
, folder = "/dummy/folder/"
, imageKitCallback = this
)
// Java
ImageKit.Companion.getInstance().uploader().upload(
file,
filename,
false, // useUniqueFilename
new String[]{"nice", "copy", "books"}, // tags,
"/dummy/folder/",
imageKitCallback
)
- The official step by step iOS quick start guide - https://docs.imagekit.io/getting-started/quickstart-guides/ios
- You can also run the demo application in sample folder.
The library includes 3 Primary Classes:
ImageKit
for defining options likeurlEndpoint
,publicKey
orauthenticationEndpoint
for the application to use.ImageKitURLConstructor
for constructing image urls.ImageKitUploader
for client-side file uploading.
In order to use the SDK, you need to provide it with a few configuration parameters.
// In kotlin
import com.imagekit.android.ImageKit;
ImageKit.init(
context = applicationContext,
publicKey = "your_public_api_key",
urlEndpoint = "https://ik.imagekit.io/your_imagekit_id",
transformationPosition = TransformationPosition.PATH,
authenticationEndpoint = "http://www.yourserver.com/auth"
)
// In Java
import com.imagekit.android.ImageKit;
ImageKit.Companion.init(
getApplicationContext(),
"your_public_api_key",
"https://ik.imagekit.io/your_imagekit_id",
TransformationPosition.PATH,
"http://www.yourserver.com/auth"
);
urlEndpoint
is required to use the SDK. You can get URL-endpoint from your ImageKit dashboard - https://imagekit.io/dashboard#url-endpoints.publicKey
andauthenticationEndpoint
parameters are required if you want to use the SDK for client-side file upload. You can get these parameters from the developer section in your ImageKit dashboard - https://imagekit.io/dashboard#developers.transformationPosition
is optional. The default value for this parameter isTransformationPosition.PATH
. Acceptable values areTransformationPosition.PATH
&TransformationPosition.QUERY
Note: Do not include your Private Key in any client-side code.
The ImageKitURLConstructor
is used to create a url that can be used for rendering and manipulating images in real-time. ImageKitURLConstructor
consists of functions that can be chained together to perform transformations.
ImageKitURLConstructor
can be initialized by calling ImageKit.getInstance().url(...)
with a set of parameters defined below.
Parameter | Type | Description |
---|---|---|
urlEndpoint | String | Optional. The base URL to be appended before the path of the image. If not specified, the URL-endpoint specified in the parent IKContext component is used. For example, https://ik.imagekit.io/your_imagekit_id/endpoint/ |
path | String | Conditional. This is the path at which the image exists. For example, /path/to/image.jpg . Either the path or src parameter needs to be specified for URL generation. |
src | String | Conditional. This is the complete URL of an image already mapped to ImageKit. For example, https://ik.imagekit.io/your_imagekit_id/endpoint/path/to/image.jpg . Either the path or src parameter needs to be specified for URL generation. |
transformationPosition | TransformationPosition | Optional. The default value is .PATH that places the transformation string as a URL path parameter. It can also be specified as .QUERY , which adds the transformation string as the URL's query parameter i.e.tr . If you use src parameter to create the URL, then the transformation string is always added as a query parameter. |
The transformations to be applied to the URL can be chained to ImageKit.getInstance().url(...)
. See the list of different tranformations. Different steps of a chained transformation can be added by calling the function chainTransformation
.
// Kotlin
// https://ik.imagekit.io/your_imagekit_id/default-image.jpg?tr=h-400.00,ar-3-2
ImageKit.getInstance()
.url(
path = "default-image.jpg",
transformationPosition = TransformationPosition.QUERY
)
.height(400f)
.aspectRatio(3, 2)
.create()
// Java
// https://ik.imagekit.io/your_imagekit_id/default-image.jpg?tr=h-400.00,ar-3-2
ImageKit.Companion.getInstance()
.url(
"default-image.jpg",
TransformationPosition.QUERY
)
.height(400f)
.aspectRatio(3, 2)
.create()
More Examples can be found in URLGenerationTests.kt
The complete list of transformations supported and their usage in ImageKit can be found here. The SDK provides a function for each transformation parameter, making the code simpler and readable. If a transformation is supported in ImageKit, but if a name for it cannot be found in the table below, then use the addCustomTransformation
function and pass the transformation code from ImageKit docs as the first parameter and value as the second parameter. For example - .addCustomTransformation("w", "400")
Expand
Supported Transformation Name | Transformation Function Prototypes | Translates to parameter |
---|---|---|
height | height(height: Int) | h |
width | width(width: Int) | w |
aspectRatio | aspectRatio(width: Int, height: Int) | ar |
quality | quality(quality: Int) | q |
crop | crop(cropType: CropType) | c |
cropMode | cropMode(cropMode: CropMode) | cm |
x, y | focus(x: Int, y: Int) | x, y |
focus | focus(focusType: FocusType) | fo |
format | format(format: Format) | f |
radius | radius(radius: Int) | r |
background | background(backgroundColor: String) | bg |
border | border(borderWidth: Int, borderColor: String) | b |
rotation | rotation(rotation: Rotation) | rt |
blur | blur(blur: Int) | bl |
named | named(namedTransformation: String) | n |
overlayX | overlayX(overlayX: Int) | ox |
overlayY | overlayY(overlayY: Int) | oy |
overlayFocus | overlayFocus(overlayFocus: OverlayFocusType) | ofo |
overlayHeight | overlayHeight(overlayHeight: Int) | oh |
overlayWidth | overlayWidth(overlayWidth: Int) | ow |
overlayImage | overlayImage(overlayImage: String) | oi |
overlayImageTrim | overlayImageTrim(overlayImageTrim: Boolean) | oit |
overlayImageAspectRatio | overlayImageAspectRatio(width: Int, height: Int) | oiar |
overlayImageBackground | overlayImageBackground(overlayImageBackground: String) | oibg |
overlayImageBorder | overlayImageBorder(borderWidth: Int, borderColor: String) | oib |
overlayImageDPR | overlayImageDPR(dpr: Float) | oidpr |
overlayImageQuality | overlayImageQuality(quality: Int) | oiq |
overlayImageCropping | overlayImageCropping(cropMode: CropMode) | oic |
overlayText | overlayText(overlayText: String) | ot |
overlayTextFontSize | overlayTextFontSize(overlayTextFontSize: Int) | ots |
overlayTextFontFamily | overlayTextFontFamily(overlayTextFontFamily: OverlayTextFont) | otf |
overlayTextColor | overlayTextColor(overlayTextColor: String) | otc |
overlayTextTransparency | overlayTextTransparency(overlayTextTransparency: Int) | oa |
overlayAlpha | overlayAlpha(overlayAlpha: Int) | oa |
overlayTextTypography | overlayTextTypography(overlayTextTypography: OverlayTextTypography) | ott |
overlayBackground | overlayBackground(overlayBackground: String) | obg |
overlayTextEncoded | overlayTextEncoded(overlayTextEncoded: String) | ote |
overlayTextWidth | overlayTextWidth(width: Int) | otw |
overlayTextBackground | overlayTextBackground(overlayTextColor: String) | otbg |
overlayTextPadding | overlayTextPadding(overlayTextPadding: String) overlayTextPadding(overlayTextPadding: Int) overlayTextPadding(verticalPadding: Int, horizontalPadding: Int) overlayTextPadding(topPadding: Int, horizontalPadding: Int, bottomPadding: Int) overlayTextPadding(topPadding: Int, rightPadding: Int, bottomPadding: Int, leftPadding: Int) |
otp |
overlayTextInnerAlignment | overlayTextInnerAlignment(overlayTextInnerAlignment: OverlayTextInnerAlignment) | otia |
overlayRadius | overlayRadius(radius: Int) | or |
progressive | progressive(flag: Boolean) | pr |
lossless | lossless(flag: Boolean) | lo |
trim | trim(flag: Boolean) trim(value: Int) |
t |
metadata | metadata(flag: Boolean) | md |
colorProfile | colorProfile(flag: Boolean) | cp |
defaultImage | defaultImage(defaultImage: String) | di |
dpr | dpr(dpr: Float) | dpr |
effectSharpen | effectSharpen(value: Int = 0) | e-sharpen |
effectUSM | effectUSM( radius: Float, sigma: Float, amount: Float, threshold: Float) | e-usm |
effectContrast | effectContrast(flag: Boolean) | e-contrast |
effectGray | effectGray(flag: Boolean) | e-grayscale |
original | original(flag: Boolean) | orig |
The SDK provides a simple interface using the ImageKit.getInstance().uploader().upload(...)
method to upload files to the ImageKit Media Library. It accepts all the parameters supported by the ImageKit Upload API.
Make sure that you have specified authenticationEndpoint
during SDK initialization. The SDK makes an HTTP GET request to this endpoint and expects a JSON response with three fields i.e. signature
, token
, and expire
.
Learn how to implement authenticationEndpoint on your server.
The ImageKit.getInstance().uploader().upload(...)
accepts the following parameters
Parameter | Type | Description |
---|---|---|
file | Binary / Bitmap / String | Required. |
fileName | String | Required. If not specified, the file system name is picked. |
useUniqueFileName | Boolean | Optional. Accepts true of false . The default value is true . Specify whether to use a unique filename for this file or not. |
tags | Array of string | Optional. Set the tags while uploading the file e.g. ["tag1","tag2"] |
folder | String | Optional. The folder path (e.g. /images/folder/ ) in which the file has to be uploaded. If the folder doesn't exist before, a new folder is created. |
isPrivateFile | Boolean | Optional. Accepts true of false . The default value is false . Specify whether to mark the file as private or not. This is only relevant for image type files |
customCoordinates | String | Optional. Define an important area in the image. This is only relevant for image type files. To be passed as a string with the x and y coordinates of the top-left corner, and width and height of the area of interest in format x,y,width,height . For example - 10,10,100,100 |
responseFields | Array of string | Optional. Values of the fields that you want upload API to return in the response. For example, set the value of this field to ["tags", "customCoordinates", "isPrivateFile"] to get value of tags , customCoordinates , and isPrivateFile in the response. |
imageKitCallback | ImageKitCallback | Required. |
Sample Usage
ImageKit.getInstance().uploader().upload(
file = image,
fileName = "sample-image.jpg",
useUniqueFilename = true,
tags = ["demo"],
folder = "/",
isPrivateFile = false,
customCoordinates = "",
responseFields = "",
imageKitCallback = object: ImageKitCallback {
override fun onSuccess(uploadResponse: UploadResponse) {
// Handle Success Response
}
override fun onError(uploadError: UploadError) {
// Handle Upload Error
}
}
)
For any feedback or to report any issues or general implementation support please reach out to [email protected]
Released under the MIT license.