Click here to Skip to main content
15,881,812 members
Articles / Programming Languages / C#
Article

Gios PDF .NET library

Rate me:
Please Sign up or sign in to vote.
4.89/5 (157 votes)
18 Apr 2005LGPL32 min read 2.2M   13.1K   558   358
A .NET library for generating impressive PDF reports.

Image 1

Introduction

This article describes how to use the Gios Pdf.NET open source library, a complete object-oriented .NET library for generating impressive reports with few lines of code.

Background

I started writing this library because I really couldn’t find a good C# library for exporting my reports. When you open a PDF document with Notepad to find out if it’s possible to edit it… well… you change your mind!

...But if you download the PDF format specifications from Adobe’s official site… you can demystify everything!

In this article, it’s not my intention to teach “how to write a clone of my library” but “how to use it” … By the way, if you want to try to write your own library… try it: it’s not impossible and it's a good (and difficult!) exercise!

Using the code

Start instantiating the document with a new PdfDocument object. Remember to set the document format. In this case we specify width and height in centimeters. Document format is provided by the PdfDocumentFormat class:

C#
PdfDocument myPdfDocument = 
  new PdfDocument(PdfDocumentFormat.InCentimeters(21,29.7));

Now we create a table of 100 lines, 6 columns and 4 points of padding:

C#
PdfTable myPdfTable = 
  myPdfDocument.NewTable(new Font("Verdana",12),200,6,4);

Importing data from the datatables... (also column names for the headers!):

C#
myPdfTable.ImportDataTable(Table);

Set the format for correct date-time representation:

C#
myPdfTable.Columns[2].SetContentFormat("{0:dd/MM/yyyy}");

Now we set our Graphic Design: Colors and Borders...

C#
myPdfTable.HeadersRow.SetColors(Color.White,Color.Navy);
myPdfTable.SetColors(Color.Black,Color.White,Color.Gainsboro);
myPdfTable.SetBorders(Color.Black,1,BorderType.CompleteGrid);

With just one method, we can set the proportional width of the columns. It's a "percentage like" assignment, but the sum can be different from 100.

C#
myPdfTable.SetColumnsWidth(new int[]{5,25,16,20,20,15});

You can also set colors for a range of cells, in this case, a row:

C#
myPdfTable.Rows[7].SetColors(Color.Black,Color.LightGreen);

Now we set some alignment... for the whole table and then, for a column:

C#
myPdfTable.SetContentAlignment(ContentAlignment.MiddleCenter);                      
myPdfTable.Columns[1].SetContentAlignment(ContentAlignment.MiddleLeft);

This is the most important feature of the library: each page generated by the table can be managed in all the details:

C#
while (!myPdfTable.AllTablePagesCreated)
{
    // we create a new page to put the generation of the new TablePage:

    PdfPage newPdfPage=myPdfDocument.NewPage();
    PdfTablePage newPdfTablePage = 
      myPdfTable.CreateTablePage(new PdfArea(myPdfDocument,48,120,500,670));

    // we also put a Label 
 
    PdfTextArea pta=new PdfTextArea(new Font("Verdana",26, FontStyle.Bold), 
      Color.Red, new PdfArea(myPdfDocument,0,20,595,120), 
      ContentAlignment.MiddleCenter,"Contact List");

    // nice thing: we can put all the objects
    // in the following lines, so we can have
    // a great control of layer sequence... 

    newPdfPage.Add(newPdfTablePage);
    newPdfPage.Add(pta);

    // Now we create a loop for serching for people born in 1968. If we find
    // one, we will draw a circle over
    // the birthday cell. This is possible using the
    // the CellArea, that is the Area occupied by a rasterized Cell.
 
    for (int index=newPdfTablePage.FirstRow;index<=newPdfTablePage.LastRow;index++)
       if (((DateTime)myPdfTable.Rows[index][2].Content).Year==1968)
       {
          PdfCircle pc=newPdfTablePage.CellArea(index,2).InnerCircle(Color.Blue,2);
          pc.StrokeWidth=3.5;
          newPdfPage.Add(pc);
       }

    // we save each generated page before start rendering the next.
    newPdfPage.SaveToDocument();

}

At last... remember to save the document!

C#
myPdfDocument.SaveToFile("Example1.pdf");

And this is the result:

Image 2

Remember, you can also output the PDF to a generic Stream. These are the lines for a Web Response:

C#
Response.ClearHeaders();
Response.AppendHeader("Content-disposition", 
   string.Format("attachment;filename={0}","Report.pdf"));
