Cómo realizar OCR en Android en .NET MAUI

This article was translated from English: Does it need improvement?
Translated
View the article in English
Android related to Cómo realizar OCR en Android en .NET MAUI

.NET MAUI (Interfaz de Usuario de Aplicación Multiplataforma) es una evolución del marco Xamarin.Forms, diseñado para crear aplicaciones multiplataforma para Android, iOS, macOS y Windows utilizando .NET. .NET MAUI tiene como objetivo simplificar el proceso de construir interfaces de usuario nativas que pueden ejecutarse en múltiples plataformas.

¡El paquete IronOcr.Android lleva soporte de OCR a Android!

Paquete IronOCR para Android

El paquete IronOcr.Android habilita funciones de OCR en dispositivos Android a través de proyectos multiplataforma de .NET. No se necesita el paquete IronOCR estándar.

Paquete de instalación IronOcr.Android
Biblioteca C# NuGet para PDF

Instalar con NuGet

Paquete de instalación IronOcr.Android

Crear un proyecto .NET MAUI

Abre Visual Studio y haz clic en "Crear un nuevo proyecto". Busca MAUI, selecciona .NET MAUI App y "Siguiente".

Crear proyecto de aplicación .NET MAUI

Incluir la biblioteca IronOCR.Android

La biblioteca se puede agregar de varias maneras. La más fácil es quizás usando NuGet.

  1. Dentro de Visual Studio, haz clic derecho en "Dependencias" y selecciona "Gestionar paquetes NuGet ...".
  2. Seleccione la pestaña "Examinar" y busque "IronOCR.Android".
  3. Seleccione el paquete "IronOCR.Android" y haga clic en "Instalar".

Descargue el paquete IronOCR.Android

Para evitar problemas con otras plataformas, modifica el archivo csproj para incluir el paquete solo cuando se apunte a la plataforma Android. Para hacerlo:

  1. Haga clic derecho en el proyecto y seleccione "Editar archivo del proyecto".
  2. Crea un nuevo elemento ItemGroup de la siguiente manera:

    <ItemGroup Condition="$(TargetFramework.Contains('android')) == true">
    </ItemGroup>
    <ItemGroup Condition="$(TargetFramework.Contains('android')) == true">
    </ItemGroup>
    XML
  3. Mueva la referencia del paquete "IronOCR.Android" dentro del grupo de elementos que acabamos de crear.

Los pasos anteriores evitarán que el paquete "IronOCR.Android" se utilice en, por ejemplo, plataformas iOS (para eso, instale IronOCR.iOS en su lugar).

Editar "MainActivity.cs"

  • Abra el archivo "MainActivity.cs" navegando a Plataformas -> Android.
  • Agregue el método MainActivity e invoque el método Initialize.
using Android.App;
using Android.Content.PM;
using Android.Runtime;
using Android.OS;
using IronOcr;

namespace MAUIIronOCRAndroidSample
{
    [Activity(Theme = "@style/Maui.SplashTheme", MainLauncher = true, ConfigurationChanges = ConfigChanges.ScreenSize | ConfigChanges.Orientation | ConfigChanges.UiMode | ConfigChanges.ScreenLayout | ConfigChanges.SmallestScreenSize | ConfigChanges.Density)]
    public class MainActivity : MauiAppCompatActivity
    {
        public MainActivity()
        {
            // Initialize IronTesseract for OCR purposes
            IronTesseract.Initialize(this);
        }
    }
}
using Android.App;
using Android.Content.PM;
using Android.Runtime;
using Android.OS;
using IronOcr;

namespace MAUIIronOCRAndroidSample
{
    [Activity(Theme = "@style/Maui.SplashTheme", MainLauncher = true, ConfigurationChanges = ConfigChanges.ScreenSize | ConfigChanges.Orientation | ConfigChanges.UiMode | ConfigChanges.ScreenLayout | ConfigChanges.SmallestScreenSize | ConfigChanges.Density)]
    public class MainActivity : MauiAppCompatActivity
    {
        public MainActivity()
        {
            // Initialize IronTesseract for OCR purposes
            IronTesseract.Initialize(this);
        }
    }
}
Imports Android.App
Imports Android.Content.PM
Imports Android.Runtime
Imports Android.OS
Imports IronOcr

