Accueil > > > GÉNÉRATION D'UN PDF AVEC COUVERTURE ET IMAGE EN PIED DE PAGE AVEC ITEXTSHARP
GÉNÉRATION D'UN PDF AVEC COUVERTURE ET IMAGE EN PIED DE PAGE AVEC ITEXTSHARP
Information sur la source
Description
Je voulais créer un PDF à partir d'une sélection de texte dans une RichTextBox, en insérant à ce PDF une couverture, et pour les pages suivantes, une image en pied de page... Sans utiliser les évenements. Le PDF de couverture et l'image pied se trouvent dans le dossier Resources de l'application. Dans une Form on met une RichTextBox et un bouton qui contient le code (sub click) suivant texte = RichTextBox.SelectedText if ExportModifié(texte)then msgbox("PDF exporté avec succès sur le bureau") Else msgbox("Echec de l'export!") end if Pour ne pas avoir de surprises, l'image pied doit être en 72ppp, ce qui évite de lui appliquer un facteur de zoom au moment de son insertion dans le pdf. Donc, voilà une petite fonction...(ne pas oublier d'ajouter iTextsharp dans les références du projet)
Source
- Imports System.IO
- Imports iTextSharp
- Imports iTextSharp.text
- Imports iTextSharp.text.pdf
- Imports iTextSharp.text.xml
-
- Module Module1
-
-
-
-
-
-
-
- Public Function ExportModifié(ByRef redaction As String) As Boolean
-
- Try
- Dim STRImagePied = Image.GetInstance(Application.StartupPath + "\Resources\Pied.jpg")
- Dim STRdirBureau = Environ("USERPROFILE") & "\Bureau\"
- Dim IntNumb, IntCount As Integer
- Dim ReaderCouverture As New PdfReader(Application.StartupPath + "\Resources\Couverture.pdf")
- Dim CouvertureSize As iTextSharp.text.Rectangle = ReaderCouverture.GetPageSize(1)
- Dim Temp As New Document(CouvertureSize, 36, 36, 36, 88) 'Document temporaire sans pied, le nombre de page n'étant pas connu, on insèrera le pied ultérieurement, en reservant 88 pixels, ce qui correspond à la hauteur de l'image pied
- Dim WriterTemp As PdfWriter = PdfWriter.GetInstance(Temp, File.Create(Application.StartupPath + "\Resources\Temp.pdf"))
-
- Temp.Open() 'On ouvre le document temporaire maintenant, pour affecter les valeurs à ContentByteTemp et ImportCouverture au moment de leur définition
-
- Dim ContentByteTemp As PdfContentByte = WriterTemp.DirectContent
- Dim ImportCouverture As PdfImportedPage = WriterTemp.GetImportedPage(ReaderCouverture, 1)
- Dim bfArial = BaseFont.CreateFont(Application.StartupPath + "\Resources\ARIAL.TTF", BaseFont.CP1252, BaseFont.NOT_EMBEDDED)
- Dim arial = New Font(bfArial, 12, FontStyle.Regular, Color.BLACK)
- Dim Paragraphe As Paragraph = New Paragraph
-
- Temp.NewPage()
- ContentByteTemp.AddTemplate(ImportCouverture, 1.0F, 0, 0, 1.0F, 0, 0)
- Temp.NewPage()
- Paragraphe.Add(New Chunk(redaction, New Font(arial)))
- Temp.Add(Paragraphe)
-
- Temp.Close()
-
- Dim ReaderTemp As New PdfReader(Application.StartupPath + "\Resources\Temp.pdf")
- Dim Final As New Document(CouvertureSize, 0, 0, 0, 0)
- Dim WriterFinal As PdfWriter = PdfWriter.GetInstance(Final, File.Create(STRdirBureau & "Final.pdf"))
-
- Final.Open() 'idem Temp.Open...
-
- Dim ContentByteFinal As PdfContentByte = WriterFinal.DirectContent
- Dim ImportTemp As PdfImportedPage
-
- 'Création de la couverture dans le document final
- Final.NewPage()
- IntCount = 1
- ImportTemp = WriterFinal.GetImportedPage(ReaderTemp, IntCount)
- ContentByteFinal.AddTemplate(ImportTemp, 1.0F, 0, 0, 1.0F, 0, 0)
- IntCount = IntCount + 1
-
- IntNumb = ReaderTemp.NumberOfPages
- 'Création des pages suivantes, avec l'image en pied de page
- Do While IntCount <= IntNumb
- Final.NewPage()
- ImportTemp = WriterFinal.GetImportedPage(ReaderTemp, IntCount)
- ContentByteFinal.AddTemplate(ImportTemp, 1.0F, 0, 0, 1.0F, 0, 0)
- STRImagePied.SetAbsolutePosition(Final.PageSize.Width - 740, 0)
- Final.Add(STRImagePied)
- IntCount = IntCount + 1
- Loop
-
- Final.Close()
- File.Delete(Application.StartupPath + "\Resources\Temp.pdf")
-
- Catch
- ExportModifié = False
-
- End Try
- ExportModifié = True
-
- End Function
-
-
- End Module
Imports System.IO
Imports iTextSharp
Imports iTextSharp.text
Imports iTextSharp.text.pdf
Imports iTextSharp.text.xml
Module Module1
Public Function ExportModifié(ByRef redaction As String) As Boolean
Try
Dim STRImagePied = Image.GetInstance(Application.StartupPath + "\Resources\Pied.jpg")
Dim STRdirBureau = Environ("USERPROFILE") & "\Bureau\"
Dim IntNumb, IntCount As Integer
Dim ReaderCouverture As New PdfReader(Application.StartupPath + "\Resources\Couverture.pdf")
Dim CouvertureSize As iTextSharp.text.Rectangle = ReaderCouverture.GetPageSize(1)
Dim Temp As New Document(CouvertureSize, 36, 36, 36, 88) 'Document temporaire sans pied, le nombre de page n'étant pas connu, on insèrera le pied ultérieurement, en reservant 88 pixels, ce qui correspond à la hauteur de l'image pied
Dim WriterTemp As PdfWriter = PdfWriter.GetInstance(Temp, File.Create(Application.StartupPath + "\Resources\Temp.pdf"))
Temp.Open() 'On ouvre le document temporaire maintenant, pour affecter les valeurs à ContentByteTemp et ImportCouverture au moment de leur définition
Dim ContentByteTemp As PdfContentByte = WriterTemp.DirectContent
Dim ImportCouverture As PdfImportedPage = WriterTemp.GetImportedPage(ReaderCouverture, 1)
Dim bfArial = BaseFont.CreateFont(Application.StartupPath + "\Resources\ARIAL.TTF", BaseFont.CP1252, BaseFont.NOT_EMBEDDED)
Dim arial = New Font(bfArial, 12, FontStyle.Regular, Color.BLACK)
Dim Paragraphe As Paragraph = New Paragraph
Temp.NewPage()
ContentByteTemp.AddTemplate(ImportCouverture, 1.0F, 0, 0, 1.0F, 0, 0)
Temp.NewPage()
Paragraphe.Add(New Chunk(redaction, New Font(arial)))
Temp.Add(Paragraphe)
Temp.Close()
Dim ReaderTemp As New PdfReader(Application.StartupPath + "\Resources\Temp.pdf")
Dim Final As New Document(CouvertureSize, 0, 0, 0, 0)
Dim WriterFinal As PdfWriter = PdfWriter.GetInstance(Final, File.Create(STRdirBureau & "Final.pdf"))
Final.Open() 'idem Temp.Open...
Dim ContentByteFinal As PdfContentByte = WriterFinal.DirectContent
Dim ImportTemp As PdfImportedPage
'Création de la couverture dans le document final
Final.NewPage()
IntCount = 1
ImportTemp = WriterFinal.GetImportedPage(ReaderTemp, IntCount)
ContentByteFinal.AddTemplate(ImportTemp, 1.0F, 0, 0, 1.0F, 0, 0)
IntCount = IntCount + 1
IntNumb = ReaderTemp.NumberOfPages
'Création des pages suivantes, avec l'image en pied de page
Do While IntCount <= IntNumb
Final.NewPage()
ImportTemp = WriterFinal.GetImportedPage(ReaderTemp, IntCount)
ContentByteFinal.AddTemplate(ImportTemp, 1.0F, 0, 0, 1.0F, 0, 0)
STRImagePied.SetAbsolutePosition(Final.PageSize.Width - 740, 0)
Final.Add(STRImagePied)
IntCount = IntCount + 1
Loop
Final.Close()
File.Delete(Application.StartupPath + "\Resources\Temp.pdf")
Catch
ExportModifié = False
End Try
ExportModifié = True
End Function
End Module
Sources de la même categorie
Commentaires et avis
Discussions en rapport avec ce code source dans le forum
Comment créer des PDF remplissables ? [ par Phil72000 ]
Bonjour,J'utilise avec succès itextsharp.dll 4.0.4.0.J'aimerais maintenant aller plus loin en créant des PDF remplissables avec ajout de texte, case à
itextSharp [ par ha10 ]
Bonjour, SVP je cherche un lien qui me permet de télécharger itextSharp.dll pour écrire des pdf à partir de VB.NET J'ai essayé plusieurs lien mais ils
|
Derniers Blogs
MBA : POURQUOI FAIRE ET COMMENT LE CHOISIR ?MBA : POURQUOI FAIRE ET COMMENT LE CHOISIR ? par ROMELARD Fabrice
Formation initiale Durant la formation, le découpage classique est le suivant (je donnerai les équivalences Suisse lorsque je les connaîtrais) : Ecole primaire jusqu'au Collège : Formation générale permettant d'obtenir les méthodes...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice Y'A DES ERREURS QUI PEUVENT RENDRE LE DéVELOPPEUR VIOLENTY'A DES ERREURS QUI PEUVENT RENDRE LE DéVELOPPEUR VIOLENT par Aleks
Quand on a ce genre d'erreur sans log :
Et bas on a juste envie de choper le gas de Microsoft qu'a développé ça et lui foutre des baffes de Coboye ! ...
Cliquez pour lire la suite de l'article par Aleks [HYPER-V 3] PRéSENTATION DES COMMANDLETS POWERSHELL[HYPER-V 3] PRéSENTATION DES COMMANDLETS POWERSHELL par Pierrick CATRO-BROUILLET
Avec la sortie prochaine de la Beta Consumer Preview de Windows 8, j'avais envie de revenir sur une des fonctionnalités que j'attends le plus et que, en bon geek que je suis, j'utilise déjà : Hyper-V 3 ainsi son module PowerShell.
Il y a déjà pléthor...
Cliquez pour lire la suite de l'article par Pierrick CATRO-BROUILLET IIS7 - COMPRESSION GZIPIIS7 - COMPRESSION GZIP par cyril
La compression GZIP permet d'améliorer les performances de navigation en compressant ce qu'envoie le serveur à un client. Pour comprendre comment cela fonctionne, regardons ce qu'il se passe au niveau HTTP lorsqu'un client tente d'accéder à une ress...
Cliquez pour lire la suite de l'article par cyril SHAREPOINT 15 TECHNICAL PREVIEW MANAGED OBJECT MODEL SOFTWARE DEVELOPMENT KITSHAREPOINT 15 TECHNICAL PREVIEW MANAGED OBJECT MODEL SOFTWARE DEVELOPMENT KIT par Matthew
http://www.microsoft.com/download/en/details.aspx?id=28768&utm_source=feedburner&utm_medium=feed&utm_campaign=Feed%3A+MicrosoftDownloadCenter+(Microsoft+Download+Center) ...
Cliquez pour lire la suite de l'article par Matthew
Logiciels
Easy-Planning (1.0.0.1)EASY-PLANNING (1.0.0.1)Basé sur les mêmes principes que MyPlanning, Easy-Planning permet de créer des plannings sous la ... Cliquez pour télécharger Easy-Planning Academy System (17.1.3.0)ACADEMY SYSTEM (17.1.3.0)Logiciel de gestion des établissements.
- élèves/étudiants (inscription, dossier, absence...)
-... Cliquez pour télécharger Academy System COLLECTOR PLUS (3.00B)COLLECTOR PLUS (3.00B)COLLECTOR PLUS version 3.00B est un logiciel utilisant une base de données alimentée par :
- L... Cliquez pour télécharger COLLECTOR PLUS PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO (V7.4)PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO (V7.4)PONAMEDIA TV DEVIENS HELLLOOO FLASH
LA TV SUR VOTRE ORDINATEUR.
Toute une plateforme Multi... Cliquez pour télécharger PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO LettresFaciles 2011 (8.0.0.1)LETTRESFACILES 2011 (8.0.0.1)LettresFaciles est un logiciel facilitant la création et la rédaction de lettres types.
Son inte... Cliquez pour télécharger LettresFaciles 2011
|