itextsharp: pdfptables сталкиваются друг с другом

Кто-нибудь знает, почему мои таблицы накладываются друг на друга?

Dim datatable As PdfPTable = New PdfPTable(4)
Dim page As Rectangle = document.PageSize
datatable.TotalWidth = page.Width - document.LeftMargin - document.RightMargin
datatable.DefaultCell.Border = 0

Dim datatable1 As PdfPTable = New PdfPTable(4)
datatable1.TotalWidth = page.Width - document.LeftMargin - document.RightMargin
datatable1.DefaultCell.Border = 0

Dim datatable2 As PdfPTable = New PdfPTable(4)
datatable2.TotalWidth = page.Width - document.LeftMargin - document.RightMargin
datatable2.DefaultCell.Border = 0

Dim last_pos As Integer = 580
Const xpos As Integer = 70

For i = 0 To extreme_foods.Count - 1
    datatable.AddCell(extreme_foods(i))
Next

datatable.WriteSelectedRows(0, -1, xpos, last_pos, writer.DirectContent)

For i = 0 To moderate_foods.Count - 1
    datatable1.AddCell(moderate_foods(i))
Next

last_pos = last_pos - datatable1.TotalHeight
datatable1.WriteSelectedRows(0, -1, xpos, last_pos, writer.DirectContent)

For i = 0 To light_foods.Count - 1
    datatable2.AddCell(light_foods(i))
Next

last_pos = last_pos - datatable2.TotalHeight
datatable2.WriteSelectedRows(0, -1, xpos, last_pos, writer.DirectContent)

'document.Add(datatable)

Catch de As DocumentException
    Console.Error.WriteLine(de.Message)
    MessageBox.Show(de.Message)
Catch ioe As IOException
    Console.Error.WriteLine(ioe.Message)
    MessageBox.Show(ioe.Message)
Catch e As Exception
    Console.Error.WriteLine(e.Message)
    MessageBox.Show(e.Message)

End Try
document.Close()

Несмотря на то, что я уменьшаю last_pos на высоту предыдущей таблицы, они все равно странным образом перекрываются, например:

скриншот http://img3.imageshack.us/img3/8168/38741459.jpg


person Alex Gordon    schedule 03.09.2009    source источник


Ответы (1)


ваше вычитание чуть-чуть прочь. вы вычитаете last_pos из текущей таблицы, а не из предыдущей. вы должны делать это:

Dim last_pos As Integer = 580
Const xpos As Integer = 70
For i = 0 To extreme_foods.Count - 1
    datatable.AddCell(extreme_foods(i))
Next

datatable.WriteSelectedRows(0, -1, xpos, last_pos, writer.DirectContent)
For i = 0 To moderate_foods.Count - 1
    datatable1.AddCell(moderate_foods(i))
Next

last_pos = last_pos - datatable.TotalHeight '<--- NOT datatable1'
datatable1.WriteSelectedRows(0, -1, xpos, last_pos, writer.DirectContent)
person Jason    schedule 03.09.2009