Namespace MAUIIronOCRAndroidSample
	<Activity(Theme := "@style/Maui.SplashTheme", MainLauncher := True, ConfigurationChanges := ConfigChanges.ScreenSize Or ConfigChanges.Orientation Or ConfigChanges.UiMode Or ConfigChanges.ScreenLayout Or ConfigChanges.SmallestScreenSize Or ConfigChanges.Density)>
	Public Class MainActivity
		Inherits MauiAppCompatActivity

		Public Sub New()
			' Initialize IronTesseract for OCR purposes
			IronTesseract.Initialize(Me)
		End Sub
	End Class
End Namespace
$vbLabelText   $csharpLabel

Editar "MainPage.xaml"

Edite el archivo XAML para mostrar un botón y una etiqueta para mostrar el resultado del OCR. Por ejemplo:

<?xml version="1.0" encoding="utf-8" ?>
<ContentPage xmlns="http://schemas.microsoft.com/dotnet/2021/maui"
             xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
             x:Class="MAUIIronOCRAndroidSample.MainPage">

    <Grid>
        <Grid.RowDefinitions>
            <RowDefinition Height="Auto"/>
            <RowDefinition Height="*"/>
        </Grid.RowDefinitions>
        <Button
            Text="Import File"
            Clicked="ReadFileOnImport"
            Grid.Row="0"
            HorizontalOptions="Center"
            Margin="20, 20, 20, 10"/>

        <ScrollView
            Grid.Row="1"
            BackgroundColor="LightGray"
            Padding="10"
            Margin="10, 10, 10, 30">
            <Label x:Name="OutputText"/>
        </ScrollView>
    </Grid>

</ContentPage>
<?xml version="1.0" encoding="utf-8" ?>
<ContentPage xmlns="http://schemas.microsoft.com/dotnet/2021/maui"
             xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
             x:Class="MAUIIronOCRAndroidSample.MainPage">

    <Grid>
        <Grid.RowDefinitions>
            <RowDefinition Height="Auto"/>
            <RowDefinition Height="*"/>
        </Grid.RowDefinitions>
        <Button
            Text="Import File"
            Clicked="ReadFileOnImport"
            Grid.Row="0"
            HorizontalOptions="Center"
            Margin="20, 20, 20, 10"/>

        <ScrollView
            Grid.Row="1"
            BackgroundColor="LightGray"
            Padding="10"
            Margin="10, 10, 10, 30">
            <Label x:Name="OutputText"/>
        </ScrollView>
    </Grid>

</ContentPage>
XML

Editar "MainPage.xaml.cs"

Primero, cree una instancia del objeto IronTesseract. Asegúrese de que IronTesseract se inicialice una vez dentro de la clase, como se muestra en el código a continuación. Instanciarlo dentro de un método puede ser ineficaz y puede causar errores inesperados.

A continuación, use el método FilePicker.PickAsync para seleccionar un archivo, luego abra un flujo de lectura desde el FileResult. Cree un nuevo objeto OcrInput y cargue la imagen en él. Realice OCR en la imagen utilizando la instancia tesseract y recupere el texto. Finalmente, muestre el texto resultante en una etiqueta.

using IronOcr;
using Microsoft.Maui.Controls;
using System;
using System.Diagnostics;
using System.IO;
using System.Threading.Tasks;

namespace MAUIIronOCRAndroidSample
{
    public partial class MainPage : ContentPage
    {
        // Initialize IronTesseract once in a class
        private readonly IronTesseract ocrTesseract = new IronTesseract();

        public MainPage()
        {
            InitializeComponent();
            // Apply License key if required
            IronOcr.License.LicenseKey = "IRONOCR.MYLICENSE.KEY.1EF01";
        }

