Reads the properties of the attachments embedded in the specified file.
public CodecsAttachments ReadAttachments(
string fileName
)
public:
CodecsAttachments^ ReadAttachments(
String^ fileName
)
def ReadAttachments(self,fileName):
fileName
Owner file that may contain embedded attachments.
Collection of CodecsAttachment with the properties of any attachments found.
ReadAttachments(string) returns the following:
If the format of the owner file supports attachments, such as PDF, then a valid CodecsAttachments is always returned. The number of items in the collection equals the number of attachments found in the file.
If the format of the owner file does not support attachments, such as PNG or BMP, or LEADTOOLS does not support reading attachments of these types of formats, then null is returned.
The number of attachment items returned by this method is the same as the CodecsImageInfo.AttachmentCount value of the object returned by GetInformation.
Each CodecsAttachment contains properties of the attachment such as its FileName, FileLength, and other extra information provided by the owner document.
Call ExtractAttachment to extract the binary content of the attachment file into an output disk file or stream for further processing (such as using GetInformation or Load).
LEADTOOLS supports reading the attachments embedded in the PDF file format.
PDF files support embedded attachments of any number and file format (PDF, TIFF, XML, etc). PDF files can also be created as a portfolio, which contains multiple files assembled into an integrated unit. In these types of documents, the file contains a single generic help page with text such as "For the best experience, open this PDF portfolio in a compatible viewer". It also contains any number of attachments as well as a schema to control how to view the document. The value of CodecsImageInfo.IsPortfolio will be true if the file is a PDF portfolio and it is up to the application to determine any additional handling of the file.
This example will do the following:
using Leadtools;
using Leadtools.Codecs;
using Leadtools.ImageProcessing;
using Leadtools.ImageProcessing.Color;
using Leadtools.Svg;
private static void ReadAttachmentsExample(string fileName, string outputDir)
{
using (RasterCodecs rasterCodecs = new RasterCodecs())
{
int attachmentCount;
// Get information on the owner file
// This step is optional if we are not interested in determining whether the owner file format
// or whether it is a PDF portfolio.
using (CodecsImageInfo imageInfo = rasterCodecs.GetInformation(fileName, true))
{
Debug.WriteLine("Information");
Debug.WriteLine("Format:" + imageInfo.Format);
// If PDF, check if it is portfolio
if (imageInfo.Format == RasterImageFormat.RasPdf)
Debug.WriteLine("IsPortfolio:" + imageInfo.IsPortfolio);
attachmentCount = imageInfo.AttachmentCount;
Debug.WriteLine("Attachments:" + imageInfo.AttachmentCount);
}
// Read the properties of the attachments embedded in this file
CodecsAttachments attachments = rasterCodecs.ReadAttachments(fileName);
if (attachments == null)
{
// The format either:
// - Does not support attachments
// - LEADTOOLS does not support reading its attachments
Debug.WriteLine("Attachments is not supported for this file format");
return;
}
// Sanity check
Debug.Assert(attachments.Count == attachmentCount);
Debug.Assert(attachments.OriginalFormat == RasterImageFormat.Unknown);
if (attachments.Count == 0)
{
Debug.WriteLine("No attachments to extract");
return;
}
// Create the output directory if it does not exist
if (!Directory.Exists(outputDir))
Directory.CreateDirectory(outputDir);
// Extract the attachments
foreach (CodecsAttachment attachment in attachments)
{
// Get the output file name
string outputFileName = Path.Combine(outputDir, attachment.FileName);
var description = attachment.Description;
var displayName = attachment.DisplayName;
var fileLength = attachment.FileLength;
var metaData = attachment.Metadata;
var timeCreated = attachment.TimeCreated;
var timeModified = attachment.TimeModified;
Debug.WriteLine("Extracting attachment to output file: " + outputFileName);
rasterCodecs.ExtractAttachment(fileName, attachment.AttachmentNumber, outputFileName);
// Show information on this attachment
try
{
using (CodecsImageInfo imageInfo = rasterCodecs.GetInformation(outputFileName, true))
{
Debug.WriteLine($" attachment format is {imageInfo.Format} and has {imageInfo.TotalPages} pages");
}
}
catch (Exception ex)
{
Debug.WriteLine($" attachment format could not be obtained, error {ex.Message}");
}
}
}
}
import java.io.*;
import java.net.*;
import java.nio.file.Paths;
import java.util.*;
import java.time.Instant;
import java.time.Duration;
import org.junit.*;
import org.junit.runner.JUnitCore;
import org.junit.runner.Result;
import org.junit.runner.notification.Failure;
import static org.junit.Assert.*;
import leadtools.*;
import leadtools.codecs.*;
import leadtools.codecs.RasterCodecs.FeedCallbackThunk;
import leadtools.drawing.internal.*;
import leadtools.imageprocessing.*;
import leadtools.imageprocessing.color.ChangeIntensityCommand;
import leadtools.svg.*;
public void readAttachmentsExample() throws IOException {
final String LEAD_VARS_IMAGES_DIR = "C:\\LEADTOOLS23\\Resources\\Images";
String fileName = combine(LEAD_VARS_IMAGES_DIR, "pdfsegmentation.pdf");
String outputDir = combine(LEAD_VARS_IMAGES_DIR, "attachments_test.pdf");
RasterCodecs rasterCodecs = new RasterCodecs();
int attachmentCount;
// Get information on the owner file
// This step is optional if we are not interested in determining whether the
// owner file format
// or whether it is a PDF portfolio.
CodecsImageInfo imageInfo = rasterCodecs.getInformation(fileName, true);
System.out.println("Information");
System.out.println("Format:" + imageInfo.getFormat());
// If PDF, check if it is portfolio
if (imageInfo.getFormat() == RasterImageFormat.RAS_PDF)
System.out.println("IsPortfolio:" + imageInfo.isPortfolio());
attachmentCount = imageInfo.getAttachmentCount();
System.out.println("Attachments:" + imageInfo.getAttachmentCount());
// Read the properties of the attachments embedded in this file
CodecsAttachments attachments = rasterCodecs.readAttachments(fileName);
if (attachments == null) {
// The format either:
// - Does not support attachments
// - LEADTOOLS does not support reading its attachments
System.out.println("Attachments is not supported for this file format");
return;
}
// Sanity check
assertTrue(attachments.size() == attachmentCount);
assertTrue(attachments.getOriginalFormat() == RasterImageFormat.UNKNOWN);
if (attachments.size() == 0) {
System.out.println("No attachments to extract");
return;
}
// Create the output directory if it does not exist
File outputDirFile = new File(outputDir);
if (!outputDirFile.exists())
outputDirFile.createNewFile();
// Extract the attachments
for (CodecsAttachment attachment : attachments) {
// Get the output file name
String outputFileName = combine(outputDir, attachment.getFileName());
String description = attachment.getDescription();
String displayName = attachment.getDisplayName();
long fileLength = attachment.getFileLength();
Map<String, String> metaData = attachment.getMetadata();
Date timeCreated = attachment.getTimeCreated();
Date timeModified = attachment.getTimeModified();
System.out.println("Description: " + description);
System.out.println("Display name: " + displayName);
System.out.println("File length: " + fileLength);
System.out.println("Meta data: " + metaData);
System.out.println("Time created: " + timeCreated);
System.out.println("Time modified: " + timeModified);
System.out.println("Extracting attachment to output file: " + outputFileName);
rasterCodecs.extractAttachment(fileName, attachment.getAttachmentNumber(), outputFileName);
// Show information on this attachment
try {
imageInfo = rasterCodecs.getInformation(outputFileName, true);
System.out.println(" attachment format is {imageInfo.Format} and has {imageInfo.TotalPages} pages");
} catch (Exception ex) {
System.out.println(" attachment format could not be obtained, error {ex.Message}");
}
}
}
Help Collections
Raster .NET | C API | C++ Class Library | HTML5 JavaScript
Document .NET | C API | C++ Class Library | HTML5 JavaScript
Medical .NET | C API | C++ Class Library | HTML5 JavaScript
Medical Web Viewer .NET
Multimedia
Direct Show .NET | C API | Filters
Media Foundation .NET | C API | Transforms
Supported Platforms
.NET, Java, Android, and iOS/macOS Assemblies
Imaging, Medical, and Document
C API/C++ Class Libraries
Imaging, Medical, and Document
HTML5 JavaScript Libraries
Imaging, Medical, and Document