Convert documents to PDF in Xamarin

This tutorial only applies to Xamarin.iOS. See Xamarin.Android equivalent here .

Saving annotations back to non-PDF formats is not supported. You can instead save the annotated PDFDoc to a PDF file.

Apryse has a powerful conversion system which allows you to convert many file formats to PDF. The PTConvert class handles the conversion process and supports the following file types:

  • Office files: .docx, .pptx, .xlsx, .doc (with the office conversion Add-On module)
  • Images: .bmp, .jpg, .tif, .png, .gif
  • Image collections (zip archives with any type of image listed above)
  • Markdown files: .md (with the office conversion Add-On module)

Open a non-PDF file

The simplest way to convert and view any file format that Apryse supports is to use the PTDocumentController (or PTTabbedDocumentViewController) method openDocumentWithURL:. This method supports local files, files opened from remote cloud services and "raw" http URLs.

Convert a non-PDF file

Another way is to convert a file with the Convert class's StreamingPDFConversion(String, ConversionOptions) method. The following code shows how to convert a non-PDF file using Apryse's internal conversion:

C#

1var documentConversion = Convert.StreamingPDFConversion("my_file_path", null);
2documentConversion.Convert();
3var pdfDoc = documentConversion.GetDoc();

The result of the conversion will be contained in the provided PTPDFDoc, which can then be displayed.

Convert other non-PDF files

In addition to the file types supported by Apryse's internal conversion, it is also possible to convert many other file types with an iOS-specific API. The PTConvert class's +convertOfficeToPDF:paperSize:completion: method can convert any file type supported by WKWebView to PDF. Some of the supported file types include:

  • iWork files: .pages, .key, .numbers
  • Binary office files: .doc, .ppt, .xls
  • Rich Text Format files: .rtf

The following code shows how to convert a file with the iOS-specific API:

C#

1pdftronprivate.PTConvert.ConvertOfficeToPDF("", CGSize.Empty, (pathToPDF) => {
2 if (pathToPDF == null) {
3 // Failed to convert HTML to PDF.
4 return;
5 }
6 var dirs = NSSearchPath.GetDirectories(NSSearchPathDirectory.DocumentDirectory, NSSearchPathDomain.User, false);
7 var documentDirectory = dirs[0];
8
9 var urlToPdf = new NSUrl(pathToPDF);
10 var destinationURL = (new NSUrl(documentDirectory)).Append(urlToPdf.LastPathComponent, false);
11
12 NSError error = null;
13 var result = NSFileManager.DefaultManager.Copy(urlToPdf, destinationURL, out error);
14 if (!result) {
15 // Failed to copy PDF to persistent location.
16 }
17
18 // Do something with PDF output.
19});

Convert HTML to PDF

Please see this guide about Web/HTML to PDF.

Did you find this helpful?

Trial setup questions?

Ask experts on Discord

Need other help?

Contact Support

Pricing or product questions?

Contact Sales