Skip to content
This repository has been archived by the owner on May 17, 2022. It is now read-only.

M.1 Add Mlkit

Hadi Tavakoli edited this page Jun 16, 2019 · 2 revisions

Connect your AdobeAIR app to Firebase

  1. Make sure you are considering the minimum requirements for running Firebase.
  2. Install the Firebase SDK.
  3. In the Firebase console, add your app to your Firebase project.

Add MLKit ANE to your app

Before adding MLKit (or any of the other Firebase child ANEs) to your AdobeAIR app, you need to make sure you have setup the firebaseCore.ane correctly in your project. IMPORTANT: To add MLKit, you need to add the required ANEs and Frameworks to your project. These dependencies are explained in details in this document.

MLKIT is still in beta version. For some unknown reason, Mlkit.createVisionImageFromFile is not working!, instead you may use other methods.

Air manifest .xml file
Beside changes you need to make to your manifest .xml file when implementing the firebaseCore.ane you need to add the following changes also to make the MLKit ANE work properly:

<!--
  Optional but recommended: If you use the on-device API, configure your app to automatically
  download the ML model to the device after your app is installed from the Play Store.
-->
<meta-data
  android:name="com.google.firebase.ml.vision.DEPENDENCIES"
  android:value="ocr,face,barcode,label"/>
  <!-- To use only one model: android:value="ocr" -->


<!--
  Change "YOUR.PACKAGE.NAME" to your own applicationID but keep
  ".provider" at the end. [your-app-id].provider
-->
<provider
  android:name="com.myflashlabs.firebase.mlkit.AneMLKITProvider"
  android:authorities="YOUR.PACKAGE.NAME.provider"
  android:exported="false"
  android:grantUriPermissions="true">
  <meta-data
    android:name="android.support.FILE_PROVIDER_PATHS"
    android:resource="@xml/mlkit_ane_provider_paths"/>
</provider>






  <extensions>
	
	<!-- 
		Required ANEs for the Firebase Core ANE comes here first.
		https://github.com/myflashlab/Firebase-ANE/wiki/A.4.-Initialize-Firebase-in-your-app
	-->
	
	<!-- Firebase MLKIT -->
    <extensionID>com.myflashlab.air.extensions.firebase.mlkit</extensionID>

    <!-- Dependency ANEs for Firebase MLKIT -->
    <extensionID>com.myflashlab.air.extensions.dependency.firebase.ml</extensionID>
    <extensionID>com.myflashlab.air.extensions.dependency.googlePlayServices.auth</extensionID>
    <extensionID>com.myflashlab.air.extensions.dependency.googlePlayServices.vision</extensionID>
    <extensionID>com.myflashlab.air.extensions.dependency.googlePlayServices.clearcut</extensionID>
    <extensionID>com.myflashlab.air.extensions.dependency.googlePlayServices.flags</extensionID>
    <extensionID>com.myflashlab.air.extensions.dependency.googlePlayServices.phenotype</extensionID>
    <extensionID>com.myflashlab.air.extensions.dependency.tensorflow</extensionID>
	
  </extensions>

Add MLKit iOS Resources

In the Firebase iOS SDK you downloaded from this page, copy the following resources to your projects assets folder. These files must be accessible from File.applicationDirectory. Make sure these files are included in your app package.

  • MLVisionFaceModel/Resources/GoogleMVFaceDetectorResources.bundle
  • MLVisionTextModel/Resources/GoogleMVTextDetectorResources.bundle
  • MLNLSmartReply/Resources/PredictOnDeviceResource.bundle

Add MLKit Android Resources

Download MLKit Android resources from here and copy all the files there to your projects assets folder. These files must be accessible from File.applicationDirectory. Make sure these files are included in your app package.

Notice: There's a folder named models, you must also include that folder and everything in it. But make sure you are actually adding the folder to your project resources and do not take out the files in it to ther locations. Firebase SDK will look for those files relatively.

Introduction to Firebase ANEs collection for Adobe Air apps


Get Started with Firebase Core in AIR

  1. Prerequisites
  2. Add Firebase to your app
  3. Add the Firebase SDK
  4. Init Firebase Core
  5. Available ANEs
  6. Managing Firebase iid

Get Started with Analytics

  1. Add Analytics ANE
  2. Init Analytics ANE
  3. Log Events
  4. Set User Properties

Get Started with Crashlytics

  1. Add Crashlytics ANE
  2. Test Your Implementation
  3. Customize Crash Reports
  4. Upload .dSYM for iOS apps

Get Started with DynamicLinks

  1. Add DynamicLinks ANE
  2. Init DynamicLinks ANE
  3. Create DynamicLinks
  4. Receive DynamicLinks
  5. View Analytics

Get Started with Authentication

  1. Add Authentication
  2. Init Authentication
  3. Manage Users
  4. Phone Number
  5. Custom Auth
  6. Anonymous Auth
  7. State in Email Actions
  8. Email Link Authentication

Get Started with FCM + OneSignal

  1. Add FCM ANE
  2. Init FCM ANE
  3. Send Your 1st Message
  4. Send Msg to Topics
  5. Understanding FCM Messages
  6. init OneSignal

Get Started with Firestore

  1. Add Firestore
  2. Init Firestore
  3. Add Data
  4. Transactions & Batches
  5. Delete Data
  6. Manage the Console
  7. Get Data
  8. Get Realtime Updates
  9. Simple and Compound
  10. Order and Limit Data
  11. Paginate Data
  12. Manage Indexes
  13. Secure Data
  14. Offline Data
  15. Where to Go From Here

Get Started with Realtime Database

  1. Add Realtime Database
  2. Init Realtime Database
  3. Structure Your Database
  4. Save Data
  5. Retrieve Data
  6. Enable Offline Capabilities

Get Started with Remote Config

  1. Parameters and Conditions
  2. Add Remote Config
  3. Init Remote Config

Get Started with Performance

  1. Add Performance ANE
  2. Init & Start Monitoring

Get Started with Storage

  1. Add Storage ANE
  2. Init Storage ANE
  3. Upload Files to Storage
  4. Download Files to Air
  5. Use File Metadata
  6. Delete Files

Get Started with Functions

  1. Write & Deploy Functions
  2. Add Functions ANE
  3. Init Functions
Clone this wiki locally