ColorProfile

The SetColorProfile method is used to attach a color profile to the Document Converter printer.

 

Syntax

ActiveX:

System.Boolean SetColorProfile(System.String ProfileName)

DLL:

int SetColorProfile(HANDLE hPrinter, LPCSTR szColorProfile);

 

Parameters

ProfileName, szColorProfile

Name of the color profile to be attached.

hPrinter

Handle to printer returned by any of the DriverInit function calls.

 

Return Value

Returns Value True or 1 if the method succeeds, False or 0 otherwise.

 

Remarks

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 CDIntfEx.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.

 

ProfileName can be either the name of the profile with the extension (e.g. AmyuniCMYK.icc) if the color profile is already installed on the system, or the full path to where the profile is located.

In addition to attaching a color profile, the PDF printer should be configured for CMYK conversion by using IO_CONVERTTOCMYK in ImageOptions property.

 

Member of CDIntfEx.CDIntfEx.

 

Example

<Flags()>
Public Enum FILENAMEOPTIONS As Integer
    ' Please check FileNameOptions for the complete flags version
    NoPrompt = &H1
    UseFileName = &H2
    Concatenate = &H4
    DisableCompression = &H8
    EmbedFonts = &H10
    BroadcastMessages = &H20
    PrintWatermark = &H40
End Enum
 
<Flags()>
Public Enum IMAGEOPTIONS 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
    IO_ENABLEEPS = &H40000000
    IO_SIMPOSTSCRIPT = &H80000000
End Enum
 
Public Sub Sample()
    ' Constants for Activation codes
    Const strLicenseTo As String = "Amyuni PDF Converter Evaluation"
    Const strActivationCode As String = "07EFCDAB0100010025AFF180A1B9441306C5739F7D452154DB83BB9CECBA2ADE79E3762A69FFC354528A5F4A5811BE3204A0A439F5BA"
    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()
 
    ' Resulting PDF document stored here
    PDF.DefaultDirectory = "C:\Temp"
 
    ' Set Printer options
    PDF.FileNameOptionsEx = FILENAMEOPTIONS.NoPrompt
 
    ' The EnablePrinter() method needs to be called right before each print job. 
    ' Calling the EnablePrinter() method will start a 20 second time-out value
    PDF.EnablePrinter(strLicenseTo, strActivationCode)
 
    ' Set Image conversion options in IO_CONVERTTOCMYK (Mandatory)
    PDF.ImageOptions = IMAGEOPTIONS.IO_CONVERTTOCMYK
 
    ' Set the ColorProfile option locate in %WINDIR%\system32\spool\drivers\color
    PDF.SetColorProfile("AmyuniCMYK")
 
    ' 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 FILENAMEOPTIONS
{
    // Please check FileNameOptions for the complete flags version
    NoPrompt = 0x00000001,
    UseFileName = 0x00000002,
    Concatenate = 0x00000004,
    DisableCompression = 0x00000008,
    EmbedFonts = 0x00000010,
    BroadcastMessages = 0x00000020,
    PrintWatermark = 0x00000040
}
 
 [Flags]
public enum IMAGEOPTIONS
{
    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 ,
    IO_ENABLEEPS = 0x40000000 ,
    IO_SIMPOSTSCRIPT = unchecked((int)0x80000000)
}
 