Response.ContentType="application/pdf"; 
myPdfDocument.SaveToStream(Response.OutputStream);
Response.End();

History

  • April 18, 2005 - Initial release.

License

This article, along with any associated source code and files, is licensed under The GNU Lesser General Public License (LGPLv3)


Written By
Web Developer
Italy Italy
Freelance software ASPNET / C# Software Developer

I live in Torino, Italy

my homepage is: http://www.paologios.com

Comments and Discussions

 
AnswerRe: Some feeback needed for the v2.0 Pin
Dan Walton19-Jan-06 11:51
Dan Walton19-Jan-06 11:51 
GeneralText Pin
Phorum29-Sep-05 22:04
Phorum29-Sep-05 22:04 
GeneralRe: Text Pin
Paolo Gios29-Sep-05 22:07
Paolo Gios29-Sep-05 22:07 
Questionjpg inside table cell Pin
yuvarajr27-Sep-05 13:51
yuvarajr27-Sep-05 13:51 
AnswerRe: jpg inside table cell Pin
Paolo Gios27-Sep-05 20:57
Paolo Gios27-Sep-05 20:57 
GeneralRe: jpg inside table cell Pin
yuvarajr29-Sep-05 12:05
yuvarajr29-Sep-05 12:05 
NewsGios PDF .NET v2.0 basic project released Pin
Paolo Gios13-Sep-05 0:25
Paolo Gios13-Sep-05 0:25 
QuestionGIF? Pin
tgiphil7-Sep-05 10:20
tgiphil7-Sep-05 10:20 
Great library! I'm using it!

Does this library support inserting a GIF image? If not, will you be adding this soon? Otherwise, I'll give it a shot otherwise - any guidance would be helpful.

I'm going to modify the library to also accept a image stream, instead just a filename. I have images which are stored in SQLServer. I'll post the changes here when done.

Thanks again!
AnswerRe: GIF? Pin
tgiphil8-Sep-05 8:43
tgiphil8-Sep-05 8:43 
GeneralRe: GIF? Pin
Paolo Gios8-Sep-05 21:13
Paolo Gios8-Sep-05 21:13 
GeneralCell-Alignment Pin
Andreas Meier6-Sep-05 2:14
Andreas Meier6-Sep-05 2:14 
GeneralRe: Cell-Alignment Pin
Paolo Gios6-Sep-05 2:23
Paolo Gios6-Sep-05 2:23 
Generalnot support non-ASCII characters... Pin
Huisheng Chen28-Aug-05 22:15
Huisheng Chen28-Aug-05 22:15 
GeneralRe: not support non-ASCII characters... Pin
infal29-Aug-05 5:44
infal29-Aug-05 5:44 
GeneralRe: not support non-ASCII characters... Pin
Huisheng Chen29-Aug-05 17:08
Huisheng Chen29-Aug-05 17:08 
GeneralRe: not support non-ASCII characters... Pin
infal30-Aug-05 7:23
infal30-Aug-05 7:23 
QuestionRe: not support non-ASCII characters... Pin
Canastro7-Oct-05 7:25
Canastro7-Oct-05 7:25 
AnswerRe: not support non-ASCII characters... Pin
infal9-Oct-05 6:15
infal9-Oct-05 6:15 
AnswerRe: not support non-ASCII characters... Pin
Marco Delgado5-Sep-06 2:01
Marco Delgado5-Sep-06 2:01 
GeneralRe: not support non-ASCII characters... Pin
zhangwusheng25-Dec-06 0:10
zhangwusheng25-Dec-06 0:10 
GeneralTextEncode error: Pin
Huisheng Chen28-Aug-05 22:12
Huisheng Chen28-Aug-05 22:12 
Questionstartxref ? Pin
infal24-Aug-05 16:37
infal24-Aug-05 16:37 
AnswerRe: startxref ? Pin
Paolo Gios25-Aug-05 0:04
Paolo Gios25-Aug-05 0:04 
GeneralRe: startxref ? Pin
infal25-Aug-05 3:15
infal25-Aug-05 3:15 
GeneralSystem.Drawing.Image i=Image.FromFile(file); Pin
infal22-Aug-05 7:46
infal22-Aug-05 7:46 

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Praise Praise    Rant Rant    Admin Admin   

Use Ctrl+Left/Right to switch messages, Ctrl+Up/Down to switch threads, Ctrl+Shift+Left/Right to switch pages.