        private async void ReadFileOnImport(object sender, EventArgs e)
        {
            try
            {
                // Configure the file picker
                var options = new PickOptions
                {
                    PickerTitle = "Please select a file"
                };

                // Await user's file selection
                var result = await FilePicker.PickAsync(options);
                if (result != null)
                {
                    using var stream = await result.OpenReadAsync();
                    // Instantiate OcrInput
                    using var ocrInput = new OcrInput();
                    // Load image stream for OCR processing
                    ocrInput.AddImage(stream);
                    // Perform OCR
                    var ocrResult = ocrTesseract.Read(ocrInput);
                    // Display extracted text
                    OutputText.Text = ocrResult.Text;
                }
            }
            catch (Exception ex)
            {
                // Log and handle exceptions
                Debug.WriteLine(ex);
            }
        }
    }
}
using IronOcr;
using Microsoft.Maui.Controls;
using System;
using System.Diagnostics;
using System.IO;
using System.Threading.Tasks;

namespace MAUIIronOCRAndroidSample
{
    public partial class MainPage : ContentPage
    {
        // Initialize IronTesseract once in a class
        private readonly IronTesseract ocrTesseract = new IronTesseract();

        public MainPage()
        {
            InitializeComponent();
            // Apply License key if required
            IronOcr.License.LicenseKey = "IRONOCR.MYLICENSE.KEY.1EF01";
        }

        private async void ReadFileOnImport(object sender, EventArgs e)
        {
            try
            {
                // Configure the file picker
                var options = new PickOptions
                {
                    PickerTitle = "Please select a file"
                };

                // Await user's file selection
                var result = await FilePicker.PickAsync(options);
                if (result != null)
                {
                    using var stream = await result.OpenReadAsync();
                    // Instantiate OcrInput
                    using var ocrInput = new OcrInput();
                    // Load image stream for OCR processing
                    ocrInput.AddImage(stream);
                    // Perform OCR
                    var ocrResult = ocrTesseract.Read(ocrInput);
                    // Display extracted text
                    OutputText.Text = ocrResult.Text;
                }
            }
            catch (Exception ex)
            {
                // Log and handle exceptions
                Debug.WriteLine(ex);
            }
        }
    }
}
Imports IronOcr
Imports Microsoft.Maui.Controls
Imports System
Imports System.Diagnostics
Imports System.IO
Imports System.Threading.Tasks

Namespace MAUIIronOCRAndroidSample
	Partial Public Class MainPage
		Inherits ContentPage

		' Initialize IronTesseract once in a class
		Private ReadOnly ocrTesseract As New IronTesseract()

		Public Sub New()
			InitializeComponent()
			' Apply License key if required
			IronOcr.License.LicenseKey = "IRONOCR.MYLICENSE.KEY.1EF01"
		End Sub

		Private Async Sub ReadFileOnImport(ByVal sender As Object, ByVal e As EventArgs)
			Try
				' Configure the file picker
				Dim options = New PickOptions With {.PickerTitle = "Please select a file"}

				' Await user's file selection
				Dim result = Await FilePicker.PickAsync(options)
				If result IsNot Nothing Then
					Dim stream = Await result.OpenReadAsync()
					' Instantiate OcrInput
					Dim ocrInput As New OcrInput()
					' Load image stream for OCR processing
					ocrInput.AddImage(stream)
					' Perform OCR
					Dim ocrResult = ocrTesseract.Read(ocrInput)
					' Display extracted text
					OutputText.Text = ocrResult.Text
				End If
			Catch ex As Exception
				' Log and handle exceptions
				Debug.WriteLine(ex)
			End Try
		End Sub
	End Class
End Namespace
$vbLabelText   $csharpLabel

Por último, en el archivo .csproj, asegúrese de que solo está compilando el proyecto para Android. Dado que el paquete que agregamos es solo para Android, compilar el proyecto para todas las plataformas fallará.

Ejecutar el proyecto

Esto le mostrará cómo ejecutar el proyecto y realizar OCR.

Execute .NET MAUI App project

Descargar proyecto de aplicación .NET MAUI

Puede descargar el código completo de esta guía. Viene como un archivo comprimido que puede abrir en Visual Studio como un proyecto de aplicación .NET MAUI.