public void Sample()
{
    // Constants for Activation codes
    const string strLicenseTo = "Amyuni PDF Converter Evaluation";
    const string strActivationCode = "07EFCDAB0100010025AFF180A1B9441306C5739F7D452154DB83BB9CECBA2ADE79E3762A69FFC354528A5F4A5811BE3204A0A439F5BA";
    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();
 
    // Resulting PDF document stored here
    PDF.DefaultDirectory = @"C:\Temp";
 
    // Set Printer options
    PDF.FileNameOptionsEx = (int)FILENAMEOPTIONS.NoPrompt;
 
    // The EnablePrinter() method needs to be called right before each print job. 
    // Calling the EnablePrinter() method will start a 20 second time-out value
    PDF.EnablePrinter(strLicenseTo, strActivationCode);
 
    // Set Image conversion options in IO_CONVERTTOCMYK (Mandatory)
    PDF.ImageOptions = (int)IMAGEOPTIONS.IO_CONVERTTOCMYK;
 
    // Set the ColorProfile option locate in %WINDIR%\system32\spool\drivers\color
    PDF.SetColorProfile("AmyuniCMYK");
 
    // 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 = null;    
}
// 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 "07EFCDAB0100010025AFF180A1B9441306C5739F7D452154DB83BB9CECBA2ADE79E3762A69FFC354528A5F4A5811BE3204A0A439F5BA"
    #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);
 
    // Resulting PDF document stored here
    SetDefaultDirectory(PDF, "c:\\Temp");
 
    // Set Printer options
    SetFileNameOptions(PDF, NoPrompt);
 
    // The EnablePrinter() method needs to be called right before each print job. 
    // Calling the EnablePrinter() method will start a 20 second time-out value
    EnablePrinter(PDF, strLicenseTo, strActivationCode);
 
    // Set Image conversion options in IO_CONVERTTOCMYK (Mandatory)
    SetImageOptions(PDF, IO_CONVERTTOCMYK);
 
    // Set the ColorProfile option locate in %WINDIR%\system32\spool\drivers\color
    SetColorProfile(PDF, "AmyuniCMYK");
 
    // 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 IMAGEOPTIONS
    {
        // Please check FileNameOptions for the complete flags version
        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),
        IO_ENABLEEPS( 0x40000000),
        IO_SIMPOSTSCRIPT( 0x80000000);
        public int value;
        public IMAGEOPTIONS(int value)
        {
            this.value = value;
        }
        public Object value(){
            return value;
        }        
    }
 
    public enum FILENAMEOPTIONS
    {
        // Please check FileNameOptions for the complete flags version
        NoPrompt(0x00000001),
        UseFileName(0x00000002),
        Concatenate(0x00000004),
        DisableCompression(0x00000008),
        EmbedFonts(0x00000010),
        BroadcastMessages(0x00000020),
        PrintWatermark(0x00000040);
        public int value;
        public FILENAMEOPTIONS(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 = "07EFCDAB0100010025AFF180A1B9441306C5739F7D452154DB83BB9CECBA2ADE79E3762A69FFC354528A5F4A5811BE3204A0A439F5BA";
        String AMYUNIPRINTERNAME = "Amyuni PDF Converter";
 
        // Declare a new cdintfex object if it does not exist in the form.
        ActiveXComponent pdf = new ActiveXComponent("CDIntfEx.CDIntfEx.6.0"); 
 
        // 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");
 
        // Resulting PDF document stored here
        Dispatch.put(pdf,"DefaultDirectory","c:\\Temp");
 
        // Set Printer options
        Dispatch.put(pdf,"FileNameOptionsEx",FILENAMEOPTIONS.NoPrompt.value);
 
        // The EnablePrinter() method needs to be called right before each print job. 
        // Calling the EnablePrinter() method will start a 20 second time-out value
        Dispatch.call(pdf,"EnablePrinter", strLicenseTo, strActivationCode); 
 
        // Set Image conversion options in IO_CONVERTTOCMYK (Mandatory)
        Dispatch.put(pdf,"ImageOptions", IMAGEOPTIONS.IO_CONVERTTOCMYK.value);
 
        // Set the ColorProfile option locate in %WINDIR%\system32\spool\drivers\color
        Dispatch.put(pdf, "SetColorProfile", "AmyuniCMYK");
 
        // 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"); 
 
        // This function will simply detach from an existing printer because the handle was created using DriverInit
        Dispatch.call(pdf,"DriverEnd");
 
        // Destroy PDF object
        pdf = null;        
    }
}
$IMAGEOPTIONS = @{
    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 
    IO_ENABLEEPS = 0x40000000 
    IO_SIMPOSTSCRIPT = 0x80000000
 
$FILENAMEOPTIONS = @{
    NoPrompt = 0x00000001
    UseFileName = 0x00000002
    Concatenate = 0x00000004
    DisableCompression = 0x00000008
    EmbedFonts = 0x00000010
    BroadcastMessages = 0x00000020
    PrintWatermark = 0x00000040
#Please check FileNameOptions for the complete flags version
 
# Constants for Activation codes
$strLicenseTo  =  "Amyuni PDF Converter Evaluation"
$strActivationCode = "07EFCDAB0100010025AFF180A1B9441306C5739F7D452154DB83BB9CECBA2ADE79E3762A69FFC354528A5F4A5811BE3204A0A439F5BA"
$AMYUNIPRINTERNAME = "Amyuni PDF Converter"
 
#Declare a new cdintfex object if it does not exist in the form.
$PDF = New-Object -ComObject CDIntfEx.CDIntfEx.6.0
 
#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) 
 
#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,$FILENAMEOPTIONS::NoPrompt)
 
#The EnablePrinter() method needs to be called right before each print job. 
#Calling the EnablePrinter() method will start a 20 second time-out value
[System.__ComObject].InvokeMember('EnablePrinter' ,[System.Reflection.BindingFlags]::InvokeMethod,$null,$PDF, @($strLicenseTo, $strActivationCode))
 
#Set Image conversion options in IO_CONVERTTOCMYK (Mandatory)
[System.__ComObject].InvokeMember('ImageOptions' ,[System.Reflection.BindingFlags]::SetProperty,$null,$PDF,$IMAGEOPTIONS::IO_CONVERTTOCMYK)
 
#Set the Postscript option locate in %WINDIR%\system32\spool\drivers\color
[System.__ComObject].InvokeMember('SetColorProfile' ,[System.Reflection.BindingFlags]::InvokeMethod,$null,$PDF,"AmyuniCMYK") 
 
#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 = 1
Const IO_DOWNSAMPLE = 2
Const IO_CONVERTTOCMYK = 4
Const IO_OUTPUTPDFA = 8
Const IO_XMPMETADATA = 16
Const IO_OUTPUTPDFA8 = 32
Const IO_NOPRECOMPRESSED = 64
Const IO_OUTPUTPDFX1 = 128
Const IO_OUTPUTPDFX3 = 256
Const IO_COMPRESSJBIG2 = 512
Const IO_ENABLEEPS = 1073741824
Const IO_SIMPOSTSCRIPT = 2147483648
 
' FileNameOptions constants
' Please check FileNameOptions for the complete flags version
Const NoPrompt = 1
Const UseFileName = 2
Const Concatenate = 4
Const DisableCompression = 8
Const EmbedFonts = 16
Const BroadcastMessages = 32
Const PrintWatermark = 64
Const MultilingualSupport = 128
Const EncryptDocument = 256
Const FullEmbed = 512
 
' Constants for Activation codes
Const strLicenseTo = "Amyuni PDF Converter Evaluation"
Const strActivationCode = "07EFCDAB0100010025AFF180A1B9441306C5739F7D452154DB83BB9CECBA2ADE79E3762A69FFC354528A5F4A5811BE3204A0A439F5BA"
Const AMYUNIPRINTERNAME = "Amyuni PDF Converter"
 
' Declare a new cdintfex object
Dim PDF
Set PDF = CreateObject("CDIntfEx.CDIntfEx.6.0")
 
' 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
 
' Resulting PDF document stored here
PDF.DefaultDirectory = "C:\Temp"
 
' Set Printer options
PDF.FileNameOptionsEx = NoPrompt
 
' The EnablePrinter() method needs to be called right before each print job.
' Calling the EnablePrinter() method will start a 20 second time-out value
PDF.EnablePrinter strLicenseTo, strActivationCode
 
' Set Image conversion options in IO_CONVERTTOCMYK (Mandatory)
PDF.ImageOptions = IO_CONVERTTOCMYK
 
' Set the ColorProfile option locate in %WINDIR%\system32\spool\drivers\color        
PDF.SetColorProfile("AmyuniCMYK")
 
' 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
Set PDF = Nothing