PDF/X is a subset of the PDF ISO standard.
PDF/X-1a:2003 has now become an ISO standard: ISO 15930-4:2003 norm for Electronic document file format for long-term preservation. This is a revision of PDF/X-1a:2001 based on PDF 1.4
PDF/X-3:2003 has now become an ISO standard: ISO 15930-6:2003 norm for Electronic document file format for long-term preservation. This is a revision of PDF/X-3:2002 based on PDF 1.4
The main constraints that are placed on PDF files include:
All fonts must be embedded with Unicode conversion tables
All images need to be grayscale, CMYK or named spot colors. Only PDF/X-3 accepts other Colorspaces like RGB or LAB.
Images without any transparency.
The Open Prepress Interface (OPI) is not allowed.
Audio and video content, Javascript, AutoPrint and encryption are forbidden.
Annotations only can be outside of the bleed area.
an ICC color profile needed.
PDF files should contain XMP based metadata.
To enable PDF/X when converting documents using PDF Converter, you should set the following flags in the imageOptions property or function call:
ImageOptions |
Description |
Value |
---|---|---|
IO_XMPMETADATA |
Add XMP metadata to PDF files (can be used independently of PDF/A). |
0x00000010 |
IO_CONVERTTOCMYK |
Convert RGB colors to CMYK. Only mandatory to the PDF/X-1a |
0x00000004 |
IO_OUTPUTPDFX1 |
Create PDF files that conform to the PDF/X-1a standard. |
0x00000080 |
IO_OUTPUTPDFX3 |
Create PDF files that conform to the PDF/X-3 standard. |
0x00000100 |
And these following flags in the FileNameOptionsEx property or function call:
FileNameOptionsEx |
Description |
Value |
---|---|---|
EmbedFonts |
Enable embedding of fonts used in the source document. |
0x00000010 |
MultilingualSupport |
Add supports for international character sets. |
0x00000080 |
EmbedStandardFonts |
Embed standard fonts such as Arial, Times, etc. |
0x00200000 |
EmbedLicensedFonts |
Embed fonts requiring a license. |
0x00400000 |
ImageOptions = IO_OUTPUTPDFX1 | IO_XMPMETADATA;
FileNameOptionsEx = NoPrompt | EmbedFonts | MultilingualSupport | EmbedStandardFonts | EmbedLicensedFonts | FullEmbed;
SetDefaultConfig
ImageOptions = IO_IO_OUTPUTPDFX3 | IO_XMPMETADATA;
FileNameOptionsEx = NoPrompt | EmbedFonts | MultilingualSupport | EmbedStandardFonts | EmbedLicensedFonts | FullEmbed;
SetDefaultConfig
Having 2 separate flags will enable the developer to output XMP Metadata independently of PDF/X compatibility. In addition, the developer should always set Multilingual support and partial font embedding so that the fonts get properly embedded.
For Unicode fonts, full font embedding (FullEmbed) should NOT be used. This is because Unicode font files are usually very large, and will result in very large file sizes.
In order to succeed with PDF/X document creation is important to follow this:
Include the options of embedFonts, MultilingualSupport, EmbedStandardFonts and EmbedLicensedFonts in the FileNameOptionsEx property.
Not to use the option of IO_COMPRESSJBIG2 in the ImageOptions propriety nor JPEG2000Compression in the FileNameOptionsEx property.
Include IO_CONVERTTOCMYK for PDF/X-1a option.
Any kind of Encryption will not comply with PDF/X standards.
To generate PDF files with CMYK content, a color profile should be attached to the printer; this can be done either manually from the printers’ panel, or through the SetColorProfile helper function. The ICC profile is usually supplied by the printer manufacturer. Microsoft provides a standard CMYK ICC profile that can be used; the Microsoft profile is located under: http://www.microsoft.com/whdc/device/display/color/CMYK_Profile.mspx.
Amyuni also provides a standard CMYK profile under: https://www.amyuni.com/downloads/AmyuniCMYK.icc.
The best color profile remains the one supplied by the printer manufacturer of the destination printer.
The Evaluation License adds a watermark which breaks the PDF/X specification. Only the Full License will give you a proper PDF/X file.
<Flags()>
Public Enum acImageOptions As Integer
IO_NODUPLICATES = &H1
IO_DOWNSAMPLE = &H2
IO_CONVERTTOCMYK = &H4
IO_OUTPUTPDFA = &H8
IO_XMPMETADATA = &H10
IO_OUTPUTPDFA8 = &H20
IO_NOPRECOMPRESSED = &H40
IO_OUTPUTPDFX1 = &H80
IO_OUTPUTPDFX3 = &H100
IO_COMPRESSJBIG2 = &H200 ' It cannot be used with PDF/X standard
IO_ENABLEEPS = &H40000000
IO_SIMPOSTSCRIPT = &H80000000
End Enum
<Flags()>
Public Enum acFileNameOptions As Integer
' Please check FileNameOptions for the complete version of the flags
NoPrompt = &H1
UseFileName = &H2
Concatenate = &H4
DisableCompression = &H8
EmbedFonts = &H10
BroadcastMessages = &H20
PrintWatermark = &H40
MultilingualSupport = &H80
EncryptDocument = &H100 ' It cannot be used with PDF/X standard
EmbedStandardFonts = &H200000
EmbedLicensedFonts = &H400000
Jpeg2000Compression = &H1000000 ' It cannot be used with PDF/X standard
EncryptDocument128 = &H40000000 ' It cannot be used with PDF/X standard
End Enum
Sub Sample()
Constants for Activation codes
Const strLicenseTo As String = "Amyuni PDF Converter Evaluation"
Const strActivationCode As String = "07EFCDAB0100010025AFF1801CB9441306C5739F7D452154D8833B9CECBA2ADE79E3762A69FFC354528A5F4A5811BE3204A0A439F5BA"
Const AMYUNIPRINTERNAME As String = "Amyuni PDF Converter"
' Declare a new cdintfex object if it does not exist in the form.
Dim PDF As New CDIntfEx.CDIntfEx
' Get a reference to the installed printer.
' This will fail if the printer name passed to the DriverInit method is
' not found in the printer’s folder
PDF.DriverInit(AMYUNIPRINTERNAME)
' The SetDefaultPrinter function sets the system default printer to the one
' initialized by the DriverInit functions.
PDF.SetDefaultPrinter()
' The EnablePrinter() method needs to be called right before each print job.
' and before the configuration
' Calling the EnablePrinter() method will start a 20 second time-out value
PDF.EnablePrinter(strLicenseTo, strActivationCode)
' Resulting PDF document stored here
PDF.DefaultDirectory = "C:\Temp"
' Set Printer options
PDF.FileNameOptionsEx = acFileNameOptions.NoPrompt Or acFileNameOptions.EmbedFonts _
Or acFileNameOptions.MultilingualSupport Or acFileNameOptions.EmbedStandardFonts _
Or acFileNameOptions.EmbedLicensedFonts
' Set Image conversion options to create PDF/X-1a
PDF.ImageOptions = acImageOptions.IO_OUTPUTPDFX1 Or acImageOptions.IO_XMPMETADATA Or acImageOptions.IO_CONVERTTOCMYK
' Set the ColorProfile option
PDF.SetColorProfile("C:\temp\AmyuniCMYK.icc")
' Apply Settings
PDF.SetDefaultConfig()
' The BatchConvert method converts a number of files to PDF.
PDF.BatchConvert("C:\Temp\*.docx")
' The RestoreDefaultPrinter function resets the system default printer
' to the printer that was the default before the call to SetDefaultPrinter.
PDF.RestoreDefaultPrinter()
' This function will simply detach from an existing printer because the handle was created using DriverInit
PDF.DriverEnd()
' Destroy PDF object
PDF = Nothing
End Sub
[Flags]
public enum acImageOptions
{
IO_NODUPLICATES = 0x00000001,
IO_DOWNSAMPLE = 0x00000002,
IO_CONVERTTOCMYK = 0x00000004,
IO_OUTPUTPDFA = 0x00000008,
IO_XMPMETADATA = 0x00000010,
IO_OUTPUTPDFA8 = 0x00000020,
IO_NOPRECOMPRESSED = 0x00000040,
IO_OUTPUTPDFX1 = 0x00000080,
IO_OUTPUTPDFX3 = 0x00000100,
IO_COMPRESSJBIG2 = 0x00000200, // It cannot be used with PDF/X standard
IO_ENABLEEPS = 0x40000000,
IO_SIMPOSTSCRIPT = unchecked((int)0x80000000)
}
[Flags]
public enum acFileNameOptions
{
// Please check FileNameOptions for the complete version of the flags
NoPrompt = 0x00000001,
UseFileName = 0x00000002,
Concatenate = 0x00000004,
DisableCompression = 0x00000008,
EmbedFonts = 0x00000010,
BroadcastMessages = 0x00000020,
PrintWatermark = 0x00000040,
MultilingualSupport = 0x00000080,
EncryptDocument = 0x00000100, // It cannot be used with PDF/X standard
EmbedStandardFonts = 0x00200000,
EmbedLicensedFonts = 0x00400000,
Jpeg2000Compression = 0x01000000, // It cannot be used with PDF/X standard
EncryptDocument128 = 0x40000000 // It cannot be used with PDF/X standard
}
static void Main(string[] args)
{
// Constants for Activation codes
const string strLicenseTo = "Amyuni PDF Converter Evaluation";
const string strActivationCode = "07EFCDAB0100010025AFF1801CB9441306C5739F7D452154D8833B9CECBA2ADE79E3762A69FFC354528A5F4A5811BE3204A0A439F5BA";
const string AMYUNIPRINTERNAME = "Amyuni PDF Converter";
// Declare a new cdintfex object if it does not exist in the form.
CDIntfEx.CDIntfEx PDF = new CDIntfEx.CDIntfEx();
// Get a reference to the installed printer.
// This will fail if the printer name passed to the DriverInit method is
// not found in the printer’s folder
PDF.DriverInit(AMYUNIPRINTERNAME);
// The SetDefaultPrinter function sets the system default printer to the one
// initialized by the DriverInit functions.
PDF.SetDefaultPrinter();
// The EnablePrinter() method needs to be called right before each print job.
// and before the configuration
// Calling the EnablePrinter() method will start a 20 second time-out value
PDF.EnablePrinter(strLicenseTo, strActivationCode);
// Resulting PDF document stored here
PDF.DefaultDirectory = @"C:\Temp";
// Set Printer options
PDF.FileNameOptionsEx = (int)(acFileNameOptions.NoPrompt | acFileNameOptions.EmbedFonts
| acFileNameOptions.MultilingualSupport | acFileNameOptions.EmbedStandardFonts
| acFileNameOptions.EmbedLicensedFonts);
// Set Image conversion options to create PDF/X-1a
PDF.ImageOptions = (int)(acImageOptions.IO_OUTPUTPDFX1 | acImageOptions.IO_XMPMETADATA | acImageOptions.IO_CONVERTTOCMYK);
// Set the ColorProfile option
PDF.SetColorProfile(@"C:\temp\AmyuniCMYK.icc");
// Apply Settings
PDF.SetDefaultConfig();
// The BatchConvert method converts a number of files to PDF.
PDF.BatchConvert(@"C:\Temp\*.docx");
// The RestoreDefaultPrinter function resets the system default printer
// to the printer that was the default before the call to SetDefaultPrinter.
PDF.RestoreDefaultPrinter();
// This function will simply detach from an existing printer because the handle was created using DriverInit
PDF.DriverEnd();
}
// PDF Converter Cpp.cpp : Defines the entry point for the console application.
//
# include <Windows.h>
# include <string>
# include <iostream>
# include "CdIntf.h"
# pragma comment (lib, "CDIntf.lib")
using namespace std;
int main()
{
// Constants for Activation codes
# define strLicenseTo "Amyuni PDF Converter Evaluation"
# define strActivationCode "07EFCDAB0100010025AFF1801CB9441306C5739F7D452154D8833B9CECBA2ADE79E3762A69FFC354528A5F4A5811BE3204A0A439F5BA"
# define AMYUNIPRINTERNAME "Amyuni PDF Converter"
// Get a reference to the installed printer.
// This will fail if the printer name passed to the DriverInit method is
// not found in the printer’s folder
HANDLE PDF = DriverInit(AMYUNIPRINTERNAME);
// The CDISetDefaultPrinter function sets the system default printer to the one
// initialized by the DriverInit functions.
CDISetDefaultPrinter(PDF);
// The EnablePrinter() method needs to be called right before each print job.
// and before the configuration
// Calling the EnablePrinter() method will start a 20 second time-out value
EnablePrinter(PDF, strLicenseTo, strActivationCode);
// Resulting PDF document stored here
SetDefaultDirectory(PDF, "C:\temp");
// Set Printer options
// EncryptDocument, Jpeg2000Compression nor EncryptDocument128 cannot be used with PDF/A standard
SetFileNameOptions(PDF, NoPrompt | EmbedFonts | MultilingualSupport | EmbedStandardFonts | EmbedLicensedFonts | FullEmbed);
// Set Image conversion options to create PDF/X-1a
SetImageOptions(PDF, IO_OUTPUTPDFX1 | IO_XMPMETADATA | IO_CONVERTTOCMYK);
// Set the ColorProfile option
SetColorProfile(PDF, "C:\temp\\AmyuniCMYK.icc");
// Apply Settings
SetDefaultConfig(PDF);
// The BatchConvert method converts a number of files to PDF.
BatchConvertEx(PDF, "C:\temp\\*.docx");
// The RestoreDefaultPrinter function resets the system default printer
// to the printer that was the default before the call to SetDefaultPrinter.
RestoreDefaultPrinter(PDF);
// This function will simply detach from an existing printer because the handle was created using DriverInit
DriverEnd(PDF);
// Destroy PDF object
PDF = nullptr;
return 0;
}
package Example;
import com.jacob.activeX.ActiveXComponent;
import com.jacob.com.Dispatch;
public class Sample {
public enum acImageOptions
{
IO_NODUPLICATES(0x00000001),
IO_DOWNSAMPLE(0x00000002),
IO_CONVERTTOCMYK(0x00000004),
IO_OUTPUTPDFA(0x00000008),
IO_XMPMETADATA(0x00000010),
IO_OUTPUTPDFA8(0x00000020),
IO_NOPRECOMPRESSED(0x00000040),
IO_OUTPUTPDFX1(0x00000080),
IO_OUTPUTPDFX3(0x00000100),
IO_COMPRESSJBIG2(0x00000100), // It cannot be used for PDF/X creation
IO_SIMPOSTSCRIPT(0x80000000);
private int value;
private acImageOptions(int value)
{
this.value = value;
}
public Object value(){
return value;
}
}
public enum acFileNameOptions
{
// Please check FileNameOptions for the complete version of the flags
NoPrompt(0x00000001),
UseFileName(0x00000002),
Concatenate(0x00000004),
DisableCompression(0x00000008),
EmbedFonts(0x00000010),
BroadcastMessages(0x00000020),
PrintWatermark(0x00000040),
MultilingualSupport(0x00000080),
EncryptDocument(0x00000100), // It cannot be used for PDF/X creation
EmbedStandardFonts(0x00200000),
EmbedLicensedFonts(0x00400000),
Jpeg2000Compression(0x01000000), // It cannot be used for PDF/X creation
EncryptDocument128(0x40000000); // It cannot be used for PDF/X creation
private int value;
private acFileNameOptions(int value)
{
this.value = value;
}
public Object value(){
return value;
} }
public static void main(String[] args)
{
// Constants for Activation codes
String strLicenseTo = "Amyuni PDF Converter Evaluation";
String strActivationCode = "07EFCDAB0100010025AFF1801CB9441306C5739F7D452154D8833B9CECBA2ADE79E3762A69FFC354528A5F4A5811BE3204A0A439F5BA";
String AMYUNIPRINTERNAME = "Amyuni PDF Converter";
// Declare a new cdintfex object if it doesn' t exist in the form.
ActiveXComponent pdf = new ActiveXComponent("CDIntfEx.CDIntfEx.6.5");
// Get a reference to the installed printer.
// This will fail if the printer name passed to the DriverInit method is
// not found in the printer’s folder
Dispatch.call(pdf,"DriverInit",AMYUNIPRINTERNAME);
// The SetDefaultPrinter function sets the system default printer to the one
// initialized by the DriverInit functions.
Dispatch.call(pdf,"SetDefaultPrinter");
// The EnablePrinter() method needs to be called right before each print job.
// and before the configuration
// Calling the EnablePrinter() method will start a 20 second time-out value
Dispatch.call(pdf,"EnablePrinter", strLicenseTo, strActivationCode);
// Resulting PDF document stored here
Dispatch.put(pdf,"DefaultDirectory","C:\temp");
// Set Printer options
Dispatch.put(pdf,"FileNameOptionsEx",acFileNameOptions.NoPrompt.value | acFileNameOptions.EmbedFonts.value
| acFileNameOptions.MultilingualSupport.value | acFileNameOptions.EmbedStandardFonts.value
| acFileNameOptions.EmbedLicensedFonts.value);
// Set Image conversion options to create PDF/X-1a
Dispatch.put(pdf, "ImageOptions", acImageOptions.IO_OUTPUTPDFX1.value | acImageOptions.IO_XMPMETADATA.value | acImageOptions.IO_CONVERTTOCMYK.value);
// /Set the ColorProfile option
Dispatch.call(pdf, "SetColorProfile", "C:\temp\\AmyuniCMYK.icc");
// Apply Settings
Dispatch.call(pdf, "SetDefaultConfig");
// The BatchConvert method converts a number of files to PDF.
Dispatch.call(pdf,"BatchConvert","C:\temp\\*.docx");
// The RestoreDefaultPrinter function resets the system default printer
// to the printer that was the default before the call to SetDefaultPrinter.
Dispatch.call(pdf,"RestoreDefaultPrinter");
// Close Printer
Dispatch.call(pdf,"DriverEnd");
// Destroy PDF object
pdf = null;
}
}
$acImageOptions = @{
IO_NODUPLICATES = 0x00000001
IO_DOWNSAMPLE = 0x00000002
IO_CONVERTTOCMYK = 0x00000004
IO_OUTPUTPDFA = 0x00000008
IO_XMPMETADATA = 0x00000010
IO_OUTPUTPDFA8 = 0x00000020
IO_NOPRECOMPRESSED = 0x00000040
IO_OUTPUTPDFX1 = 0x00000080
IO_OUTPUTPDFX3 = 0x00000100
IO_COMPRESSJBIG2 = 0x00000200 # It cannot be used with PDF/X standard
IO_ENABLEEPS = 0x40000000
IO_SIMPOSTSCRIPT = 0x80000000
}
# Please check FileNameOptions for the complete version of the flags
$acFileNameOptions = @{
NoPrompt = 0x00000001
UseFileName = 0x00000002
Concatenate = 0x00000004
DisableCompression = 0x00000008
EmbedFonts = 0x00000010
BroadcastMessages = 0x00000020
PrintWatermark = 0x00000040
MultilingualSupport = 0x00000080
EncryptDocument = 0x00000100 # It cannot be used with PDF/X standard
EmbedStandardFonts = 0x00200000
EmbedLicensedFonts = 0x00400000
Jpeg2000Compression = 0x01000000 # It cannot be used with PDF/X standard
EncryptDocument128 = 0x40000000 # It cannot be used with PDF/X standard
}
# Constants for Activation codes
$strLicenseTo = "Amyuni PDF Converter Evaluation"
$strActivationCode = "07EFCDAB0100010025AFF1801CB9441306C5739F7D452154D8833B9CECBA2ADE79E3762A69FFC354528A5F4A5811BE3204A0A439F5BA"
$AMYUNIPRINTERNAME = "Amyuni PDF Converter"
# Declare a new cdintfex object if it doesn' t exist in the form.
$PDF = New-Object -ComObject CDIntfEx.CDIntfEx.6.5
# Get a reference to the installed printer.
# This will fail if the printer name passed to the DriverInit method is
# not found in the printer’s folder
[System.__ComObject].InvokeMember('DriverInit', [System.Reflection.BindingFlags]::InvokeMethod,$null,$PDF,$AMYUNIPRINTERNAME)
# The SetDefaultPrinter function sets the system default printer to the one
# initialized by the DriverInit functions.
[System.__ComObject].InvokeMember('SetDefaultPrinter', [System.Reflection.BindingFlags]::InvokeMethod,$null,$PDF,$null)
# The EnablePrinter()method needs to be called right before each print job.
# and before the configuration
# Calling the EnablePrinter()method will start a 20 second time-out value
[System.__ComObject].InvokeMember('EnablePrinter', [System.Reflection.BindingFlags]::InvokeMethod,$null,$PDF, @($strLicenseTo, $strActivationCode))
# Resulting PDF document stored here
[System.__ComObject].InvokeMember('DefaultDirectory', [System.Reflection.BindingFlags]::SetProperty,$null,$PDF,"C:/Temp")
# Set Printer options
[System.__ComObject].InvokeMember('FileNameOptionsEx', [System.Reflection.BindingFlags]::SetProperty,$null,$PDF,$acFileNameOptions::NoPrompt `
-bOr $acFileNameOptions::EmbedFonts -bOr $acFileNameOptions::MultilingualSupport -bOr $acFileNameOptions::EmbedStandardFonts `
-bOr $acFileNameOptions::EmbedLicensedFonts)
# Set Image conversion options to create PDF/X-1a
[System.__ComObject].InvokeMember('ImageOptions', [System.Reflection.BindingFlags]::SetProperty,$null,$PDF,$acImageOptions::IO_OUTPUTPDFX1 `
-bOr $acImageOptions::IO_XMPMETADATA -bOr $acImageOptions::IO_CONVERTTOCMYK)
# Apply Settings
[System.__ComObject].InvokeMember('SetDefaultConfig', [System.Reflection.BindingFlags]::InvokeMethod,$null,$PDF, $null)
# The BatchConvert method converts a number of files to PDF.
[System.__ComObject].InvokeMember('BatchConvert', [System.Reflection.BindingFlags]::InvokeMethod,$null,$PDF, "C:\Temp\*.docx")
# The RestoreDefaultPrinter function resets the system default printer
# to the printer that was the default before the call to SetDefaultPrinter.
[System.__ComObject].InvokeMember('RestoreDefaultPrinter', [System.Reflection.BindingFlags]::InvokeMethod,$null,$PDF,$null)
# This function will simply detach from an existing printer because the handle was created using DriverInit
[System.__ComObject].InvokeMember('DriverEnd', [System.Reflection.BindingFlags]::InvokeMethod,$null,$PDF,$null)
# Destroy PDF object
$PDF = $null
' ImageOptions Constants
Const IO_NODUPLICATES = &H1
Const IO_DOWNSAMPLE = &H2
Const IO_CONVERTTOCMYK = &H4
Const IO_OUTPUTPDFA = &H8
Const IO_XMPMETADATA = &H10
Const IO_OUTPUTPDFA8 = &H20
Const IO_NOPRECOMPRESSED = &H40
Const IO_OUTPUTPDFX1 = &H80
Const IO_OUTPUTPDFX3 = &H100
Const IO_COMPRESSJBIG2 = &H200 ' It cannot be used with PDF/X standard
Const IO_ENABLEEPS = &H40000000
Const IO_SIMPOSTSCRIPT = &H80000000
' FileNameOptions constants
' Please check FileNameOptions for the complete version of the flags
NoPrompt = &H1
UseFileName = &H2
Concatenate = &H4
DisableCompression = &H8
EmbedFonts = &H10
BroadcastMessages = &H20
PrintWatermark = &H40
MultilingualSupport = &H80
EncryptDocument = &H100 ' It cannot be used with PDF/X standard
EmbedStandardFonts = &H200000
EmbedLicensedFonts = &H400000
Jpeg2000Compression = &H1000000 ' It cannot be used with PDF/X standard
EncryptDocument128 = &H40000000 ' It cannot be used with PDF/X standard
' Constants for Activation codes
Const strLicenseTo = "Amyuni PDF Converter Evaluation"
Const strActivationCode = "07EFCDAB0100010025AFF1801CB9441306C5739F7D452154D8833B9CECBA2ADE79E3762A69FFC354528A5F4A5811BE3204A0A439F5BA"
Const AMYUNIPRINTERNAME = "Amyuni PDF Converter"
' Declare a new cdintfex object
Dim PDF
Set PDF = CreateObject("CDIntfEx.CDIntfEx.6.5")
' Get a reference to the installed printer.
' This will fail if the printer name passed to the DriverInit method is
' not found in the printer’s folder
PDF.DriverInit AMYUNIPRINTERNAME
' The SetDefaultPrinter function sets the system default printer to the one
' initialized by the DriverInit functions.
PDF.SetDefaultPrinter
' The EnablePrinter() method needs to be called right before each print job.
' and before the configuration
' Calling the EnablePrinter() method will start a 20 second time-out value
PDF.EnablePrinter strLicenseTo, strActivationCode
' Resulting PDF document stored here
PDF.DefaultDirectory = "C:\Temp"
' Set Printer options
PDF.FileNameOptionsEx = NoPrompt Or EmbedFonts Or MultilingualSupport Or EmbedStandardFonts Or EmbedLicensedFonts
' Set Image conversion options to create PDF/X-1a
PDF.ImageOptions = IO_OUTPUTPDFX1 Or IO_XMPMETADATA Or IO_CONVERTTOCMYK
' Set the ColorProfile option
PDF.SetColorProfile("C:\temp\AmyuniCMYK.icc")
' Apply Settings
PDF.SetDefaultConfig
' The BatchConvert method converts a number of files to PDF.
PDF.BatchConvert "C:\Temp\test.doc"
' The RestoreDefaultPrinter function resets the system default printer
' to the printer that was the default before the call to SetDefaultPrinter.
PDF.RestoreDefaultPrinter
' This function will simply detach from an existing printer because the handle was created using DriverInit
PDF.DriverEnd
' Destroy PDF object
Set PDF = Nothing
The Evaluation License adds a watermark which breaks the PDF/X specification. Only the Full License will give you a proper PDF/X file.
<Flags()>
Public Enum acImageOptions As Integer
IO_NODUPLICATES = &H1
IO_DOWNSAMPLE = &H2
IO_CONVERTTOCMYK = &H4
IO_OUTPUTPDFA = &H8
IO_XMPMETADATA = &H10
IO_OUTPUTPDFA8 = &H20
IO_NOPRECOMPRESSED = &H40
IO_OUTPUTPDFX1 = &H80
IO_OUTPUTPDFX3 = &H100
IO_COMPRESSJBIG2 = &H200 ' It cannot be used with PDF/X standard
IO_ENABLEEPS = &H40000000
IO_SIMPOSTSCRIPT = &H80000000
End Enum
<Flags()>
Public Enum acFileNameOptions As Integer
' Please check FileNameOptions for the complete version of the flags
NoPrompt = &H1
UseFileName = &H2
Concatenate = &H4
DisableCompression = &H8
EmbedFonts = &H10
BroadcastMessages = &H20
PrintWatermark = &H40
MultilingualSupport = &H80
EncryptDocument = &H100 ' It cannot be used with PDF/X standard
EmbedStandardFonts = &H200000
EmbedLicensedFonts = &H400000
Jpeg2000Compression = &H1000000 ' It cannot be used with PDF/X standard
EncryptDocument128 = &H40000000 ' It cannot be used with PDF/X standard
End Enum
Sub Sample()
' Constants for Activation codes
Const strLicenseTo As String = "Amyuni PDF Converter Evaluation"
Const strActivationCode As String = "07EFCDAB0100010025AFF1801CB9441306C5739F7D452154D8833B9CECBA2ADE79E3762A69FFC354528A5F4A5811BE3204A0A439F5BA"
Const AMYUNIPRINTERNAME As String = "Amyuni PDF Converter"
' Declare a new cdintfex object if it does not exist in the form.
Dim PDF As New CDIntfEx.CDIntfEx
' Get a reference to the installed printer.
' This will fail if the printer name passed to the DriverInit method is
' not found in the printer’s folder
PDF.DriverInit(AMYUNIPRINTERNAME)
' The SetDefaultPrinter function sets the system default printer to the one
' initialized by the DriverInit functions.
PDF.SetDefaultPrinter()
' The EnablePrinter() method needs to be called right before each print job.
' and before the configuration
' Calling the EnablePrinter() method will start a 20 second time-out value
PDF.EnablePrinter(strLicenseTo, strActivationCode)
' Resulting PDF document stored here
PDF.DefaultDirectory = "C:\Temp"
' Set Printer options
PDF.FileNameOptionsEx = acFileNameOptions.NoPrompt Or acFileNameOptions.EmbedFonts _
Or acFileNameOptions.MultilingualSupport Or acFileNameOptions.EmbedStandardFonts _
Or acFileNameOptions.EmbedLicensedFonts
' Set Image conversion options to create PDF/X-3
PDF.ImageOptions = acImageOptions.IO_OUTPUTPDFX3 Or acImageOptions.IO_XMPMETADATA
' Set the ColorProfile option
PDF.SetColorProfile("C:\temp\AmyuniCMYK.icc")
' Apply Settings
PDF.SetDefaultConfig()
' The BatchConvert method converts a number of files to PDF.
PDF.BatchConvert("C:\Temp\*.docx")
' The RestoreDefaultPrinter function resets the system default printer
' to the printer that was the default before the call to SetDefaultPrinter.
PDF.RestoreDefaultPrinter()
' This function will simply detach from an existing printer because the handle was created using DriverInit
PDF.DriverEnd()
' Destroy PDF object
PDF = Nothing
End Sub
[Flags]
public enum acImageOptions
{
IO_NODUPLICATES = 0x00000001,
IO_DOWNSAMPLE = 0x00000002,
IO_CONVERTTOCMYK = 0x00000004,
IO_OUTPUTPDFA = 0x00000008,
IO_XMPMETADATA = 0x00000010,
IO_OUTPUTPDFA8 = 0x00000020,
IO_NOPRECOMPRESSED = 0x00000040,
IO_OUTPUTPDFX1 = 0x00000080,
IO_OUTPUTPDFX3 = 0x00000100,
IO_COMPRESSJBIG2 = 0x00000200, // It cannot be used with PDF/X standard
IO_ENABLEEPS = 0x40000000,
IO_SIMPOSTSCRIPT = unchecked((int)0x80000000)
}
[Flags]
public enum acFileNameOptions
{
// Please check FileNameOptions for the complete version of the flags
NoPrompt = 0x00000001,
UseFileName = 0x00000002,
Concatenate = 0x00000004,
DisableCompression = 0x00000008,
EmbedFonts = 0x00000010,
BroadcastMessages = 0x00000020,
PrintWatermark = 0x00000040,
MultilingualSupport = 0x00000080,
EncryptDocument = 0x00000100, // It cannot be used with PDF/X standard
EmbedStandardFonts = 0x00200000,
EmbedLicensedFonts = 0x00400000,
Jpeg2000Compression = 0x01000000, // It cannot be used with PDF/X standard
EncryptDocument128 = 0x40000000 // It cannot be used with PDF/X standard
}
static void Sample()
{
// Constants for Activation codes
const string strLicenseTo = "Amyuni PDF Converter Evaluation";
const string strActivationCode = "07EFCDAB0100010025AFF1801CB9441306C5739F7D452154D8833B9CECBA2ADE79E3762A69FFC354528A5F4A5811BE3204A0A439F5BA";
const string AMYUNIPRINTERNAME = "Amyuni PDF Converter";
// Declare a new cdintfex object if it does not exist in the form.
CDIntfEx.CDIntfEx PDF = new CDIntfEx.CDIntfEx();
// Get a reference to the installed printer.
// This will fail if the printer name passed to the DriverInit method is
// not found in the printer’s folder
PDF.DriverInit(AMYUNIPRINTERNAME);
// The SetDefaultPrinter function sets the system default printer to the one
// initialized by the DriverInit functions.
PDF.SetDefaultPrinter();
// The EnablePrinter() method needs to be called right before each print job.
// and before the configuration
// Calling the EnablePrinter() method will start a 20 second time-out value
PDF.EnablePrinter(strLicenseTo, strActivationCode);
// Resulting PDF document stored here
PDF.DefaultDirectory = @"C:\Temp";
// Set Printer options
PDF.FileNameOptionsEx = (int)(acFileNameOptions.NoPrompt | acFileNameOptions.EmbedFonts
| acFileNameOptions.MultilingualSupport | acFileNameOptions.EmbedStandardFonts
| acFileNameOptions.EmbedLicensedFonts);
// Set Image conversion options to create PDF/X-3
PDF.ImageOptions = (int)(acImageOptions.IO_OUTPUTPDFX3 | acImageOptions.IO_XMPMETADATA);
// Set the ColorProfile option
PDF.SetColorProfile(@"C:\temp\AmyuniCMYK.icc");
// Apply Settings
PDF.SetDefaultConfig();
// The BatchConvert method converts a number of files to PDF.
PDF.BatchConvert(@"C:\Temp\*.docx");
// The RestoreDefaultPrinter function resets the system default printer
// to the printer that was the default before the call to SetDefaultPrinter.
PDF.RestoreDefaultPrinter();
// This function will simply detach from an existing printer because the handle was created using DriverInit
PDF.DriverEnd();
}
// PDF Converter Cpp.cpp : Defines the entry point for the console application.
//
# include <Windows.h>
# include <string>
# include <iostream>
# include "CdIntf.h"
# pragma comment (lib, "CDIntf.lib")
using namespace std;
int main()
{
// Constants for Activation codes
# define strLicenseTo "Amyuni PDF Converter Evaluation"
# define strActivationCode "07EFCDAB0100010025AFF1801CB9441306C5739F7D452154D8833B9CECBA2ADE79E3762A69FFC354528A5F4A5811BE3204A0A439F5BA"
# define AMYUNIPRINTERNAME "Amyuni PDF Converter"
// Get a reference to the installed printer.
// This will fail if the printer name passed to the DriverInit method is
// not found in the printer’s folder
HANDLE PDF = DriverInit(AMYUNIPRINTERNAME);
// The CDISetDefaultPrinter function sets the system default printer to the one
// initialized by the DriverInit functions.
CDISetDefaultPrinter(PDF);
// The EnablePrinter() method needs to be called right before each print job.
// and before the configuration
// Calling the EnablePrinter() method will start a 20 second time-out value
EnablePrinter(PDF, strLicenseTo, strActivationCode);
// Resulting PDF document stored here
SetDefaultDirectory(PDF, "C:\temp");
// Set Printer options
// EncryptDocument, Jpeg2000Compression nor EncryptDocument128 cannot be used with PDF/A standard
SetFileNameOptions(PDF, NoPrompt | EmbedFonts | MultilingualSupport | EmbedStandardFonts | EmbedLicensedFonts | FullEmbed);
// Set Image conversion options to create PDF/X-3
SetImageOptions(PDF, IO_OUTPUTPDFX3 | IO_XMPMETADATA);
// Set the ColorProfile option
SetColorProfile(PDF, "C:\temp\\AmyuniCMYK.icc");
// Apply Settings
SetDefaultConfig(PDF);
// The BatchConvert method converts a number of files to PDF.
BatchConvertEx(PDF, "C:\temp\\*.docx");
// The RestoreDefaultPrinter function resets the system default printer
// to the printer that was the default before the call to SetDefaultPrinter.
RestoreDefaultPrinter(PDF);
// This function will simply detach from an existing printer because the handle was created using DriverInit
DriverEnd(PDF);
// Destroy PDF object
PDF = nullptr;
return 0;
}
package Example;
import com.jacob.activeX.ActiveXComponent;
import com.jacob.com.Dispatch;
public class Sample {
public enum acImageOptions
{
IO_NODUPLICATES(0x00000001),
IO_DOWNSAMPLE(0x00000002),
IO_CONVERTTOCMYK(0x00000004),
IO_OUTPUTPDFA(0x00000008),
IO_XMPMETADATA(0x00000010),
IO_OUTPUTPDFA8(0x00000020),
IO_NOPRECOMPRESSED(0x00000040),
IO_OUTPUTPDFX1(0x00000080),
IO_OUTPUTPDFX3(0x00000100),
IO_COMPRESSJBIG2(0x00000100), // It cannot be used for PDF/X creation
IO_SIMPOSTSCRIPT(0x80000000);
private int value;
private acImageOptions(int value)
{
this.value = value;
}
public Object value(){
return value;
}
}
public enum acFileNameOptions
{
// Please check FileNameOptions for the complete version of the flags
NoPrompt(0x00000001),
UseFileName(0x00000002),
Concatenate(0x00000004),
DisableCompression(0x00000008),
EmbedFonts(0x00000010),
BroadcastMessages(0x00000020),
PrintWatermark(0x00000040),
MultilingualSupport(0x00000080),
EncryptDocument(0x00000100), // It cannot be used for PDF/X creation
EmbedStandardFonts(0x00200000),
EmbedLicensedFonts(0x00400000),
Jpeg2000Compression(0x01000000), // It cannot be used for PDF/X creation
EncryptDocument128(0x40000000); // It cannot be used for PDF/X creation
private int value;
private acFileNameOptions(int value)
{
this.value = value;
}
public Object value(){
return value;
} }
public static void main(String[] args)
{
// Constants for Activation codes
String strLicenseTo = "Amyuni PDF Converter Evaluation";
String strActivationCode = "07EFCDAB0100010025AFF1801CB9441306C5739F7D452154D8833B9CECBA2ADE79E3762A69FFC354528A5F4A5811BE3204A0A439F5BA";
String AMYUNIPRINTERNAME = "Amyuni PDF Converter";
// Declare a new cdintfex object if it doesn' t exist in the form.
ActiveXComponent pdf = new ActiveXComponent("CDIntfEx.CDIntfEx.6.5");
// Get a reference to the installed printer.
// This will fail if the printer name passed to the DriverInit method is
// not found in the printer’s folder
Dispatch.call(pdf,"DriverInit",AMYUNIPRINTERNAME);
// The SetDefaultPrinter function sets the system default printer to the one
// initialized by the DriverInit functions.
Dispatch.call(pdf,"SetDefaultPrinter");
// The EnablePrinter() method needs to be called right before each print job.
// and before the configuration
// Calling the EnablePrinter() method will start a 20 second time-out value
Dispatch.call(pdf,"EnablePrinter", strLicenseTo, strActivationCode);
// Resulting PDF document stored here
Dispatch.put(pdf,"DefaultDirectory","C:\temp");
// Set Printer options
Dispatch.put(pdf,"FileNameOptionsEx",acFileNameOptions.NoPrompt.value | acFileNameOptions.EmbedFonts.value
| acFileNameOptions.MultilingualSupport.value | acFileNameOptions.EmbedStandardFonts.value
| acFileNameOptions.EmbedLicensedFonts.value);
// Set Image conversion options to create PDF/X-3
Dispatch.put(pdf, "ImageOptions", acImageOptions.IO_OUTPUTPDFX3.value | acImageOptions.IO_XMPMETADATA.value);
// /Set the ColorProfile option
Dispatch.call(pdf, "SetColorProfile", "C:\temp\\AmyuniCMYK.icc");
// Apply Settings
Dispatch.call(pdf, "SetDefaultConfig");
// The BatchConvert method converts a number of files to PDF.
Dispatch.call(pdf,"BatchConvert","C:\temp\\*.docx");
// The RestoreDefaultPrinter function resets the system default printer
// to the printer that was the default before the call to SetDefaultPrinter.
Dispatch.call(pdf,"RestoreDefaultPrinter");
// Close Printer
Dispatch.call(pdf,"DriverEnd");
// Destroy PDF object
pdf = null;
}
}
$acImageOptions = @{
IO_NODUPLICATES = 0x00000001
IO_DOWNSAMPLE = 0x00000002
IO_CONVERTTOCMYK = 0x00000004
IO_OUTPUTPDFA = 0x00000008
IO_XMPMETADATA = 0x00000010
IO_OUTPUTPDFA8 = 0x00000020
IO_NOPRECOMPRESSED = 0x00000040
IO_OUTPUTPDFX1 = 0x00000080
IO_OUTPUTPDFX3 = 0x00000100
IO_COMPRESSJBIG2 = 0x00000200 # It cannot be used with PDF/X standard
IO_ENABLEEPS = 0x40000000
IO_SIMPOSTSCRIPT = 0x80000000
}
# Please check FileNameOptions for the complete version of the flags
$acFileNameOptions = @{
NoPrompt = 0x00000001
UseFileName = 0x00000002
Concatenate = 0x00000004
DisableCompression = 0x00000008
EmbedFonts = 0x00000010
BroadcastMessages = 0x00000020
PrintWatermark = 0x00000040
MultilingualSupport = 0x00000080
EncryptDocument = 0x00000100 # It cannot be used with PDF/X standard
EmbedStandardFonts = 0x00200000
EmbedLicensedFonts = 0x00400000
Jpeg2000Compression = 0x01000000 # It cannot be used with PDF/X standard
EncryptDocument128 = 0x40000000 # It cannot be used with PDF/X standard
}
# Constants for Activation codes
$strLicenseTo = "Amyuni PDF Converter Evaluation"
$strActivationCode = "07EFCDAB0100010025AFF1801CB9441306C5739F7D452154D8833B9CECBA2ADE79E3762A69FFC354528A5F4A5811BE3204A0A439F5BA"
$AMYUNIPRINTERNAME = "Amyuni PDF Converter"
# Declare a new cdintfex object if it doesn' t exist in the form.
$PDF = New-Object -ComObject CDIntfEx.CDIntfEx.6.5
# Get a reference to the installed printer.
# This will fail if the printer name passed to the DriverInit method is
# not found in the printer’s folder
[System.__ComObject].InvokeMember('DriverInit', [System.Reflection.BindingFlags]::InvokeMethod,$null,$PDF,$AMYUNIPRINTERNAME)
# The SetDefaultPrinter function sets the system default printer to the one
# initialized by the DriverInit functions.
[System.__ComObject].InvokeMember('SetDefaultPrinter', [System.Reflection.BindingFlags]::InvokeMethod,$null,$PDF,$null)
# The EnablePrinter()method needs to be called right before each print job.
# and before the configuration
# Calling the EnablePrinter()method will start a 20 second time-out value
[System.__ComObject].InvokeMember('EnablePrinter', [System.Reflection.BindingFlags]::InvokeMethod,$null,$PDF, @($strLicenseTo, $strActivationCode))
# Resulting PDF document stored here
[System.__ComObject].InvokeMember('DefaultDirectory', [System.Reflection.BindingFlags]::SetProperty,$null,$PDF,"C:/Temp")
# Set Printer options
[System.__ComObject].InvokeMember('FileNameOptionsEx', [System.Reflection.BindingFlags]::SetProperty,$null,$PDF,$acFileNameOptions::NoPrompt `
-bOr $acFileNameOptions::EmbedFonts -bOr $acFileNameOptions::MultilingualSupport -bOr $acFileNameOptions::EmbedStandardFonts `
-bOr $acFileNameOptions::EmbedLicensedFonts)
# Set Image conversion options to create PDF/X-3
[System.__ComObject].InvokeMember('ImageOptions', [System.Reflection.BindingFlags]::SetProperty,$null,$PDF,$acImageOptions::IO_OUTPUTPDFX1 `
-bOr $acImageOptions::IO_XMPMETADATA)
# Apply Settings
[System.__ComObject].InvokeMember('SetDefaultConfig', [System.Reflection.BindingFlags]::InvokeMethod,$null,$PDF, $null)
# The BatchConvert method converts a number of files to PDF.
[System.__ComObject].InvokeMember('BatchConvert', [System.Reflection.BindingFlags]::InvokeMethod,$null,$PDF, "C:\Temp\*.docx")
# The RestoreDefaultPrinter function resets the system default printer
# to the printer that was the default before the call to SetDefaultPrinter.
[System.__ComObject].InvokeMember('RestoreDefaultPrinter', [System.Reflection.BindingFlags]::InvokeMethod,$null,$PDF,$null)
# This function will simply detach from an existing printer because the handle was created using DriverInit
[System.__ComObject].InvokeMember('DriverEnd', [System.Reflection.BindingFlags]::InvokeMethod,$null,$PDF,$null)
# Destroy PDF object
$PDF = $null
' ImageOptions Constants
Const IO_NODUPLICATES = &H1
Const IO_DOWNSAMPLE = &H2
Const IO_CONVERTTOCMYK = &H4
Const IO_OUTPUTPDFA = &H8
Const IO_XMPMETADATA = &H10
Const IO_OUTPUTPDFA8 = &H20
Const IO_NOPRECOMPRESSED = &H40
Const IO_OUTPUTPDFX1 = &H80
Const IO_OUTPUTPDFX3 = &H100
Const IO_COMPRESSJBIG2 = &H200 ' It cannot be used with PDF/A standard
Const IO_ENABLEEPS = &H40000000
Const IO_SIMPOSTSCRIPT = &H80000000
' FileNameOptions constants
' Please check FileNameOptions for the complete version of the flags
NoPrompt = &H1
UseFileName = &H2
Concatenate = &H4
DisableCompression = &H8
EmbedFonts = &H10
BroadcastMessages = &H20
PrintWatermark = &H40
MultilingualSupport = &H80
EncryptDocument = &H100 ' It cannot be used with PDF/X standard
EmbedStandardFonts = &H200000
EmbedLicensedFonts = &H400000
Jpeg2000Compression = &H1000000 ' It cannot be used with PDF/X standard
EncryptDocument128 = &H40000000 ' It cannot be used with PDF/X standard
' Constants for Activation codes
Const strLicenseTo = "Amyuni PDF Converter Evaluation"
Const strActivationCode = "07EFCDAB0100010025AFF1801CB9441306C5739F7D452154D8833B9CECBA2ADE79E3762A69FFC354528A5F4A5811BE3204A0A439F5BA"
Const AMYUNIPRINTERNAME = "Amyuni PDF Converter"
' Declare a new cdintfex object
Dim PDF
Set PDF = CreateObject("CDIntfEx.CDIntfEx.6.5")
' Get a reference to the installed printer.
' This will fail if the printer name passed to the DriverInit method is
' not found in the printer’s folder
PDF.DriverInit AMYUNIPRINTERNAME
' The SetDefaultPrinter function sets the system default printer to the one
' initialized by the DriverInit functions.
PDF.SetDefaultPrinter
' The EnablePrinter() method needs to be called right before each print job.
' and before the configuration
' Calling the EnablePrinter() method will start a 20 second time-out value
PDF.EnablePrinter strLicenseTo, strActivationCode
' Resulting PDF document stored here
PDF.DefaultDirectory = "C:\Temp"
' Set Printer options
PDF.FileNameOptionsEx = NoPrompt Or EmbedFonts Or MultilingualSupport Or EmbedStandardFonts Or EmbedLicensedFonts
' Set Image conversion options to create PDF/X-3
PDF.ImageOptions = IO_OUTPUTPDFX1 Or IO_XMPMETADATA
' Set the ColorProfile option
PDF.SetColorProfile("C:\temp\AmyuniCMYK.icc")
' Apply Settings
PDF.SetDefaultConfig
' The BatchConvert method converts a number of files to PDF.
PDF.BatchConvert "C:\Temp\test.doc"
' The RestoreDefaultPrinter function resets the system default printer
' to the printer that was the default before the call to SetDefaultPrinter.
PDF.RestoreDefaultPrinter
' This function will simply detach from an existing printer because the handle was created using DriverInit
PDF.DriverEnd
' Destroy PDF object
Set PDF = Nothing