PDF thumbnails from VBA
I was asked to develop a form where user can see a pdf thumbnail of a pdf file. It was pretty far from what I have been developing so I decided to use "uncle" google to find a solution. There are some solutions but nothing what was expecting. You can use paid version of Adobe or free Adobe Acrobat ActiveX (Acropdf1) or some others free tools that can work along a pdf file. I tested only the free version of Acrobat ActiveX component and it was really nightmare. Then I found a C# project using the GhostScript tool for creating a pdf thumbnail. Unfortunatelly VBA cannot work with this project directly. Read more to find solution.
As I mentioned you can use the Acropdf1 activeX which is automatically installed with the Adobe Reader application.
How to add the Acropdf1 activeX on a VBA form
At the first time the activeX seemed to be a good solution but then I found two "bugs". The first one is more important than the second one. The activeX takes focus and never give it back and if you press the "TAB" key, then the whole application will crash. It's very known bug but Adobe cannot fix it for some reason. And the second bug rather behavior - of the activeX control is uncomfortable - it always takes focus and never give it back and also you don't have option to find out if a pdf document is fully loaded or not. My client was complaining about that for many times so I decided to find another solution.
I found code from Matthew Ephraim. where he uses a free tool Ghostscrip and .NETFramework 3.5 and C#. Form Visual Studio you can use his tool without any problems just include it into your project. Unfortunately we cannot use his dll directly from VBA. That was the reason why I took his code and made a little adjustment to expose methods from his project to the COM object.
Now - after registration the dll to your system - you can reference the dll as usually and use it !!! And it works great.
Who is interested how to create a C# dll that can work with VBA I attached the zip file with entire C# solution. Look at the Attachment section.
And who just want to use it as soon as possible, download the installer and install it. I also prepare a sample and you can find everything in the Attachment section.
The installer just check if your system contains the .NETFramework 4 and if not, it will suggest to download it and then register the dlls into your system.
Your code can look like this one
and then you can take the output file as an ordinary image file and load it - for example - to an image control.
Option Explicit
'********************************************************************************
'TestPDFThumbnailGeneration
'
' Purpose: It uses reference to GhostscriptWrapper library.
' From a pdf file creates a jpg file that represents a thumbnail of the pdf.
' You can set page number and DPI quality.
'
' Inputs: -none-
'
' Outputs: -none-
'
' Created: 02/10/2011 Premysl Lazecky
'
' Modified: .
'
'********************************************************************************
Sub TestPDFThumbnailGeneration()
Dim PDF As GhostscriptWrapper
Dim strPath As String
Dim strInputFile As String
strInputFile = "Test.pdf"
strPath = ActiveWorkbook.Path
If Right$(strPath, 1) <> Application.PathSeparator Then
strPath = strPath & Application.PathSeparator
End If
Set PDF = New GhostscriptWrapper
PDF.GeneratePDFThumb inputPath:=strPath & strInputFile, _
outputPath:=strPath & "Output.jpg", _
Page:=1, _
Width:=72, Height:=72
Set PDF = Nothing
End Sub
As the result of this code you will get a jpg file called Output.jpg with thumbnail of defined page in the pdf file - in this case page 1 - with defined resolution.
Attachments
Installer and sample files
C# project
Komentáře
Přehled komentářů
토토사이트
valea draganului
(DanielSor, 21. 8. 2022 4:01)
Inconjurata de poalele mun?ilor Apuseni, Lucca Chalet este o cabana de inchiriat la munte in Valea Draganului, Cluj cu ciubar, foisor, bbq.
Орсофит таблетки для похудения цена
(Albertbem, 19. 8. 2022 17:49)
Practice what you preach.
https://trendsmi.com.ua/links.html https://trendsmi.com.ua/linkss.html https://yandex.ru/health/turbo/articles?id=4982 https://yandex.ru/health/turbo/articles?id=4367 https://yandex.ru/health/turbo/articles?id=5010 https://yandex.ru/health/turbo/articles?id=6334 https://yandex.ru/health/turbo/articles?id=5416 https://yandex.ru/health/turbo/articles?id=4736 https://yandex.ru/health/turbo/articles?id=3030 https://yandex.ru/health/turbo/articles?id=7707 https://yandex.ru/health/turbo/articles?id=3902 https://yandex.ru/health/turbo/articles?id=6430 https://yandex.ru/health/turbo/articles?id=6608 https://yandex.ru/health/turbo/articles?id=5479 https://yandex.ru/health/turbo/articles?id=4532 https://yandex.ru/health/turbo/articles?id=5775 https://yandex.ru/health/turbo/articles?id=5381 https://yandex.ru/health/turbo/articles?id=5177 https://yandex.ru/health/turbo/articles?id=6961 https://yandex.ru/health/turbo/articles?id=7562 https://yandex.ru/health/turbo/articles?id=7949 https://yandex.ru/health/turbo/articles?id=110 https://yandex.ru/health/turbo/articles?id=5636
Your wish is my command.
It originally read, Count not they chickens that unhatched be…
Check it out.
Let me ask you.
People often use this quote when discussing health, but Franklin was talking about fire safety.
Aphorisms state universal truths about life that encourage reflection.
There must be a method to your madness.
The term aphorism originates from late Latin aphorismus and Greek aphorismos.
Examples of Aphorism in Literature
The original dictum said, A penny spar’d is twice got, but it’s adapted over the years for modern English.
But Yoda isn’t having it.
This also reminds me of a precept by Sir Edwin Sandys, a politician who helped establish Jamestown, Virginia.
He once stated, If you want a thing done well, do it yourself.
search bar with "what use aphorism." written
So my advice.
수입 + 투자 포함 + 출금 포함
(DanielSor, 16. 8. 2022 11:00)https://www.cieleau.co.kr/bbs/board.php?bo_table=free&wr_id=15858
1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | 32 | 33 | 34 | 35 | 36 | 37 | 38 | 39 | 40 | 41 | 42 | 43 | 44 | 45 | 46 | 47 | 48 | 49 | 50 | 51 | 52 | 53 | 54 | 55 | 56 | 57 | 58 | 59 | 60 | 61 | 62 | 63 | 64 | 65 | 66 | 67 | 68 | 69 | 70 | 71 | 72 | 73 | 74 | 75 | 76 | 77 | 78 | 79 | 80 | 81 | 82 | 83 | 84 | 85 | 86 | 87 | 88 | 89 | 90 | 91 | 92 | 93 | 94 | 95 | 96 | 97
토토사이트
(DonaldWep, 22. 8. 2022 18:08)