This article applies only to novaPDF. If you don't have it yet, you must download it first.

Download now Buy licenses
Lorant (Softland)
Sep 17, 2019

novaPDF SDK 10, 9, 8

We strive to keep our articles as accurate as possible. If you notice any inconsistencies or outdated info please let us know.

This SDK sample shows how to convert an existing file to PDF by using the ShellExecute function in Visual Basic.

The VBNet Converter sample demonstrates how to convert an existing file by printing it to novaPDF Printer using the ShellExecute function. It also demonstrates how to set different options and manage profiles. The same approach should be used if you print using a Print() method from another object (like an internet browser or a report control). Just replace the ShellExecute call with the call of your Print method.

Note: To be able to use the samples you must install novaPDF SDK as samples work only with it. Download it here: novaPDF SDK.

When the application starts, it creates a few profiles and makes different settings in the profiles. Then it shows a dialog from where the user can select the active profile and change its settings using the controls from the dialog. After that a document can be selected from the harddisk and printed to novaPDF Printer using the ShellExecute function call.

When using this technique to convert a file to PDF, you have to take care of the fact that ShellExecute prints to the default printer. This function returns immediately and does not wait until the print is finished (it may return before the printing is actually started).

Therefore you have to set the default printer to novaPDF Printer before calling ShellExecute (using the SetDefaultPrinter method), wait the process to be started (using WaitForExit()), restore the default printer (with the RestoreDefaultPrinter method). This way you made sure that the default printer was restored and your document is printed to novaPDF Printer.

Source Code Snippets

'1. Declare INovaPdfOptions variable
Private mobjNovaOptios As NovaPdfOptions80Class

'2. Initialize INovaPdfOptions
mobjNovaOptios = New NovaPdfOptions80Class

' initialize the NovaPdfOptions object


'3. Set <%SDK_SAMPLE_PRINTER%> Options
    Dim newSmallSizeProfileId As String = ""
    ' add new profile
    mobjNovaOptios.AddProfile(SMALL_SIZE_PROFILE, PROFILE_IS_PUBLIC, newSmallSizeProfileId)

    'load the new profile

    ' Set some options to this profile
    ' disable the "Save PDF file as" prompt
    mobjNovaOptios.SetOptionLong(NovaOptions.NOVAPDF_SAVE_PROMPT_TYPE, 0)
    ' set generated Pdf files destination folder  "c:\"
    mobjNovaOptios.SetOptionString(NovaOptions.NOVAPDF_SAVE_FOLDER, "c:\\")

    // .....

Catch ComException As System.Runtime.InteropServices.COMException
    MessageBox.Show("Error creating Small Size Profile:" & Microsoft.VisualBasic.Chr(13) & "" & Microsoft.VisualBasic.Chr(10) & "" + ComException.Message)
End Try

'4. Start a Print job
Private Sub btnStartPrinting_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles btnStartPrinting.Click

    mobjNovaOptios.SetActiveProfile(CType((cmbProfiles.SelectedItem), String))
    Dim myProcess As Process = New Process
        myProcess.StartInfo.FileName = txtFileToConvert.Text
        myProcess.StartInfo.Verb = "Print"
        myProcess.StartInfo.CreateNoWindow = True
        myProcess.StartInfo.WindowStyle = ProcessWindowStyle.Hidden
    Catch ex As Win32Exception
        If ex.NativeErrorCode = ERROR_FILE_NOT_FOUND Then
            Console.WriteLine(ex.Message + ". Check the path and filename")
            ' Note that if your word processor might generate exceptions
            ' such as this, which are handled first.
            If ex.NativeErrorCode = ERROR_ACCESS_DENIED Then
                Console.WriteLine(ex.Message + ". You do not have permission to print this file.")
            End If
        End If
    End Try
End Sub