Combining Multiple PDF's with Foxit Phantom

Combining Multiple PDF's with Foxit Phantom

zachary.watsonTTAEZ
Participant Participant
3,536 Views
5 Replies
Message 1 of 6

Combining Multiple PDF's with Foxit Phantom

zachary.watsonTTAEZ
Participant
Participant

Hello forum readers,

 

I am currently working on a macro that will take an assembly drawing, print a pdf of it and pdf's of all the drawings for the parts within its BOM, and combine those PDF's into one pdf. I have successfully completed everything up to combining the pdf files into one file. I haven't had much experience trying to open and operate other programs within the inventor VBA environment and haven't had much luck in my google searches either. I have found a reference manual for using VBA code with Foxit Phantom, but the example codes have not worked for me (reference manual attached). My code is shown below and everything is fine until after the comment "Combine the files". Any help is appreciated with defining the variables properly and calling the program to combine the files. Thanks!

 

Sub Redline_Package()

Dim idwpathname As String
Dim pdfpathname As String
Dim newFolderPath As String
Dim combinedFolderPath As String
Dim combinedName As String
Dim oDoc As DrawingDocument
Dim oPrintMgr As PrintManager
Dim oRefDocs As DocumentsEnumerator
Dim oRefDoc As Document
Dim oPrtDoc As PartDocument
Dim numFiles As Integer
'Dim oNumberRefDocs As Integer
Dim oOpenDoc As Document
Set oPrintMgr = ThisApplication.ActiveDocument.PrintManager
Dim oDrgPrintMgr As DrawingPrintManager
Dim filelist As String ' list of open files
Dim FileName As String 'truncated filename
Dim MyTimeEnd, MytimeStart As String
Dim msg As Variant

'initialize variables
filelist = ""
numFiles = 1

' Sets variables based on file type
If ThisApplication.ActiveDocumentType = kDrawingDocumentObject Then
Set oDoc = ThisApplication.ActiveDocument
Set oRefDocs = oDoc.AllReferencedDocuments
' oNumberRefDocs = oRefDocs.count
'
' 'Subtract one because array numbering starts at 0 instead of 1
' oNumberRefDocs = oNumberRefDocs - 1

Else
msg = MsgBox("Not a valid file.", vbOKOnly, "Invalid")
Exit Sub

End If

On Error Resume Next

' Record list of open files

For Each oOpenDoc In ThisApplication.Documents.VisibleDocuments
filelist = filelist + ThisApplication.Documents.VisibleDocuments.Item(numFiles).FullDocumentName
numFiles = numFiles + 1

Next

'Create new folder path
newFolderPath = "P:\Lean Improvements\VBA Code\New Folder"

'Check if the folder exists, if it does then don't make one
If Dir(folderPath, vbDirectory) = "" Then

'Folder does not exist, so create it
MkDir newFolderPath

End If

'reinitialize variable
'numFiles = -1

''Create array for file names
'Dim nameArray() As Variant
'ReDim nameArray(oNumberRefDocs)

'Loop through assembly and parts and create redline package
For Each oRefDoc In oRefDocs
idwpathname = Left(oRefDoc.FullDocumentName, Len(oRefDoc.FullDocumentName) - 3) & "idw"
If fileExists(idwpathname) Then
Set oDoc = ThisApplication.Documents.Open(idwpathname, True)
oDoc.Activate