Haga clic aquí para descargar el proyecto.

Uso de IronOcr.Android en Avalonia

Similar a MAUI, IronOcr.Android se puede usar en un proyecto Avalonia con la misma configuración descrita anteriormente.

Si desea realizar OCR en iOS, navegue al siguiente artículo para obtener más información: "Cómo realizar OCR en iOS en .NET MAUI"

Preguntas Frecuentes

¿Cómo puedo realizar OCR en Android en una aplicación .NET MAUI?

Para realizar OCR en Android usando .NET MAUI, instala el paquete IronOcr.Android vía NuGet en Visual Studio. Utiliza la clase IronTesseract para procesar imágenes y extraer texto. Asegúrate de que tu proyecto esté configurado para dirigirse a Android modificando adecuadamente el archivo .csproj.

¿Cuál es el propósito del paquete IronOcr.Android?

El paquete IronOcr.Android está diseñado específicamente para llevar capacidades de OCR a dispositivos Android dentro de proyectos .NET MAUI. Simplifica la integración de características de reconocimiento de texto en aplicaciones multiplataforma dirigidas a Android.

¿Cómo configuro un proyecto .NET MAUI para OCR en Android?

Configura tu proyecto .NET MAUI instalando el paquete IronOcr.Android a través de NuGet. Ajusta el archivo .csproj para dirigirte a Android creando un nuevo elemento ItemGroup y moviendo la referencia de paquete IronOcr.Android dentro de él. Esto evita problemas de construcción para otras plataformas.

¿Qué modificaciones se necesitan en MainActivity.cs para la configuración de OCR?

En el archivo MainActivity.cs bajo Platforms -> Android, añade el método MainActivity y llama al método Initialize de IronTesseract. Esto establece las capacidades de OCR necesarias para procesar texto de imágenes.

¿Cómo puedo editar MainPage.xaml para incorporar características de OCR?

Edita MainPage.xaml para incluir un botón para importar archivos y una etiqueta para mostrar los resultados del OCR. Define los elementos de interfaz de usuario necesarios para interactuar con la lógica de procesamiento de OCR y gestionar eficazmente la entrada del usuario.

¿Qué debo hacer si encuentro errores durante el procesamiento de OCR?

Utiliza bloques try-catch alrededor de tu código de procesamiento de OCR para manejar excepciones. Registra cualquier error empleando Debug.WriteLine u otro mecanismo de registro para ayudar a diagnosticar y solucionar problemas.

¿Es posible usar el paquete IronOcr.Android en proyectos Avalonia?

Sí, el paquete IronOcr.Android se puede usar en proyectos Avalonia con un proceso de configuración similar al de .NET MAUI. Ajusta la configuración del proyecto en consecuencia para habilitar la funcionalidad OCR.

¿Dónde puedo encontrar un proyecto de muestra completo para OCR en Android usando .NET MAUI?

Un proyecto de muestra completo para OCR en Android usando la biblioteca IronOCR en .NET MAUI está disponible para descargar a través de un enlace proporcionado en la guía. El proyecto viene como un archivo comprimido, listo para abrirse en Visual Studio.

¿Cómo aseguro que el paquete IronOcr.Android solo apunte a Android en un proyecto multiplataforma?

Para asegurar que el paquete IronOcr.Android solo apunte a Android, modifica el archivo .csproj creando un ItemGroup condicional para Android y moviendo la referencia de paquete IronOcr.Android dentro de él. Esto previene conflictos al construir para otras plataformas.

Curtis Chau
Escritor Técnico

Curtis Chau tiene una licenciatura en Ciencias de la Computación (Carleton University) y se especializa en el desarrollo front-end con experiencia en Node.js, TypeScript, JavaScript y React. Apasionado por crear interfaces de usuario intuitivas y estéticamente agradables, disfruta trabajando con frameworks modernos y creando manuales bien ...

Leer más
¿Listo para empezar?
Nuget Descargas 5,167,857 | Version: 2025.11 recién lanzado