System.Drawing.Bitmap
is a class in the .NET Framework used for working with bitmap images. It provides methods and properties to create, manipulate, and display bitmap images.
System.Drawing.Image
is a base class for all GDI+ image objects in the .NET Framework. It is the parent class for various image types, including System.Drawing.Bitmap
.
IronSoftware.Drawing.AnyBitmap
is a bitmap class in IronDrawing, an open-source library originally developed by Iron Software. It helps C# software engineers replace System.Drawing.Common
in .NET projects on Windows, macOS, and Linux platforms.
Get started with IronOCR
Start using IronOCR in your project today with a free trial.
How to Read from System.Drawing Objects
- Download a C# library for reading System.Drawing Objects
- Obtain System.Drawing objects such as Bitmap and Image
- Construct the OcrImageInput class using the acquired data
- Utilize AnyBitmap from Iron Software for Linux and macOS
- Define the reading area by specifying the crop region
Read System.Drawing.Bitmap Example
First, instantiate the IronTesseract class to perform OCR. Create a System.Drawing.Bitmap
from one of the various methods. In the code example, I've decided to use a file path.
Next, use the using
statement to create the OcrImageInput
object, passing the image from the System.Drawing.Bitmap
object to it. Finally, use the Read
method to perform OCR.
:path=/static-assets/ocr/content-code-examples/how-to/input-system-drawing-read-bitmap.cs
using IronOcr;
using System.Drawing;
// This code snippet demonstrates how to perform Optical Character Recognition (OCR)
// using the IronTesseract library on a given image file. The image file is read into
// a Bitmap object, which is then processed to extract text using OCR and print the result
// to the console.
// Make sure that the IronOcr library is properly referenced in your project before trying to use it.
// Instantiate IronTesseract object
var ocrTesseract = new IronTesseract();
// Read the image file into a Bitmap object
// Ensure "Potter.tiff" exists in the executing directory, or specify the full path to the image
using (Bitmap bitmap = new Bitmap("Potter.tiff"))
{
// Use the OcrInput class to prepare the Bitmap for OCR processing
using (var imageInput = new OcrInput(bitmap))
{
// Perform OCR on the input image and store the text result
OcrResult ocrResult = ocrTesseract.Read(imageInput);
// Print the OCR result text to the console
Console.WriteLine(ocrResult.Text);
}
}
// Note: Ensure you handle exceptions and edge cases (like file not found) in real-world applications.
Read System.Drawing.Image Example
Reading from a System.Drawing.Image
is as simple as creating the OcrImageInput
object with the Image and then performing the standard OCR process using the Read
method.
:path=/static-assets/ocr/content-code-examples/how-to/input-system-drawing-read-image.cs
using IronOcr;
using System;
using System.Drawing;
// This implementation utilizes IronTesseract to perform OCR (Optical Character Recognition)
// on an image file. The image is loaded, and text is extracted from it using IronTesseract.
try
{
// Instantiate the OCR engine.
IronTesseract ocrTesseract = new IronTesseract();
// Open the image file as a System.Drawing.Image.
// Ensure the file path is correct.
using Image image = Image.FromFile("Potter.tiff");
// Convert the image into an OCR-friendly format using OcrInput.
using var imageInput = new OcrInput();
imageInput.AddImage(image);
// Perform OCR on the input image.
OcrResult ocrResult = ocrTesseract.Read(imageInput);
// Output the detected text to the console (or handle it as needed).
Console.WriteLine("Extracted Text: ");
Console.WriteLine(ocrResult.Text);
}
catch (Exception ex)
{
// Handle any exceptions that occur during the OCR process.
Console.WriteLine("An error occurred: " + ex.Message);
}
Read IronSoftware.Drawing.AnyBitmap Example
Similarly, after creating or obtaining an AnyBitmap
object, you can construct the OcrImageInput
class. The constructor will take care of all the necessary steps to import the data. The code example below demonstrates this.
:path=/static-assets/ocr/content-code-examples/how-to/input-system-drawing-read-anybitmap.cs
using IronOcr;
using IronSoftware.Drawing;
public class OcrExample
{
// Instantiate IronTesseract for Optical Character Recognition (OCR)
private static readonly IronTesseract ocrTesseract = new IronTesseract();
public static void Main()
{
// Load the image file as AnyBitmap. Ensure that the file path is correct and accessible.
AnyBitmap anyBitmap = null;
try
{
anyBitmap = AnyBitmap.FromFile("Potter.tiff");
}
catch (Exception ex)
{
Console.WriteLine($"Error loading image: {ex.Message}");
return;
}
// Use 'using' statement to ensure proper disposal of OcrImageInput resource.
using (var imageInput = new OcrImageInput(anyBitmap))
{
try
{
// Perform OCR on the image to extract text content.
OcrResult ocrResult = ocrTesseract.Read(imageInput);
// Output the recognized text to the console or handle it as needed in your application.
Console.WriteLine("Recognized Text:");
Console.WriteLine(ocrResult.Text);
}
catch (Exception ex)
{
Console.WriteLine($"Error during OCR process: {ex.Message}");
}
}
}
}
Specify Scan Region
In the construction of the OcrImageInput
class, you can specify the area to scan. This allows you to define the specific region of the image document for OCR. Depending on the image document, specifying the scanning region can significantly enhance performance. In the provided code example, I specify that only the chapter number and title should be extracted.
:path=/static-assets/ocr/content-code-examples/how-to/input-images-read-specific-region.cs
// Using directives for necessary namespaces
using IronOcr;
using IronSoftware.Drawing;
using System;
// Instantiate IronTesseract, a library for OCR (Optical Character Recognition)
IronTesseract ocrTesseract = new IronTesseract();
// Specify the crop region - the rectangular area of the image to be analyzed
// Parameters are (x: start position, y: start position, width: width of the rectangle, height: height of the rectangle)
var scanRegion = new System.Drawing.Rectangle(800, 200, 900, 400);
try
{
// Load the image from given file and specify the region for OCR by setting ContentArea property
using var imageInput = new OcrInput("Potter.tiff");
// Ensure the region is set only if it's within the bounds of the image
imageInput.ContentArea = scanRegion;
// Perform OCR on the specified region of the image
OcrResult ocrResult = ocrTesseract.Read(imageInput);
// Output the recognized text to the console
Console.WriteLine(ocrResult.Text);
}
catch (Exception ex)
{
// Catch and display any exceptions during image processing or OCR
Console.WriteLine($"An error occurred: {ex.Message}");
}
OCR Result

