使用Ext.net中的iTextsharp将griddata转换为PDF文件时,无法在表格的单元格中插入图像

时间:2012-05-04 07:10:25

标签: ext.net

我正在使用iTextSharp将Griddata导出为PDF。我无法将.jpg图像插入到表格的单元格中。我想将griddata(billdata)导出为PDF我可以在单元格上插入文本但不能插入图像。

我的代码如下

protected void ToPDF(object sender, EventArgs e)
        {      
            System.IO.MemoryStream PDFData = new System.IO.MemoryStream();
            iTextSharp.text.Document newDocument = new iTextSharp.text.Document(PageSize.A4.Rotate(), 10, 10, 10, 10);
            iTextSharp.text.pdf.PdfWriter newPdfWriter = iTextSharp.text.pdf.PdfWriter.GetInstance(newDocument, PDFData);
            DataSet newDataSet = null;

            string json = GridData.Value.ToString();
            if (json != "[]")
            {
                StoreSubmitDataEventArgs eSubmit = new StoreSubmitDataEventArgs(json, null);
                XmlNode xml = eSubmit.Xml;

                if (xml != null)
                {
                    XmlTextReader xtr = new XmlTextReader(xml.OuterXml, XmlNodeType.Element, null);
                    newDataSet = new DataSet();
                    newDataSet.ReadXml(xtr);


                    int totalColumns = newDataSet.Tables[0].Columns.Count;
                    iTextSharp.text.pdf.PdfPTable newPdfTable = new iTextSharp.text.pdf.PdfPTable(totalColumns - 3+1);
                    newPdfTable.DefaultCell.Padding = 1;
                    newPdfTable.WidthPercentage = 80;
                    newPdfTable.DefaultCell.HorizontalAlignment = iTextSharp.text.Element.ALIGN_LEFT;
                    newPdfTable.DefaultCell.VerticalAlignment = iTextSharp.text.Element.ALIGN_MIDDLE;    
                    newPdfTable.HeaderRows = 1; 
                    newPdfTable.DefaultCell.BorderColor = new iTextSharp.text.BaseColor(255, 255, 255);
                    newPdfTable.DefaultCell.BackgroundColor = new iTextSharp.text.BaseColor(255, 255, 255);

                    iTextSharp.text.Image image = iTextSharp.text.Image.GetInstance("D:\\company_logo.jpg");
                    image.Alignment = iTextSharp.text.Image.ALIGN_LEFT;

                    iTextSharp.text.pdf.PdfPCell cell = new iTextSharp.text.pdf.PdfPCell(image);
                    cell.Rowspan = 5;
                    cell.HorizontalAlignment = 0;
                    //cell.Border = 1;
                    newPdfTable.AddCell(cell);

                   cell = new iTextSharp.text.pdf.PdfPCell(new Phrase("Your company name", FontFactory.GetFont("Times New Roman", 18, Font.BOLD, new iTextSharp.text.BaseColor(80, 80, 80))));
                    cell.Colspan = 6;
                    cell.HorizontalAlignment = 0;
                    //cell.Border = 1;
                    newPdfTable.AddCell(cell);

                    cell = new iTextSharp.text.pdf.PdfPCell(new Phrase(Environment.NewLine));
                    cell.Colspan = 6;
                    cell.HorizontalAlignment = 0;
                    //cell.Border = 1;
                    newPdfTable.AddCell(cell);

                    cell = new iTextSharp.text.pdf.PdfPCell(new Phrase("Street Address", FontFactory.GetFont("Times New Roman", 12, Font.NORMAL, new iTextSharp.text.BaseColor(80, 80, 80))));
                    cell.Colspan = 6;
                    cell.HorizontalAlignment = 0;
                    //cell.Border =1;
                    newPdfTable.AddCell(cell);

                    cell = new iTextSharp.text.pdf.PdfPCell(new Phrase("City, Pincode", FontFactory.GetFont("Times New Roman", 12, Font.NORMAL, new iTextSharp.text.BaseColor(80, 80, 80))));
                    cell.Colspan = 5; 
                    cell.HorizontalAlignment = 0;                   
                    //cell.Border = 1;
                    newPdfTable.AddCell(cell);

                    string dt=Convert.ToString( Convert.ToDateTime(dtBill.Text).ToShortDateString());
                    cell = new iTextSharp.text.pdf.PdfPCell(new Phrase("Date : " + dt, FontFactory.GetFont("Times New Roman", 12, Font.NORMAL, new iTextSharp.text.BaseColor(80, 80, 80))));
                   //cell.Colspan = 2;
                    cell.HorizontalAlignment = 0;
                    //cell.Border = 1;
                    newPdfTable.AddCell(cell);

                    cell = new iTextSharp.text.pdf.PdfPCell(new Phrase("Phone no., Website, etc.", FontFactory.GetFont("Times New Roman", 12, Font.NORMAL, new iTextSharp.text.BaseColor(80, 80, 80))));
                    cell.Colspan = 5; 
                    cell.HorizontalAlignment = 0;
                    //cell.Border =1;      
                    newPdfTable.AddCell(cell);

                    cell = new iTextSharp.text.pdf.PdfPCell(new Phrase("Bill no : " + cmbBill.Text, FontFactory.GetFont("Times New Roman", 12, Font.NORMAL, new iTextSharp.text.BaseColor(80, 80, 80))));
                    //cell.Colspan = 2;                   
                    cell.HorizontalAlignment = 0;                   
                    //cell.Border =1;
                    newPdfTable.AddCell(cell);

                    cell = new iTextSharp.text.pdf.PdfPCell(new Phrase(Environment.NewLine));
                    cell.Colspan = 7;
                    cell.HorizontalAlignment = 0;
                    //cell.Border = 1;
                    newPdfTable.AddCell(cell);

                    cell = new iTextSharp.text.pdf.PdfPCell(new Phrase(Environment.NewLine));
                    cell.Colspan = 7;
                    cell.HorizontalAlignment = 0;
                    //cell.Border = 1;
                    newPdfTable.AddCell(cell);

                    cell = new iTextSharp.text.pdf.PdfPCell(new Phrase(Environment.NewLine));
                    cell.Colspan = 7;
                    cell.HorizontalAlignment = 0;
                    //cell.Border = 1;
                    newPdfTable.AddCell(cell);

                    for (int i = 0; i <= totalColumns-1 ; i++)
                    {

                        if ((i != 0) & (i != 1) & (i != 2))
                        {
                            cell = new iTextSharp.text.pdf.PdfPCell(new Phrase(newDataSet.Tables[0].Columns[i].ColumnName, FontFactory.GetFont("Tahoma", 12, Font.BOLD, new iTextSharp.text.BaseColor(80, 80, 80))));
                            cell.BorderColor = new iTextSharp.text.BaseColor(80, 80, 80);
                            cell.BackgroundColor = new iTextSharp.text.BaseColor(System.Drawing.Color.LightGray);
                            cell.VerticalAlignment =iTextSharp.text.Element.ALIGN_MIDDLE; 
                            if (i == 5)
                            {
                                cell.Colspan = 2;
                                cell.HorizontalAlignment = 1;       
                            }
                            else
                            {
                                cell.HorizontalAlignment = 1;
                            }
                            newPdfTable.AddCell(cell);
                        }

                    }
                    int j = 0;
                    foreach (DataRow record in newDataSet.Tables[0].Rows)
                    {
                        for (int i = 0; i <= totalColumns - 1; i++)
                        {

                            if ((i != 0) & (i != 1) & (i != 2))
                            {
                                if (i == 3)
                                {
                                    if(record[i].ToString()=="true")
                                        cell = new iTextSharp.text.pdf.PdfPCell(new Phrase("Yes", FontFactory.GetFont("Tahoma", 10, Font.NORMAL, new iTextSharp.text.BaseColor(80, 80, 80))));
                                    else
                                        cell = new iTextSharp.text.pdf.PdfPCell(new Phrase("No", FontFactory.GetFont("Tahoma", 10, Font.NORMAL, new iTextSharp.text.BaseColor(80, 80, 80))));
                                }
                                else
                                {
                                        cell = new iTextSharp.text.pdf.PdfPCell(new Phrase(record[i].ToString(), FontFactory.GetFont("Tahoma", 10, Font.NORMAL, new iTextSharp.text.BaseColor(80, 80, 80))));
                                }

                                if ((j % 2) == 0)
                                {
                                    //cell.BorderColor = new iTextSharp.text.BaseColor(System.Drawing.Color);
                                }
                                else
                                {
                                    cell.BackgroundColor = new iTextSharp.text.BaseColor(System.Drawing.Color.WhiteSmoke);
                                }
                                cell.VerticalAlignment = iTextSharp.text.Element.ALIGN_MIDDLE;
                                if (i == 3)
                                    cell.Border = iTextSharp.text.pdf.PdfPCell.NO_BORDER;
                                else
                                    cell.Border = iTextSharp.text.pdf.PdfPCell.LEFT_BORDER;


                                if (i == 5)
                                {
                                    cell.Colspan = 2;
                                    cell.HorizontalAlignment = 0;
                                }
                                else
                                {
                                    if ((i == 6) | (i == 7) | (i == 8))
                                    {
                                        cell.HorizontalAlignment = 2;
                                    }

                                    else
                                    {
                                        cell.HorizontalAlignment = 0;
                                    }
                                }

                                newPdfTable.AddCell(cell);
                            }
                        }
                        j++;
                    }

                    newDocument.Open();
                    newDocument.Add(new Phrase(Environment.NewLine));
                    newDocument.Add(new Phrase(Environment.NewLine));
                    newDocument.Add(newPdfTable);  
                    //newDocument.Add(new Phrase("                                                                                                                                Total  " + txtTotalQty.Text + "      " + txtTotalAmount.Text, FontFactory.GetFont("Trebuchet MS", 14, Font.BOLD, new iTextSharp.text.BaseColor(21, 66, 157))));
                    newDocument.Add(new Phrase(Environment.NewLine));
                    //newDocument.Add(new Phrase("Printed On: " + DateTime.Now.ToString(), FontFactory.GetFont("Tahoma", 9, Font.NORMAL, new iTextSharp.text.BaseColor(80, 80, 80))));
                    newDocument.Close();
                    Response.ContentType = "application/pdf";
                    Response.Cache.SetCacheability(System.Web.HttpCacheability.Public);
                    Response.AppendHeader("Content-Type", "application/pdf");
                    Response.AppendHeader("Content-Disposition", "attachment; filename=" + this.ID + ".pdf");
                    Response.OutputStream.Write(PDFData.GetBuffer(), 0, PDFData.GetBuffer().Length);
                    Response.OutputStream.Flush();
                    Response.OutputStream.Close();
                }
            }
        }

1 个答案:

答案 0 :(得分:0)

只需将 newPdfTable.HeaderRows = 1; 替换为 newPdfTable.HeaderRows = 0;

还有一件事

iTextSharp.text.pdf.PdfPCell cell = new iTextSharp.text.pdf.PdfPCell(image);

还有一个参数为true

iTextSharp.text.pdf.PdfPCell cell = new iTextSharp.text.pdf.PdfPCell(image,true);