This and a dozen other components and tools are provided to you by VFPX community
pdfium-vfp is a open source PDF viewer control and ReportOutput + ReportPreview implementation for Visual Fox Pro 9 SP2 and VFP Advanced based on
- PDFium
- PDFium binaries
- HarfBuzz (hb-subset)
- DirectWrite
- zlib
- Viewing PDF files
- Text selection and copying
- Text searching
- Printing PDF
- Multiple control instances
- VFP frx reports previewing, printing and saving (as pdf) without High DPI pain in the neck
- Export VFP frx reports to docx (OOXML strict format)
- Frx report rendering supports private fonts (non system fonts)
- Frx report rendering supports dynamics and rotation properties
- Supports VFP Advanced x86 and x64
- Windows Vista SP 2
- 1 core CPU
- 1024 MB of RAM
- Tested on Debian (12 bookworm) and Alt (kworkstation 10) distros
- Wine 9.0
- Install Thor https://github.com/VFPX/Thor
- Run VFP and open Thor / Check for updates in VFP system menu
- Download pdfium-vfp component
- Open Thor / Folders / Components in VFP system menu and then open pdfium-vfp folder in Explorer
- Read Basic Usage section on this page
- git clone https://github.com/dmitriychunikhin/pdfium-vfp
- open and explore Sample/sample.pjx
- Check wine version
> wine --version
wine-9.0
- Clone repo and run sample.exe
cd ~
git clone https://github.com/dmitriychunikhin/pdfium-vfp
cd ~/pdfium-vfp/Sample
WINEDLLOVERRIDES="gdiplus=n" wine sample.exe
#wine built-in gdiplus.dll doesn't work as expected, thus it has to be overrided. You can take one from C:/Windows/SysWOW64 folder.
Open sample.pjx project from pdfium-vfp/Sample
folder or just run Sample/sample.exe
- PdfiumViewer doesn't support page rotation, bookrmarks, annotations and active hyperlinks
- Fallback font in report previewer is Helvetica with no chance to change it
- Report previewer can deal with ttf/ttc fonts only, non ttf font (bitmap fonts) and symbol fonts are rendered as images
- Interface language always is your system language
-
Copy pdfium-vfp.vcx, pdfium-vfp.vct from Release folder to your project folder
-
VFP: Copy dependency binaries pdfium.dll, pdfium-vfp.dll from Release folder to your project's folderVFPA x64: Copy dependency binaries pdfium64.dll, pdfium-vfp64.dll from Release folder to your project's folder
-
Add PdfiumViewer object from pdfium-vfp.vcx on the form
-
Open PDF file
Thisform.PdfiumViewer.OpenPdf("some.pdf")
- Print document
Thisform.PdfiumViewer.PrintDocument()
- Save document to the file
Thisform.PdfiumViewer.SaveDocument("c:\myfolder\mydoc.pdf")
- Close PDF file
Thisform.PdfiumViewer.ClosePdf()
-
Copy PdfiumReport.app from Release folder to your project folder
-
VFP: Copy dependency binaries pdfium.dll, pdfium-vfp.dll from Release folder to your project's folderVFPA x64: Copy dependency binaries pdfium64.dll, pdfium-vfp64.dll from Release folder to your project's folder
More examples can be found at pdfium-vfp/Sample/sample.scx
LOCAL loPdfiumReport
loPdfiumReport = NEWOBJECT("PdfiumReport", "pdfium-vfp.vcx", "pdfiumreport.app")
*******************************************
* Report previewing
*******************************************
loPdfiumReport.SaveAs_Filename = "myreport" && Filename suggestion for "save as" dialog, not mandatory
loPdfiumReport.BatchBegin()
REPORT FORM Report1.frx OBJECT loPdfiumReport
REPORT FORM Report2.frx OBJECT loPdfiumReport PREVIEW
loPdfiumReport.BatchEnd()
** OR **
REPORT FORM Report1.frx OBJECT loPdfiumReport NOPAGEEJECT
REPORT FORM Report2.frx OBJECT loPdfiumReport PREVIEW
*******************************************
* Saving report output to the file
*******************************************
loPdfiumReport.BatchBegin()
REPORT FORM Report1.frx OBJECT loPdfiumReport
REPORT FORM Report2.frx OBJECT loPdfiumReport TO FILE "some.pdf"
loPdfiumReport.BatchEnd()
** OR **
REPORT FORM Report1.frx OBJECT loPdfiumReport NOPAGEEJECT
REPORT FORM Report2.frx OBJECT loPdfiumReport TO FILE "some.pdf"
SET REPORTBEHAVIOR 90
LOCAL lSave_REPORTOUTPUT
lSave_REPORTOUTPUT = _REPORTOUTPUT
TRY
_REPORTOUTPUT = "pdfiumreport.app"
DO pdfiumreport.app WITH .T. && Initialization (mandatory) / Execute on initialization step of your application
*******************************************
* Report previewing
*******************************************
REPORT FORM Report1.frx NOPAGEEJECT
REPORT FORM Report2.frx PREVIEW
*******************************************
* Saving report output to the file
*******************************************
REPORT FORM Report1.frx NOPAGEEJECT
REPORT FORM Report2.frx TO FILE "some.pdf"
DO pdfiumreport.app WITH .F. && Release / Execute on release step of your application
FINALLY
_REPORTOUTPUT = lSave_REPORTOUTPUT
ENDTRY
Private font is a font that is not installed in system in your development, testing or production environment
Sample can be found in pdfium-vfp/Sample/Sample.scx
in cmdReport.Click
* Manually create Pdfium environment and add your private fonts in Pdfium_env.PrivateFonts collection
LOCAL loPdfiumEnv
loPdfiumEnv = NEWOBJECT("Pdfium_env", "pdfium-vfp.vcx", "pdfiumreport.app")
* parameters: font file path, font face name
loPdfiumEnv.PrivateFonts.Add("Fonts\KurintoSansSC-Rg.ttf", "Kurinto Sans SC")
* Pass pdfium_env object as the first parameter of PdfiumReport constructor
LOCAL loPdfiumReport
loPdfiumReport = NEWOBJECT("PdfiumReport", "pdfium-vfp.vcx", "pdfiumreport.app", loPdfiumEnv)
* Run report with private fonts
REPORT FORM Report1.frx OBJECT loPdfiumReport PREVIEW
* Manually create Pdfium environment and add your private fonts in Pdfium_env.PrivateFonts collection
LOCAL loPdfiumEnv
loPdfiumEnv = NEWOBJECT("Pdfium_env", "pdfium-vfp.vcx", "pdfiumreport.app")
* parameters: font file path, font face name
loPdfiumEnv.PrivateFonts.Add("Fonts\KurintoSansSC-Rg.ttf", "Kurinto Sans SC")
* Pass pdfium_env object as the first parameter of PdfiumReport.app initialization routine
DO pdfiumreport.app WITH loPdfiumEnv
* Run report with private fonts
REPORT FORM Report1.frx PREVIEW
LOCAL loPdfiumReport
loPdfiumReport = Application.PdfiumReport
* or *
loPdfiumReport = NEWOBJECT("PdfiumReport", "pdfium-vfp.vcx", "pdfiumreport.app")
**********************************************************************************************
* Application.PdfiumReport is global variable created by pdfiumreport.app on initialization
**********************************************************************************************
loPdfiumReport.SaveAs_Filename = "myreport" && Filename suggestion for save as dialog in preview mode, not mandatory
* PDF metadata setup sample, setting up metadata is not mandatory
loPdfiumReport.SaveAs_PDFMeta.Author = "Me"
loPdfiumReport.SaveAs_PDFMeta.Creator = "Pdfium-vfp sample app"
loPdfiumReport.SaveAs_PDFMeta.Keywords = "pdfium-vfp,sample"
loPdfiumReport.SaveAs_PDFMeta.Subject = "report1.frx and report2.frx batch"
loPdfiumReport.SaveAs_PDFMeta.Title = "Sample report"
* PDF password protection, input any owner password and user password for testing
loPdfiumReport.SaveAs_PDFMeta.OwnerPassword = "" && Owner Password protects permissions of the doc. Mandatory if User Password was set. Owner password mustn't be equal to user password
loPdfiumReport.SaveAs_PDFMeta.UserPassword = "" && This password user inputs when open pdf file
* PDF reader permissions (matter only if Owner passwords is set)
loPdfiumReport.SaveAs_PDFMeta.Permit_Print = .T. && Allow to print document
loPdfiumReport.SaveAs_PDFMeta.Permit_Edit_All = .T. && Allow to edit contents other than annotations and forms
loPdfiumReport.SaveAs_PDFMeta.Permit_Copy = .T. && Allow copy contents of the document
loPdfiumReport.SaveAs_PDFMeta.Permit_Edit = .T. && Allow to make annotations and fill forms
**********************************************************************************************
What binaries exactly do you need to run all the stuff (or your own latest version of it)
- Adds Application.Pdfium_instance_count property
- Adds Application.PdfiumReportEnv property as pdfium_env of pdfium-vfp
- Adds Application.PdfiumReport property as pdfiumreport of pdfium-vfp
- Declares WIN32API and GDIPlus functions via WinApi_* pattern (with aliases)
- Declares pdfium.dll functions via FPDF_* pattern (with aliases)
- Declares pdfium-vfp.dll functions via VFPDF_* pattern (with aliases)
- Doesn't perform CLEAR DLLS
- Adds fonts from Pdfium_env.PrivateFonts collection to GDIPlus PrivateFontCollection (https://learn.microsoft.com/en-us/dotnet/api/system.drawing.text.privatefontcollection?view=net-8.0)