Frequently Asked Questions
What is System.Drawing.Bitmap?
System.Drawing.Bitmap is a class in the .NET Framework used for working with bitmap images. It provides methods and properties to create, manipulate, and display bitmap images.
What is the role of System.Drawing.Image in .NET?
System.Drawing.Image is a base class for all GDI+ image objects in the .NET Framework, serving as the parent class for various image types, including System.Drawing.Bitmap.
How can I use IronOCR with System.Drawing.Bitmap?
You can use IronOCR with System.Drawing.Bitmap by creating an OcrImageInput object with the bitmap and then using the Read method to perform OCR.
How does IronSoftware.Drawing.AnyBitmap help in .NET projects?
IronSoftware.Drawing.AnyBitmap is a bitmap class in the IronDrawing library that helps C# software engineers replace System.Drawing.Common in .NET projects on Windows, macOS, and Linux platforms.
How do you specify a scan region for OCR in IronOCR?
In IronOCR, you can specify a scan region by defining the area to scan using coordinates and dimensions in the OcrImageInput class, which can enhance performance by focusing on specific areas of the image.
How do you read a System.Drawing.Image using IronOCR?
To read a System.Drawing.Image using IronOCR, create an OcrImageInput object with the image and perform the standard OCR process using the Read method.
What is the use of IronTesseract in OCR?
IronTesseract is used to initialize the Tesseract OCR engine in IronOCR, allowing developers to perform OCR operations on images.
Can IronOCR be used on Linux and macOS?
Yes, IronOCR can be used on Linux and macOS by utilizing AnyBitmap from Iron Software, which supports these platforms.
What is the advantage of defining a specific scan region in an image?
Defining a specific scan region allows you to focus on a particular area of an image for OCR, which can improve performance and accuracy by narrowing the scan to relevant sections.