这里我试图将GridView转换为PDF,当转换PDF时没有获得PDF格式的GridView列宽。所以我使用另一种方法生成PDF(即)从GridView创建的itextsharp表。这里我得到了列宽大小我在GridView列中给出ItemStyle-Width.But我已经在GridView中完成了分组列,所以我没有在PDF中获得具有相同列宽的完整GridView。任何人都请帮助我。
这是来源:
<asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False"
onsorting="GridView1_Sorting">
<HeaderStyle BackColor="#4F81BD" Font-Bold="true" ForeColor="#ffffff" HorizontalAlign="Center" Font-Size="12px"/>
<AlternatingRowStyle BackColor="#D3DFEE" />
<RowStyle />
<Columns>
<asp:BoundField DataField="Category" HeaderText="Category"
SortExpression="Category" ItemStyle-Width="100px"/>
<asp:BoundField DataField="Partno" HeaderText="Partno"
ItemStyle-Width="100px"/>
<asp:BoundField DataField="Productname" HeaderText="Productname"
ItemStyle-Width="300px"/>
<asp:BoundField DataField="Brand" HeaderText="Brand"
ItemStyle-Width="100px"/>
<asp:BoundField DataField="Qty" HeaderText="Qty"
ItemStyle-Width="50px"/>
<asp:BoundField DataField="Unitprice" HeaderText="Unitprice"
ItemStyle-Width="50px"/>
<asp:BoundField DataField="Totalprice" HeaderText="Totalprice"
ItemStyle-Width="50px"/>
</Columns>
</asp:GridView>
这是分组的gridview:
这是将gridview转换为itextsharp表并生成PDF的代码:
//Create a table
iTextSharp.text.Table table = new iTextSharp.text.Table(GridView1.Columns.Count);
table.Cellpadding = 5;
//Set the column widths
int[] widths = new int[GridView1.Columns.Count];
for (int x = 0; x < GridView1.Columns.Count; x++)
{
widths[x] = (int)GridView1.Columns[x].ItemStyle.Width.Value;
string cellText = Server.HtmlDecode(GridView1.HeaderRow.Cells[x].Text);
iTextSharp.text.Cell cell = new iTextSharp.text.Cell(cellText);
cell.BackgroundColor = new iTextSharp.text.Color(System.Drawing.ColorTranslator.FromHtml("#008000"));
table.AddCell(cell);
}
table.SetWidths(widths);
//Transfer rows from GridView to table
for (int i = 0; i < GridView1.Rows.Count; i++)
{
if (GridView1.Rows[i].RowType == DataControlRowType.DataRow)
{
for (int j = 0; j < GridView1.Columns.Count; j++)
{
string cellText = Page.Server.HtmlDecode(GridView1.Rows[i].Cells[j].Text);
iTextSharp.text.Cell cell = new iTextSharp.text.Cell(cellText);
//Set Color of Alternating row
if (i % 2 != 0)
{
cell.BackgroundColor = new iTextSharp.text.Color(System.Drawing.ColorTranslator.FromHtml("#C2D69B"));
}
table.AddCell(cell);
}
}
}
//Create the PDF Document
Document pdfDoc = new Document(PageSize.A4, 10f, 10f, 10f, 0f);
PdfWriter.GetInstance(pdfDoc, Response.OutputStream);
pdfDoc.Open();
pdfDoc.Add(table);
pdfDoc.Close();
Response.ContentType = "application/pdf";
Response.AddHeader("content-disposition", "attachment;" +
"filename=GridViewExport.pdf");
Response.Cache.SetCacheability(HttpCacheability.NoCache);
Response.Write(pdfDoc);
Response.End();
这是PDF:
我希望精确的gridview在PDF中具有相同的列宽。
答案 0 :(得分:2)
PdfPTable
默认使用相对宽度。当您说table.SetWidths(widths)
iText汇总widths
并将每个宽度除以该总和以获得百分比时。因此1, 2, 3
与10, 20, 30
甚至2, 4, 6
相同。您希望使用SetTotalWidth(widths)
以及设置LockedWidth = true
强制绝对宽度。
table.SetTotalWidth(widths);
table.LockedWidth = true;
然而,这样做声明您现在已经知道并控制了表格的水平布局。如果你横向溢出页面,你将不会得到任何包装,事情就会被切断。您还声明如果需要,可以接受边际空间。
答案 1 :(得分:0)
这应该可以解决问题:
GridView1.AllowPaging = False