---
description: Unofficial Capacitor plugin for Google ML Kit Face Detection SDK to detect faces in images with support for Android and iOS.
title: Capacitor ML Kit Face Detection Plugin for Android & iOS - Capawesome
image: https://capawesome.io/docs/assets/images/social/plugins/mlkit/face-detection.png
---

[ Skip to content](#capacitor-mlkitface-detection) 

[ 🎉 Introducing **Capawesome Platform** — one platform for Live Updates, Native Builds, App Store Publishing, and Insider SDKs.](https://capawesome.io) 

* [  Formbricks ](/docs/plugins/formbricks/)
* [  Geocoder ](/docs/plugins/geocoder/)
* [  Google Sign-In ](/docs/plugins/google-sign-in/)
* [  libSQL ](/docs/plugins/libsql/)
* [  Live Update ](/docs/plugins/live-update/)
* [  Managed Configurations ](/docs/plugins/managed-configurations/)
* [  Media Session ](/docs/plugins/media-session/)
* [  ML Kit ](/docs/plugins/mlkit/)
* [  iOS ](#ios)
* [  Configuration ](#configuration)
* [  Demo ](#demo)
* [  Usage ](#usage)
* [  API ](#api)
* [  Enums ](#enums)
* [  Terms & Privacy ](#terms-privacy)
* [  Changelog ](#changelog)
* [  License ](#license)
* [  Face Mesh Detection ](/docs/plugins/mlkit/face-mesh-detection/)
* [  Selfie Segmentation ](/docs/plugins/mlkit/selfie-segmentation/)
* [  Subject Segmentation ](/docs/plugins/mlkit/subject-segmentation/)
* [  Translation ](/docs/plugins/mlkit/translation/)
* [  NFC ](/docs/plugins/nfc/)
* [  OAuth ](/docs/plugins/oauth/)
* [  Pedometer ](/docs/plugins/pedometer/)
* [  Photo Editor ](/docs/plugins/photo-editor/)
* [  PostHog ](/docs/plugins/posthog/)
* [  Printer ](/docs/plugins/printer/)
* [  Purchases ](/docs/plugins/purchases/)
* [  RealtimeKit ](/docs/plugins/realtimekit/)
* [  Screen Orientation ](/docs/plugins/screen-orientation/)
* [  Screenshot ](/docs/plugins/screenshot/)
* [  Secure Preferences ](/docs/plugins/secure-preferences/)
* [  Speech Recognition ](/docs/plugins/speech-recognition/)
* [  Speech Synthesis ](/docs/plugins/speech-synthesis/)
* [  Share Target ](/docs/plugins/share-target/)
* [  Square Mobile Payments ](/docs/plugins/square-mobile-payments/)
* [  SQLite ](/docs/plugins/sqlite/)
* [  Superwall ](/docs/plugins/superwall/)
* [  Torch ](/docs/plugins/torch/)
* [  Wifi ](/docs/plugins/wifi/)
* [  Zip ](/docs/plugins/zip/)
* [  Cloud ](/docs/cloud/)
* [  Live Updates ](/docs/cloud/live-updates/)
* Advanced
* Integrations
* [  Native Builds ](/docs/cloud/native-builds/)
* [  Configuration ](/docs/cloud/native-builds/configuration/)
* [  Environments ](/docs/cloud/native-builds/environments/)
* Guides
* [  Sample Projects ](/docs/cloud/native-builds/sample-projects/)
* [  Troubleshooting ](/docs/cloud/native-builds/troubleshooting/)
* [  Automations ](/docs/cloud/automations/)
* [  Assist ](/docs/cloud/assist/)
* Account
* Organizations
* [  Organization and User Management ](/docs/cloud/organizations/memberships/)
* [  Single Sign-On (SSO) ](/docs/cloud/organizations/sso/)
* [  Teams ](/docs/cloud/organizations/teams/)
* [  Two-Factor Authentication ](/docs/cloud/organizations/two-factor-authentication/)
* [  Integrations ](/docs/cloud/integrations/)
* [  License Keys ](/docs/cloud/license-keys/)
* [  Webhooks ](/docs/cloud/webhooks/)
* [  Pricing ](https://capawesome.io/pricing/)
* [  FAQ ](/docs/cloud/faq/)
* [  Support ](/docs/cloud/support/)
* [  Contributing ](/docs/contributing/)
* [  LLMs ](/docs/llms/)
* [  Insiders ](/docs/insiders/)
* [  License ](https://capawesome.io/legal/eula/)
* [  Support ](/docs/insiders/support/)
* [  FAQ ](/docs/insiders/faq/)
* [  Blog ](/blog/)
* Categories

* [  iOS ](#ios)
* [  Configuration ](#configuration)
* [  Demo ](#demo)
* [  Usage ](#usage)
* [  API ](#api)
* [  Enums ](#enums)
* [  Terms & Privacy ](#terms-privacy)
* [  Changelog ](#changelog)
* [  License ](#license)

# @capacitor-mlkit/face-detection[¶](#capacitor-mlkitface-detection "Permanent link")

Unofficial Capacitor plugin for [ML Kit Face Detection](https://developers.google.com/ml-kit/vision/face-detection).[1](#fn:1)

[ ![Deliver Live Updates to your Capacitor app with Capawesome Cloud](../../../assets/external/cloud.capawesome.io/assets/banners/cloud-build-and-deploy-capacitor-apps.69628c3f.png) ](https://cloud.capawesome.io/) 

## Newsletter[¶](#newsletter "Permanent link")

Stay up to date with the latest news and updates about the Capawesome, Capacitor, and Ionic ecosystem by subscribing to our [Capawesome Newsletter](https://cloud.capawesome.io/newsletter/).

## Compatibility[¶](#compatibility "Permanent link")

| Plugin Version | Capacitor Version | Status         |
| -------------- | ----------------- | -------------- |
| 8.x.x          | \>=8.x.x          | Active support |
| 7.x.x          | 7.x.x             | Deprecated     |
| 6.x.x          | 6.x.x             | Deprecated     |

## Installation[¶](#installation "Permanent link")

You can use our **AI-Assisted Setup** to install the plugin. Add the [Capawesome Skills](https://github.com/capawesome-team/skills) to your AI tool using the following command:

`[](#%5F%5Fcodelineno-0-1)npx skills add capawesome-team/skills --skill capacitor-plugins
`

Then use the following prompt:

`` [](#%5F%5Fcodelineno-1-1)Use the `capacitor-plugins` skill from `capawesome-team/skills` to install the `@capacitor-mlkit/face-detection` plugin in my project.
 ``

If you prefer **Manual Setup**, install the plugin by running the following commands and follow the platform-specific instructions below:

`[](#%5F%5Fcodelineno-2-1)npm install @capacitor-mlkit/face-detection
[](#%5F%5Fcodelineno-2-2)npx cap sync
`

**Attention**: This plugin **only supports CocoaPods** for iOS dependency management. Swift Package Manager (SPM) is not supported for the ML Kit SDK, see [this comment](https://github.com/googlesamples/mlkit/issues/180#issuecomment-1298964099).

### Android[¶](#android "Permanent link")

#### Dependencies[¶](#dependencies "Permanent link")

You need to add the following meta data **in** the `application` tag in your `AndroidManifest.xml`:

`[](#%5F%5Fcodelineno-3-1)<meta-data android:name="com.google.mlkit.vision.DEPENDENCIES" android:value="face"/>
[](#%5F%5Fcodelineno-3-2)<!-- To use multiple models: android:value="face,model2,model3" -->
`

#### Variables[¶](#variables "Permanent link")

If needed, you can define the following project variable in your app’s `variables.gradle` file to change the default version of the dependency:

* `$mlkitFaceDetectionVersion` version of `com.google.mlkit:face-detection` (default: `16.1.7`)
* `$playServicesMlkitFaceDetectionVersion` version of `com.google.android.gms:play-services-mlkit-face-detection` (default: `17.1.0`)

This can be useful if you encounter dependency conflicts with other plugins in your project.

### iOS[¶](#ios "Permanent link")

#### Minimum Deployment Target[¶](#minimum-deployment-target "Permanent link")

Make sure to set the deployment target in your `ios/App/Podfile` to at least `15.5`:

`[](#%5F%5Fcodelineno-4-1)platform :ios, '15.5'
`

## Configuration[¶](#configuration "Permanent link")

No configuration required for this plugin.

## Demo[¶](#demo "Permanent link")

A working example can be found here: [robingenz/capacitor-mlkit-plugin-demo](https://github.com/robingenz/capacitor-mlkit-plugin-demo)

## Usage[¶](#usage "Permanent link")

`[](#%5F%5Fcodelineno-5-1)import { FaceDetection, PerformanceMode, LandmarkMode, ContourMode, ClassificationMode } from '@capacitor-mlkit/face-detection';
[](#%5F%5Fcodelineno-5-2)
[](#%5F%5Fcodelineno-5-3)const processImage = async () => {
[](#%5F%5Fcodelineno-5-4)  const { faces } = await FaceDetection.processImage({
[](#%5F%5Fcodelineno-5-5)    path: 'path/to/image.jpg',
[](#%5F%5Fcodelineno-5-6)    performanceMode: PerformanceMode.Fast,
[](#%5F%5Fcodelineno-5-7)    landmarkMode: LandmarkMode.All,
[](#%5F%5Fcodelineno-5-8)    contourMode: ContourMode.All,
[](#%5F%5Fcodelineno-5-9)    classificationMode: ClassificationMode.All,
[](#%5F%5Fcodelineno-5-10)    minFaceSize: 0.1,
[](#%5F%5Fcodelineno-5-11)    enableTracking: false,
[](#%5F%5Fcodelineno-5-12)  });
[](#%5F%5Fcodelineno-5-13)  return faces;
[](#%5F%5Fcodelineno-5-14)};
`

## API[¶](#api "Permanent link")

* [processImage(...)](#processimage)
* [Interfaces](#interfaces)
* [Enums](#enums)

### processImage(...)[¶](#processimage "Permanent link")

`[](#%5F%5Fcodelineno-6-1)processImage(options: ProcessImageOptions) => Promise<ProcessImageResult>
`

Detects human faces from the supplied image.

Only available on Android and iOS.

| Param       | Type                                        |
| ----------- | ------------------------------------------- |
| **options** | [ProcessImageOptions](#processimageoptions) |

**Returns:** `Promise<[ProcessImageResult](#processimageresult)>`

**Since:** 5.1.0

---

### Interfaces[¶](#interfaces "Permanent link")

#### ProcessImageResult[¶](#processimageresult "Permanent link")

| Prop      | Type     | Description         | Since |
| --------- | -------- | ------------------- | ----- |
| **faces** | Face\[\] | The detected faces. | 5.1.0 |

#### Face[¶](#face "Permanent link")

Represents a face detected by `FaceDetector`.

| Prop                        | Type             | Description                                                                                                                                                                | Since |
| --------------------------- | ---------------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ----- |
| **bounds**                  | [Rect](#rect)    | Returns the axis-aligned bounding rectangle of the detected face.                                                                                                          | 5.1.0 |
| **landmarks**               | FaceLandmark\[\] | Returns a list of face landmarks.                                                                                                                                          | 5.1.0 |
| **contours**                | FaceContour\[\]  | Returns a list of face contours.                                                                                                                                           | 5.1.0 |
| **trackingId**              | number           | Returns the tracking ID if the tracking is enabled.                                                                                                                        | 5.1.0 |
| **headEulerAngleX**         | number           | Returns the rotation of the face about the horizontal axis of the image. Positive euler X is the face is looking up.                                                       | 5.1.0 |
| **headEulerAngleY**         | number           | Returns the rotation of the face about the vertical axis of the image. Positive euler y is when the face turns toward the right side of the image that is being processed. | 5.1.0 |
| **headEulerAngleZ**         | number           | Returns the rotation of the face about the axis pointing out of the image. Positive euler z is a counter-clockwise rotation within the image plane.                        | 5.1.0 |
| **smilingProbability**      | number           | Returns a value between 0.0 and 1.0 giving a probability that the face is smiling.                                                                                         | 5.1.0 |
| **leftEyeOpenProbability**  | number           | Returns a value between 0.0 and 1.0 giving a probability that the face's left eye is open.                                                                                 | 5.1.0 |
| **rightEyeOpenProbability** | number           | Returns a value between 0.0 and 1.0 giving a probability that the face's right eye is open.                                                                                | 5.1.0 |

#### Rect[¶](#rect "Permanent link")

[Rect](#rect) holds four integer coordinates for a rectangle.

| Prop       | Type   | Description                                          | Since |
| ---------- | ------ | ---------------------------------------------------- | ----- |
| **left**   | number | The X coordinate of the left side of the rectangle.  | 5.1.0 |
| **top**    | number | The Y coordinate of the top of the rectangle.        | 5.1.0 |
| **right**  | number | The X coordinate of the right side of the rectangle. | 5.1.0 |
| **bottom** | number | The Y coordinate of the bottom of the rectangle.     | 5.1.0 |

#### FaceLandmark[¶](#facelandmark "Permanent link")

Represent a face landmark. A landmark is a point on a detected face, such as an eye, nose, or mouth.

| Prop         | Type                          | Description                                                                                | Since |
| ------------ | ----------------------------- | ------------------------------------------------------------------------------------------ | ----- |
| **type**     | [LandmarkType](#landmarktype) | Gets the [FaceLandmark](#facelandmark).[LandmarkType](#landmarktype) type.                 | 5.1.0 |
| **position** | [Point](#point)               | Gets a 2D point for landmark position, where (0, 0) is the upper-left corner of the image. | 5.1.0 |

#### Point[¶](#point "Permanent link")

[Point](#point) holds two coordinates

| Prop  | Type   |
| ----- | ------ |
| **x** | number |
| **y** | number |

#### FaceContour[¶](#facecontour "Permanent link")

Represent a face contour. A contour is a list of points on a detected face, such as the mouth.

| Prop       | Type                        | Description                                                                                         | Since |
| ---------- | --------------------------- | --------------------------------------------------------------------------------------------------- | ----- |
| **type**   | [ContourType](#contourtype) | Gets the [FaceContour](#facecontour).[ContourType](#contourtype) type.                              | 5.1.0 |
| **points** | Point\[\]                   | Gets a list of 2D points for this face contour, where (0, 0) is the upper-left corner of the image. | 5.1.0 |

#### ProcessImageOptions[¶](#processimageoptions "Permanent link")

| Prop                   | Type                                      | Description                                                                                                                                                                                     | Default                 | Since |
| ---------------------- | ----------------------------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ----------------------- | ----- |
| **path**               | string                                    | The local path to the image file.                                                                                                                                                               | 5.1.0                   |       |
| **performanceMode**    | [PerformanceMode](#performancemode)       | Defines options to control accuracy / speed trade-offs in performing face detection.                                                                                                            | PerformanceMode.Fast    | 5.1.0 |
| **landmarkMode**       | [LandmarkMode](#landmarkmode)             | Defines options to enable face landmarks or not.                                                                                                                                                | LandmarkMode.None       | 5.1.0 |
| **contourMode**        | [ContourMode](#contourmode)               | Defines options to enable face contours or not.                                                                                                                                                 | ContourMode.None        | 5.1.0 |
| **classificationMode** | [ClassificationMode](#classificationmode) | Defines options for characterizing attributes such as "smiling" \* and "eyes open".                                                                                                             | ClassificationMode.None | 5.1.0 |
| **minFaceSize**        | number                                    | Sets the smallest desired face size, expressed as a proportion of the width of the head to the image width.                                                                                     | 0.1                     | 5.1.0 |
| **enableTracking**     | boolean                                   | Enables face tracking, which will maintain a consistent ID for each face when processing consecutive frames. Tracking should be disabled for handling a series of non-consecutive still images. | false                   | 5.1.0 |

### Enums[¶](#enums "Permanent link")

#### LandmarkType[¶](#landmarktype "Permanent link")

| Members         | Value | Description                                                                                                                                                                                                            | Since |
| --------------- | ----- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ----- |
| **MouthBottom** | 0     | The center of the subject's bottom lip.                                                                                                                                                                                | 5.1.0 |
| **LeftCheek**   | 1     | The midpoint between the subject's left mouth corner and the outer corner of the subject's left eye. For full profile faces, this becomes the centroid of the nose base, nose tip, left ear lobe and left ear tip.     | 5.1.0 |
| **LeftEar**     | 3     | The midpoint of the subject's left ear tip and left ear lobe.                                                                                                                                                          | 5.1.0 |
| **LeftEye**     | 4     | The center of the subject's left eye cavity.                                                                                                                                                                           | 5.1.0 |
| **MouthLeft**   | 5     | The subject's left mouth corner where the lips meet.                                                                                                                                                                   | 5.1.0 |
| **NoseBase**    | 6     | The midpoint between the subject's nostrils where the nose meets the face.                                                                                                                                             | 5.1.0 |
| **RightCheek**  | 7     | The midpoint between the subject's right mouth corner and the outer corner of the subject's right eye. For full profile faces, this becomes the centroid of the nose base, nose tip, right ear lobe and right ear tip. | 5.1.0 |
| **RightEar**    | 9     | The midpoint of the subject's right ear tip and right ear lobe.                                                                                                                                                        | 5.1.0 |
| **RightEye**    | 10    | The center of the subject's right eye cavity.                                                                                                                                                                          | 5.1.0 |
| **MouthRight**  | 11    | The subject's right mouth corner where the lips meet.                                                                                                                                                                  | 5.1.0 |

#### ContourType[¶](#contourtype "Permanent link")

| Members                | Value | Description                                        | Since |
| ---------------------- | ----- | -------------------------------------------------- | ----- |
| **Face**               | 1     | The outline of the subject's face.                 | 5.1.0 |
| **LeftEyebrowTop**     | 2     | The top outline of the subject's left eyebrow.     | 5.1.0 |
| **LeftEyebrowBottom**  | 3     | The bottom outline of the subject's left eyebrow.  | 5.1.0 |
| **RightEyebrowTop**    | 4     | The top outline of the subject's right eyebrow.    | 5.1.0 |
| **RightEyebrowBottom** | 5     | The bottom outline of the subject's right eyebrow. | 5.1.0 |
| **LeftEye**            | 6     | The outline of the subject's left eye cavity.      | 5.1.0 |
| **RightEye**           | 7     | The outline of the subject's right eye cavity.     | 5.1.0 |
| **UpperLipTop**        | 8     | The top outline of the subject's upper lip.        | 5.1.0 |
| **UpperLipBottom**     | 9     | The bottom outline of the subject's upper lip.     | 5.1.0 |
| **LowerLipTop**        | 10    | The top outline of the subject's lower lip.        | 5.1.0 |
| **LowerLipBottom**     | 11    | The bottom outline of the subject's lower lip.     | 5.1.0 |
| **NoseBridge**         | 12    | The outline of the subject's nose bridge.          | 5.1.0 |
| **NoseBottom**         | 13    | The outline of the subject's nose bridge.          | 5.1.0 |
| **LeftCheek**          | 14    | The center of the left cheek.                      | 5.1.0 |
| **RightCheek**         | 15    | The center of the right cheek.                     | 5.1.0 |

#### PerformanceMode[¶](#performancemode "Permanent link")

| Members      | Value | Description                                                                                                                                                                                                                 | Since |
| ------------ | ----- | --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ----- |
| **Fast**     | 1     | Indicates a preference for speed in the options that may make an accuracy vs. speed trade-off. This will tend to detect fewer faces and may be less precise in determining values such as position, but will run faster.    | 5.1.0 |
| **Accurate** | 2     | Indicates a preference for accuracy in the options that may make an accuracy vs. speed trade-off. This will tend to detect more faces and may be more precise in determining values such as position, at the cost of speed. | 5.1.0 |

#### LandmarkMode[¶](#landmarkmode "Permanent link")

| Members  | Value | Description                                             | Since |
| -------- | ----- | ------------------------------------------------------- | ----- |
| **None** | 1     | Does not perform landmark detection.                    | 5.1.0 |
| **All**  | 2     | Detects [FaceLandmark](#facelandmark) for a given face. | 5.1.0 |

#### ContourMode[¶](#contourmode "Permanent link")

| Members  | Value | Description                                                                                                | Since |
| -------- | ----- | ---------------------------------------------------------------------------------------------------------- | ----- |
| **None** | 1     | Does not perform contour detection.                                                                        | 5.1.0 |
| **All**  | 2     | Detects [FaceContour](#facecontour) for a given face. Note that it would return contours for up to 5 faces | 5.1.0 |

#### ClassificationMode[¶](#classificationmode "Permanent link")

| Members  | Value | Description                                        | Since |
| -------- | ----- | -------------------------------------------------- | ----- |
| **None** | 1     | Does not perform classification.                   | 5.1.0 |
| **All**  | 2     | Performs "eyes open" and "smiling" classification. | 5.1.0 |

## Terms & Privacy[¶](#terms-privacy "Permanent link")

This plugin uses the [Google ML Kit](https://developers.google.com/ml-kit):

* [Terms & Privacy](https://developers.google.com/ml-kit/terms)
* [Android Data Disclosure](https://developers.google.com/ml-kit/android-data-disclosure)
* [iOS Data Disclosure](https://developers.google.com/ml-kit/ios-data-disclosure)

## Changelog[¶](#changelog "Permanent link")

See [CHANGELOG.md](https://github.com/capawesome-team/capacitor-mlkit/blob/main/packages/face-detection/CHANGELOG.md).

## License[¶](#license "Permanent link")

See [LICENSE](https://github.com/capawesome-team/capacitor-mlkit/blob/main/packages/face-detection/LICENSE).

---

1. This project is not affiliated with, endorsed by, sponsored by, or approved by Google LLC or any of their affiliates or subsidiaries. [↩](#fnref:1 "Jump back to footnote 1 in the text")

May 17, 2026 

 Back to top 