Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 8115943
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: June 6, 20262026-06-06T03:38:47+00:00 2026-06-06T03:38:47+00:00

I use iTextSharp to print a grid view but I face some problems: No

  • 0

I use iTextSharp to print a grid view but I face some problems:

  1. No arabic characters appears at all.

  2. The direction is LTR and I wany it RTL instead.

  3. Some columns in the gridview are templatefields (label, imagebutton,…), and I can’t handle this case. I won’t show all of them (like delete button , …)

The code :

 protected void ExportToPDF(GridView gvReport, bool LandScape)
        {
            int noOfColumns = 0, noOfRows = 0;
            DataTable tbl = null;

            if (gvReport.AutoGenerateColumns)
            {
                tbl = gvReport.DataSource as DataTable; // Gets the DataSource of the GridView Control.
                noOfColumns = tbl.Columns.Count;
                noOfRows = tbl.Rows.Count;
            }
            else
            {
                noOfColumns = gvReport.Columns.Count;
                noOfRows = gvReport.Rows.Count;
            }

            float HeaderTextSize = 8;
            float ReportNameSize = 10;
            float ReportTextSize = 8;
            float ApplicationNameSize = 7;

            // Creates a PDF document

            Document document = null;
            if (LandScape == true)
            {
                // Sets the document to A4 size and rotates it so that the     orientation of the page is Landscape.
                document = new Document(PageSize.A4.Rotate(), 0, 0, 15, 5);
            }
            else
            {
                document = new Document(PageSize.A4, 0, 0, 15, 5);
            }

            // Creates a PdfPTable with column count of the table equal to no of columns of the gridview or gridview datasource.
            iTextSharp.text.pdf.PdfPTable mainTable = new iTextSharp.text.pdf.PdfPTable(noOfColumns);

            // Sets the first 4 rows of the table as the header rows which will be repeated in all the pages.
            mainTable.HeaderRows = 4;

            // Creates a PdfPTable with 2 columns to hold the header in the exported PDF.
            iTextSharp.text.pdf.PdfPTable headerTable = new iTextSharp.text.pdf.PdfPTable(2);

            // Creates a phrase to hold the application name at the left hand side of the header.
            Phrase phApplicationName = new Phrase("Contact List", FontFactory.GetFont("Arial", ApplicationNameSize, iTextSharp.text.Font.TIMES_ROMAN));

            // Creates a PdfPCell which accepts a phrase as a parameter.
            PdfPCell clApplicationName = new PdfPCell(phApplicationName);
            // Sets the border of the cell to zero.
            clApplicationName.Border = PdfPCell.NO_BORDER;
            // Sets the Horizontal Alignment of the PdfPCell to left.
            clApplicationName.HorizontalAlignment = Element.ALIGN_LEFT;

            // Creates a phrase to show the current date at the right hand side of the header.
            Phrase phDate = new Phrase(DateTime.Now.Date.ToString("dd/MM/yyyy"), FontFactory.GetFont("Arial", ApplicationNameSize, iTextSharp.text.Font.NORMAL));

            // Creates a PdfPCell which accepts the date phrase as a parameter.
            PdfPCell clDate = new PdfPCell(phDate);
            // Sets the Horizontal Alignment of the PdfPCell to right.
            clDate.HorizontalAlignment = Element.ALIGN_RIGHT;
            // Sets the border of the cell to zero.
            clDate.Border = PdfPCell.NO_BORDER;

            // Adds the cell which holds the application name to the headerTable.
            headerTable.AddCell(clApplicationName);
            // Adds the cell which holds the date to the headerTable.
            headerTable.AddCell(clDate);
            // Sets the border of the headerTable to zero.
            headerTable.DefaultCell.Border = PdfPCell.NO_BORDER;

            // Creates a PdfPCell that accepts the headerTable as a parameter and then adds that cell to the main PdfPTable.
            PdfPCell cellHeader = new PdfPCell(headerTable);
            cellHeader.Border = PdfPCell.NO_BORDER;
            // Sets the column span of the header cell to noOfColumns.
            cellHeader.Colspan = noOfColumns;
            // Adds the above header cell to the table.
            mainTable.AddCell(cellHeader);

            // Creates a phrase which holds the file name.
            Phrase phHeader = new Phrase("Contact List", FontFactory.GetFont("Arial", ReportNameSize, iTextSharp.text.Font.BOLD));
            PdfPCell clHeader = new PdfPCell(phHeader);
            clHeader.Colspan = noOfColumns;
            clHeader.Border = PdfPCell.NO_BORDER;
            clHeader.HorizontalAlignment = Element.ALIGN_CENTER;
            mainTable.AddCell(clHeader);

            // Creates a phrase for a new line.
            Phrase phSpace = new Phrase("\n");
            PdfPCell clSpace = new PdfPCell(phSpace);
            clSpace.Border = PdfPCell.NO_BORDER;
            clSpace.Colspan = noOfColumns;
            mainTable.AddCell(clSpace);

            // Sets the gridview column names as table headers.
            for (int i = 0; i < noOfColumns; i++)
            {
                Phrase ph = null;

                if (gvReport.AutoGenerateColumns)
                {
                    ph = new Phrase(tbl.Columns[i].ColumnName, FontFactory.GetFont("Arial", HeaderTextSize, iTextSharp.text.Font.BOLD));
                }
                else
                {
                    ph = new Phrase(gvReport.Columns[i].HeaderText, FontFactory.GetFont("Arial", HeaderTextSize, iTextSharp.text.Font.BOLD));
                }

                mainTable.AddCell(ph);
            }

            // Reads the gridview rows and adds them to the mainTable
            for (int rowNo = 0; rowNo < noOfRows; rowNo++)
            {
                for (int columnNo = 0; columnNo < noOfColumns; columnNo++)
                {
                    if (gvReport.AutoGenerateColumns)
                    {
                        string s = gvReport.Rows[rowNo].Cells[columnNo].Text.Trim();
                        Phrase ph = new Phrase(s, FontFactory.GetFont("Arial", ReportTextSize, iTextSharp.text.Font.NORMAL));
                        mainTable.AddCell(ph);
                    }
                    else
                    {
                        if (gvReport.Columns[columnNo] is TemplateField)
                        {
                            try
                            {
                                Label lc = gvReport.Rows[rowNo].Cells[columnNo].Controls[1] as Label;

                                string s = lc.Text.Trim();
                                Phrase ph = new Phrase(s, FontFactory.GetFont("Arial", ReportTextSize, iTextSharp.text.Font.NORMAL));
                                mainTable.AddCell(ph);
                            }
                            catch (NullReferenceException ee)
                            {
                                noOfColumns--;
                            }
                            catch (Exception ee)
                            {
                                noOfColumns--;
                            }
                        }
                        else
                        {
                            string s = gvReport.Rows[rowNo].Cells[columnNo].Text.Trim();
                            Phrase ph = new Phrase(s, FontFactory.GetFont("Arial", ReportTextSize, iTextSharp.text.Font.NORMAL));
                            mainTable.AddCell(ph);
                        }
                    }
                }

                // Tells the mainTable to complete the row even if any cell is left incomplete.
                mainTable.CompleteRow();
            }

            // Gets the instance of the document created and writes it to the output stream of the Response object.
            PdfWriter.GetInstance(document, Response.OutputStream);

            // Creates a footer for the PDF document.
            HeaderFooter pdfFooter = new HeaderFooter(new Phrase(), true);
            pdfFooter.Alignment = Element.ALIGN_CENTER;
            pdfFooter.Border = iTextSharp.text.Rectangle.NO_BORDER;

            // Sets the document footer to pdfFooter.
            document.Footer = pdfFooter;
            // Opens the document.
            document.Open();
            // Adds the mainTable to the document.
            document.Add(mainTable);
            // Closes the document.
            document.Close();

            Response.ContentType = "application/pdf";
            Response.AddHeader("content-disposition", "attachment; filename= ContactList.pdf");
            Response.End();
        }

