解决itext生成嵌套PdfPtable时,格…

iTextSharp 对表格的操作相对 Word 来说,显得有些笨拙,似乎无法做到单元格跨行或跨列。所以若要创建这一类型的

[java]  view plain copy
  1. PdfPTable tItemTable= new PdfPTable(1);  
  2. PdfPTable tPlanSumTable= new PdfPTable(1);  
表格,只能通过在单元格中嵌入一个表格来实现。

  iTextSharp 对表格的操作通常分为两级:表格-->单元格,通常在新建一个表格时,即需要设定表格的列数,然后再通过 AddCell 方法添加已有的单元格,这个步骤涉及到的类别有 PdfPTable 和 PdfPCell,两者位于同一命名空间中。基本的程序如下:

 

[java]  view plain copy
  1. iTextSharp.text.pdf.PdfPTable table new iTextSharp.text.pdf.PdfPTable(2); // 表格有 列    
  2. iTextSharp.text.pdf.PdfPCell cell new iTextSharp.text.pdf.PdfPCell(); // 创建单元格    
  3. cell.AddElement(element); // 在单元格中添加数据    
  4. table.AddCell(cell); // 将单元格加入到表格中   

 注意,往表格中添加单元格时有一个陷阱,如果添加的单元格数不是列数的整数倍,将会抛出异常 。通过循环添加单元格时,往往会忽略掉这个问题。

  如果要将上述的单元格 cell 拆分为两列,则需要在 cell 中嵌入另一个表格,如下:

[java]  view plain copy
  1. PdfPCell  ttCellItem new PdfPCell();  
  2. PdfPCell  ttCellConst new PdfPCell();  
  3.   
  4. ttCellItem.addElement(tItemTable);  
  5. ttCellConst.addElement(tPlanSumTable);  
  6. tTable.addCell(ttCellItem);  
  7. tTable.addCell(ttCellConst);  


 这时如果查看生成的 PDF 文件会发现有很多问题,一是单元格的边框线和内嵌的表格的边框线都会显示出来,二是内嵌的表格并未填满整个单元格,四周都会有留白,左右两边尤甚。对于问题一,可以将外围单元格的边框宽度设为 0,只显示内嵌表格的边框线即可。问题二的话,则需要设置外围单元格的 Padding 属性,也可单独针对某一边设置,这与 CSS 类似。程序如下:

 

[java]  view plain copy
  1. ttCellItem.setBorderWidth(0f);  
  2. ttCellItem.setPadding(0f);  
  3. ttCellConst.setBorderWidth(0f);  
  4. ttCellConst.setPadding(0f);  
 再查看生成的文档,发现上下两边正确了,但左右两边仍然有很宽的留白。看来 iTextSharp 对于内嵌表格会有一个默认的宽度百分比,从而导致两边出现空白。这需要我们设定表格的宽度,如下:

 

[java]  view plain copy
  1. tItemTable.setWidthPercentage(100f);  
  2. tPlanSumTable.setWidthPercentage(100f);  
  3.  // 设定表格的宽度百分比,百分比是相对父元素宽度而言的  

  再查看文档,这回正确了。但最后还有是有一个问题,不可能每个单元格都是均分的吧,那么如何设定单元格的宽度呢?如下:
    innerTable.SetWidths(new int[] { 10, 90 });    // 设置各列宽度,单位是百分比

  到这里,基本的表格就完成了。

[java]  view plain copy
  1. <pre name="code" class="java" style="margin-top: 4px; margin-right: 0px; margin-bottom: 4px; margin-left: 0px; background-color: rgb(240, 240, 240); "><pre name="code" class="java" style="margin-top: 4px; margin-right: 0px; margin-bottom: 4px; margin-left: 0px; background-color: rgb(240, 240, 240); "><pre></pre>  
  2. <pre></pre>  
  3. <pre></pre>  
  4. <pre></pre>  
  5. <pre></pre>  
  6. <pre></pre>  
  7. <pre></pre>  
  8. <pre></pre>  
  9. <pre></pre>  
  10. <pre></pre>  
  11. <pre></pre>  
  12. <pre></pre>  
  13. <pre></pre>  
  14. <pre></pre>  
  15. <pre></pre>  
  16. <pre></pre>  
  17. <pre></pre>  
  18. <pre></pre>  
  19. <pre></pre>  
  20. </pre></pre>  
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值