EngageSolutionsGroup.Apple.MLKitTranslate 5.0.0

dotnet add package EngageSolutionsGroup.Apple.MLKitTranslate --version 5.0.0                
NuGet\Install-Package EngageSolutionsGroup.Apple.MLKitTranslate -Version 5.0.0                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="EngageSolutionsGroup.Apple.MLKitTranslate" Version="5.0.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add EngageSolutionsGroup.Apple.MLKitTranslate --version 5.0.0                
#r "nuget: EngageSolutionsGroup.Apple.MLKitTranslate, 5.0.0"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install EngageSolutionsGroup.Apple.MLKitTranslate as a Cake Addin
#addin nuget:?package=EngageSolutionsGroup.Apple.MLKitTranslate&version=5.0.0

// Install EngageSolutionsGroup.Apple.MLKitTranslate as a Cake Tool
#tool nuget:?package=EngageSolutionsGroup.Apple.MLKitTranslate&version=5.0.0                

NuGet version (EngageSolutionsGroup.Apple.MLKitTranslate)

iOS Google ML Kit Translate - .NET Binding

This repository provides a .NET iOS binding for the GoogleMLKit/Translate library, enabling the use of Google ML Kit's translation capabilities in .NET iOS applications.

Features

  • Language Translation: Translate text between supported languages.

Limitations

iOS Simulator Architecture Issue

Due to an issue with the Google ML Kit library not supporting the arm64 architecture for iOS simulators, you need to configure your project to build for the x64 architecture when targeting the iOS simulator. This is necessary to avoid build errors when running the application on an iOS simulator.

For more details on this issue, you can refer to the official issue on the Google issue tracker: Issue 178965151 - iOS Simulator arm64 not supported.

Configuring the Project for iOS Simulator

To ensure that your project builds correctly for the iOS simulator, add the following setting to your .csproj file:

<PropertyGroup>
  
  <ForceSimulatorX64ArchitectureInIDE>true</ForceSimulatorX64ArchitectureInIDE>
</PropertyGroup>

Prerequisites

  • Xcode: Ensure you have the latest version of Xcode installed.
  • .NET 8.0 or later: This binding is designed for use with .NET 8.0 or later.
  • Cocoapods: Used to download Google ML Kit for translation and its depedencies.

Steps to Generate the NuGet Package

1. Prepare the Native Library

The binding project depends on the native GoogleMLKit/Translate library. You must build the xcframeworks from the native project using CocoaPods and a custom build script.

a. Navigate to the Native Project Directory

Open your terminal and navigate to the native/EngageMLKit directory:

cd native/EngageMLKit
b. Install CocoaPods Dependencies

Run the following command to install the required dependencies:

pod install
c. Build the xcframework

Execute the build.sh script to generate the xcframework:

sh ./build.sh

The generated xcframework will be available in the native/EngageMLKit/build directory.

2. Test API bindings

Open MLKitBindingTestApp.sln and launch on device/simulator

Usage

  var stringSource = "Hello how are you, My name is Yana and I am 19 years old?"
  var options = new MLKTranslatorOptions(Constants.MLKTranslateLanguageEnglish, Constants.MLKTranslateLanguageUkrainian);
  MLKTranslatorDownloadModelIfNeededCallback callback = (error) => {
      if (error != null)
      {
          Console.WriteLine($"Error: {error}");
          return;
      }
      
      Console.WriteLine("Downloaded model");
      translator.TranslateText(stringSource, (result, error) => {
          if (error != null)
          {
              Console.WriteLine($"Error: {error}");
              return;
          }
          
          Console.WriteLine($"Result: {result}");
      });
  };
  translator = MLKTranslator.TranslatorWithOptions(options);
  translator.DownloadModelIfNeededWithCompletion(callback);
Product Compatible and additional computed target framework versions.
.NET net8.0-ios18.0 is compatible.  net9.0-ios was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
  • net8.0-ios18.0

    • No dependencies.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.