The original one is Here

I change this line and add try and catch to avoid the exception (problem 3) :

DataBoundLiteralControl lc = gvReport.Rows[rowNo].Cells[columnNo].Controls[0] as DataBoundLiteralControl;

TO

Label lc = gvReport.Rows[rowNo].Cells[columnNo].Controls[1] as Label;

How to fix these problems?

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-06-06T03:38:49+00:00Added an answer on June 6, 2026 at 3:38 am

    enter image description here

    In the out put you can see that English Columns on LTR and Arabic Column on RTL. if you want to display GridView on page with RTL than you can use <div dir="rtl">Put the Grid View here</div>.
    GridView:

     <asp:GridView ID="GridView1" runat="server" DataSourceID="SqlDataSource1" AutoGenerateColumns="False">
            <Columns>
                <asp:TemplateField HeaderText="العربية" SortExpression="العربية">
                    <ItemTemplate>
                        <asp:Label ID="arabic" runat="server" Text='<%# Eval("العربية")%>' />
                    </ItemTemplate>
                </asp:TemplateField>
            </Columns>
            <Columns>
                <asp:TemplateField HeaderText="English" SortExpression="English">
                    <ItemTemplate>
                        <asp:Label ID="english" runat="server" Text='<%# Eval("English") %>' />
                    </ItemTemplate>
                </asp:TemplateField>
            </Columns>
            <Columns>
                <asp:TemplateField>
                    <ItemTemplate>
                        <asp:Button ID="deleteButton" runat="server" Text="Delete" />
                    </ItemTemplate>
                </asp:TemplateField>
            </Columns>
            <Columns>
                <asp:TemplateField>
                    <ItemTemplate>
                        <asp:HyperLink ID="open" runat="server" Text="Open" NavigateUrl="~/Default.aspx"/>
                    </ItemTemplate>
                </asp:TemplateField>
            </Columns>
        </asp:GridView>
        <asp:SqlDataSource ID="SqlDataSource1" runat="server" ConnectionString="<%$ ConnectionStrings:ConnectionString %>"
            SelectCommand="SELECT [English], [العربية] FROM [Test]"></asp:SqlDataSource>
        <br />
        <asp:Button ID="btnExport" runat="server" OnClick="btnExport_Click" Text="Export to PDF" />
    

    CS Code:

     protected void ExportPDF(GridView gridViewReport)
        {
            int columnNumber = 0, rowNumber = 0;
            DataTable tbl = null;
    
            if (gridViewReport.AutoGenerateColumns)
            {
                tbl = gridViewReport.DataSource as DataTable; // Gets the DataSource of the GridView Control.
                columnNumber = tbl.Columns.Count;
                rowNumber = tbl.Rows.Count;
            }
            else
            {
                columnNumber = gridViewReport.Columns.Count;
                rowNumber = gridViewReport.Rows.Count;
            }
            // Creates a PDF document
            Document document = null;
            document = new Document(PageSize.A4, 0, 0, 15, 5);
            PdfPTable _table = new PdfPTable(GridView1.Columns.Count);
            _table.RunDirection = PdfWriter.RUN_DIRECTION_RTL;
            BaseFont baseFont = BaseFont.CreateFont("c:\\\\windows\\\\fonts\\\\tahoma.ttf", BaseFont.IDENTITY_H, true); // Font which has Arabic characters
            iTextSharp.text.Font font = new iTextSharp.text.Font(baseFont, 10, iTextSharp.text.Font.NORMAL);
    
            // Sets the gridview column names as table headers.
            for (int i = 0; i < columnNumber; i++)
            {
                iTextSharp.text.pdf.PdfPCell ph = null;
    
                if (gridViewReport.AutoGenerateColumns)
                {
                    ph = new PdfPCell(new Phrase(10, tbl.Columns[i].ColumnName, font));
                }
                else
                {
                    ph = new PdfPCell(new Phrase(10, gridViewReport.Columns[i].HeaderText, font));
                }
                if (ph != null && gridViewReport.Columns[i].HeaderText != "")
                {
                    if (Regex.IsMatch(gridViewReport.Columns[i].HeaderText, "^[a-zA-Z0-9 ]*$")) // Check if Header Text is English
                    {
                        ph.RunDirection = PdfWriter.RUN_DIRECTION_LTR; // Left to Right
                        BaseColor color = new BaseColor(Color.Red);
                        ph.BackgroundColor = color;
                        _table.AddCell(ph);
                    }
                    else
                    {
                        ph.RunDirection = PdfWriter.RUN_DIRECTION_RTL; //Right to Left
                        BaseColor color = new BaseColor(Color.Red);
                        ph.BackgroundColor = color;
                        _table.AddCell(ph);
                    }
                }
                else
                {
                    ph.Border = iTextSharp.text.Rectangle.NO_BORDER;
                    _table.AddCell(ph);
                }
            }
            // Get the gridview rows and adds them to the _table
            for (int rowIteration = 0; rowIteration < rowNumber; rowIteration++)
            {
                for (int columnIteration = 0; columnIteration < columnNumber; columnIteration++)
                {
                    if (gridViewReport.AutoGenerateColumns) //Check if AutoGenrated Colunms
                    {
                        string s = gridViewReport.Rows[rowIteration].Cells[columnIteration].Text.Trim();
                        PdfPCell ph = new PdfPCell(new Phrase(10, s, font));
                        _table.AddCell(ph);
                    }
                    else
                    {
                        if (gridViewReport.Columns[columnIteration] is TemplateField) // Check if Item Template
                        {
                            PdfPCell ph = null;
                            Label lc = gridViewReport.Rows[rowIteration].Cells[columnIteration].Controls[1] as Label; // Label
                            Button btn = gridViewReport.Rows[rowIteration].Cells[columnIteration].Controls[1] as Button;// Button
                            HyperLink hyperLink = gridViewReport.Rows[rowIteration].Cells[columnIteration].Controls[1] as HyperLink; // HyperLink
    
                            if (lc != null)
                            {
    
                                string s = lc.Text.Trim();
                                ph = new PdfPCell(new Phrase(10, s, font));
                                if (Regex.IsMatch(s, "^[a-zA-Z0-9 ]*$")) //Check if cell string is English
                                {   ph.RunDirection = PdfWriter.RUN_DIRECTION_LTR; // Left to Right
                                    _table.AddCell(ph); 
                                }
                                else
                                {
                                    ph.RunDirection = PdfWriter.RUN_DIRECTION_RTL; // Right to Left
                                    _table.AddCell(ph);
                                }
    
                            }
                            else if (btn != null)
                            {
                                ph = new PdfPCell(new Phrase(10, btn.Text, font));
                                ph.Phrase.Clear(); // Clear the Cell Phrase
                                ph.Border = iTextSharp.text.Rectangle.NO_BORDER;
    
                                _table.AddCell(ph);
                            }
                            else if (hyperLink != null)
                            {
                                ph = new PdfPCell(new Phrase(10, hyperLink.Text, font));
                                ph.Phrase.Clear(); //Clear the Cell Phrase
                                ph.Border = iTextSharp.text.Rectangle.NO_BORDER; 
                                _table.AddCell(ph);
                            }
                            else
                            {
                                _table.AddCell("--");
                            }
                        }
                        else
                        {
                            string s = gridViewReport.Rows[rowIteration].Cells[columnIteration].Text.Trim();
                            PdfPCell ph = new PdfPCell(new Phrase(10, s, font));
                            _table.AddCell(ph);
                        }
                    }
                }
                _table.CompleteRow();
            }
            PdfWriter.GetInstance(document, Response.OutputStream);
            // Opens the document.
            document.Open();
            // Adds the _table to the document.
            document.Add(_table);
            // Closes the document.
            document.Close();
            Page.Response.ContentType = "application/pdf";
            Page.Response.AddHeader("content-disposition", "attachment;filename=MyGrid.pdf");
            Page.Response.Cache.SetCacheability(HttpCacheability.NoCache);
            Page.Response.Write(document);
            Page.Response.End();
    
        }
    

    This code might not be the perfectly coded but I hope this will help you to get your required results.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I try to use this: iTextSharp.text.pdf.PdfTable tbl = new iTextSharp.text.pdf.PdfTable(); But i always get
I am trying to use PdfSmartCopy from ItextSharp but I cannot find any relevant
I've got a partial view, i'm trying to use ITextSharp to convert the html
I use iTextSharp to sign a PDF file. But Adobe Reader cannot verify my
Use of rails 3 recaptcha. In view _form.html.erb insert <%= recaptcha_tags %> But when
I have a view that returns a pdf (using iTextSharp) with multiple pages, but
use this website a lot but first time posting. My program creates a number
Use case: I've just entered insert mode, and typed some text. Now I want
use Service layer to persist data into database. But the Unit Test does not
I am trying to use iTextSharp to read/modify PDF metadata. I figured out how

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.