idwpathname = oDoc.FullDocumentName
idwpathname = Right(idwpathname, Len(idwpathname) - InStrRev(idwpathname, "\"))
idwpathname = Left(idwpathname, Len(idwpathname) - 4)

pdfpathname = newFolderPath & "\" & idwpathname & ".pdf"

'Creating string of filenames for combining later
combinedFolderPath = combinedFolderPath & "|" & pdfpathname

' 'place path name in array
' nameArray(numFiles) = pdfpathname

If fileExists(pdfpathname) Then ' ask if file should be overwritten
If MsgBox("File " & pdfpathname & " exists. Do you want to replace this file?", vbOKCancel, "Overwrite?") = vbCancel Then
' Me.Hide ' hide the form
' Unload Me
Exit Sub ' exit
Else
FileLock = IsFileLocked(pdfpathname)
Do While FileLock = True
a = MsgBox("File " & pdfpathname & " is locked and cannot be replaced. Check that it is not open in another application.", vbRetryCancel)
If a = vbCancel Then
' Me.Hide
' Unload Me
Exit Sub
End If
If IsFileLocked(pdfpathname) = False Then
FileLock = False
Exit Do
Else
FileLock = True
End If
Loop
End If
End If

'Save Copy of Part Drawing As a pdf
Set PDFAddIn = ThisApplication.ApplicationAddIns.ItemById("{0AC6FD96-2F4D-42CE-8BE0-8AEA580399E4}")

'Set a reference to the active document (the document to be published).
Set oPDFContext = ThisApplication.TransientObjects.CreateTranslationContext
oPDFContext.Type = kFileBrowseIOMechanism

' Create a NameValueMap object
Set oPDFOptions = ThisApplication.TransientObjects.CreateNameValueMap

' Create a DataMedium object
Set oPDFDataMedium = ThisApplication.TransientObjects.CreateDataMedium

' Check whether the translator has 'SaveCopyAs' options
If PDFAddIn.HasSaveCopyAsOptions(oDoc, oPDFContext, oPDFOptions) Then

' Options for drawings...
oPDFOptions.Value("All_Color_AS_Black") = 0
oPDFOptions.Value("Remove_Line_Weights") = 0
'oPDFOptions.Value("Vector_Resolution") = 400
oPDFOptions.Value("Sheet_Range") = kPrintAllSheets
'oPDFOptions.Value("Custom_Begin_Sheet") = 2
'oPDFOptions.Value("Custom_End_Sheet") = 4

End If

'Set the destination file name
oPDFDataMedium.FileName = pdfpathname

'Publish document.
Call PDFAddIn.SaveCopyAs(oDoc, oPDFContext, oPDFOptions, oPDFDataMedium)

idwpathname = Left(oRefDoc.FullDocumentName, Len(oRefDoc.FullDocumentName) - 3) & "idw"
FileName = Right(idwpathname, Len(idwpathname) - InStrRev(idwpathname, "\"))

If InStr(1, filelist, FileName, 1) = 0 Then ' If file was open at start, do not close it.
oDoc.Close (True) ' close lower level drawings

End If

End If
Next

'Create Combined File Name
combinedName = "Redline Package"

'Combine the files
Dim phCreator As FoxitPhantomPDF.Creator
Set phCreator = CreateObject("FoxitExch.Creator")
Call phCreator.CombineFiles(combinedFolderPath, newFolderPath & "\" & combinedName, COMBINE_ADD_CONTENTS)


End Sub

0 Likes
Accepted solutions (1)
3,537 Views
5 Replies
Replies (5)
Message 2 of 6

Michael.Navara
Advisor
Advisor

Please share the minimal reproducible piece of code. Especially when the code can't be tested.

In my opinion you have few syntax errors in your code. 

  • combinedFolderPath at line 84 is not correct
  • Variable COMBINE_ADD_CONTENTS is not declared

Try just to combine your files first. Here is short sample. Used files and folders must exist before. 

 

'Setup
Dim COMBINE_ADD_CONTENTS as Integer 
COMBINE_ADD_CONTENTS = 2
Dim phCreator As FoxitPhantomPDF.Creator
Set phCreator = CreateObject("FoxitExch.Creator")

'Combine all PDFs in directory sourceFolder
Dim sourceFolder as String 
sourceFolder = "C:\Temp\SourcePDFs"
Dim ouputFile1 as String
ouputFile1 = "C:\Temp\Output1.pdf"
Call phCreator.CombineFiles(sourceFolder, ouputFile1, COMBINE_ADD_CONTENTS)

'Combine individual files
Dim pdf1 as String
pdf1 = "C:\Temp\Drawing1.pdf"
Dim pdf2 as String
pdf2 = "C:\Temp\Drawing2.pdf"
Dim ouputFile2 as String
ouputFile2 = "C:\Temp\Output2.pdf"
Dim selectedPdfFiles as String
selectedPdfFiles = pdf1 & "|" & pdf2
Call phCreator.CombineFiles(selectedPdfFiles, ouputFile2, COMBINE_ADD_CONTENTS)

 

 I can't test this code, because I don't have access to FoxitPhantomPDF
0 Likes
Message 3 of 6

zachary.watsonTTAEZ
Participant
Participant

Hey Michael,

 

Thanks for tips. I will be better in the future about posting less code at my desired fail points. 

 

I tried running the sample test code and ran into the same problem that I experienced before (I commented out combining using a source folder and ran only the second half). The picture attached shows the error message and the highlighted code it is talking about. I think VBA might be trying to define phCreator as an object, but there is no object definition it knows called FoxitPhantomPDF.Creator. I feel like it would need to call it more, but I could be wrong.

0 Likes
Message 4 of 6

A.Acheson
Mentor
Mentor

Hi @zachary.watsonTTAEZ 

Here is a forum post that I tested in the past and works nicely. It is set up for the ilogic environment. Don't forget to kudos the or8gional poster if that works for you.

If this solved a problem, please click (accept) as solution.‌‌‌‌
Or if this helped you, please, click (like)‌‌
Regards
Alan
0 Likes
Message 5 of 6

Michael.Navara
Advisor
Advisor
Accepted solution

@zachary.watsonTTAEZ this error is shown because you don't have added reference to the FoxitPhantomPDF API. But I don't know, how to setup this or if it is possible in VBA. You can try to look for it in VBA references. Otherwise try to ask Foxit support.

 
 
 

2023-05-12_7-59-36.png

 

0 Likes
Message 6 of 6

zachary.watsonTTAEZ
Participant
Participant

Hey Michael.Navara,

 

That was the problem. I was able to find a Foxit Phantom Reference and the code worked right after that. Thanks for all the help!

0 Likes