我正在尝试使用数据表创建一个PDF文件。但是当遇到分页符时,每次在断点级别将新的多单元添加到页面时它会跳转到新页面。
我尝试使用TCPDF做同样的事情,但每次在分页点级别附近添加一个新单元时,页面中断的问题仍然相同...
示例:
http://www.online-økonomi.dk/_tst_fpdf.php
require_once '../class/download/fpdf/fpdf.php';
class File_PDF {
private $pdf;
private $col_product = 25;
private $col_unit = 12;
private $col_price = 20;
private $col_count = 14;
private $col_discount = 12;
private $col_vat = 12;
private $col_sum = 22;
private $width = 200;
private $line_height = 4.2;
private $margin_top = 30;
public function generate(){
$this->pdf = new FPDF();
$this->pdf->AddPage();
$this->pdf->SetDisplayMode('real');
$this->pdf->SetAutoPageBreak(true, 150);
if($this->products){
$i = 0;
$this->color_light();
foreach($this->products as $product){
$this->add_product($product, $i % 2 ? true:false);
$i++;
}
}
$this->pdf->Output();
}
private function add_product($product, $fill){
$this->txt();
$x = $this->width;
$y = $this->pdf->GetY();
$this->cell_sum($this->col_sum, $x, $y, $product['sum'] / 100, 'R', $fill);
$this->cell_vat($this->col_vat, $x, $y, $product['vat_percent'], 'R', $fill);
$this->cell_discount($this->col_discount, $x, $y, $product['discount_percent'] / 100, 'R', $fill);
$this->cell_count($this->col_count, $x, $y, $product['count'] / 100, 'R', $fill);
$this->cell_price($this->col_price, $x, $y, $product['price'] / 100, 'R', $fill);
$this->cell_unit($this->col_unit, $x, $y, $product['unit_name'], 'L', $fill);
$this->cell_name(0, $x, $y, $product['name'], 'L', $fill);
$this->cell_product($this->col_product, $x, $y, $product['product_id_'], 'L', $fill);
}
private function cell_sum($width, &$x, $y, $str, $align, $fill=false){
$this->cnstr_cell($width, $x, $y, $str, $align, $fill);
}
private function cell_vat($width, &$x, $y, $str, $align, $fill=false){
$this->cnstr_cell($width, $x, $y, $str, $align, $fill);
}
private function cell_discount($width, &$x, $y, $str, $align, $fill=false){
$this->cnstr_cell($width, $x, $y, $str, $align, $fill);
}
private function cell_count($width, &$x, $y, $str, $align, $fill=false){
$this->cnstr_cell($width, $x, $y, $str, $align, $fill);
}
private function cell_price($width, &$x, $y, $str, $align, $fill=false){
$this->cnstr_cell($width, $x, $y, $str, $align, $fill);
}
private function cell_unit($width, &$x, $y, $str, $align, $fill=false){
$this->cnstr_cell($width, $x, $y, $str, $align, $fill);
}
private function cell_name($width, &$x, $y, $str, $align, $fill=false){
$this->pdf->SetXY($this->col_product + 10, $y);
$this->pdf->MultiCell($x - $this->col_product - 10, $this->line_height, $str, 0, $align, $fill);
}
private function cell_product($width, &$x, $y, $str, $align, $fill=false){
$this->pdf->SetXY(10, $y);
$this->pdf->MultiCell($this->col_product, $this->line_height, $str, 0, $align, $fill);
}
private function cnstr_cell($width, &$x, $y, $str, $align='L', $fill=false){
$x -= $width;
$this->pdf->SetXY($x, $y);
$this->pdf->MultiCell($width, $this->line_height, $str, 0, $align, $fill);
}
private function color_light(){
$this->pdf->SetFillColor(200, 200, 200);
}
private function txt(){
$this->pdf->SetFont('Arial', '', 8.5);
}
private function txt_marked(){
$this->pdf->SetFont('Arial', 'B', 8.5);
}
private $products = array(
array(
'product_id_' => 'ADS1550',
'name' => 'name',
'unit_name' => 'pcs',
'price' => 182450000,
'count' => 310000,
'discount_percent' => 19900,
'vat_percent' => 0,
'sum' => 1587057200
),
array(
'product_id_' => 'ADS1550',
'name' => 'name',
'unit_name' => 'pcs',
'price' => 182450000,
'count' => 310000,
'discount_percent' => 19900,
'vat_percent' => 0,
'sum' => 1587057200
),
array(
'product_id_' => 'ADS1550',
'name' => 'name',
'unit_name' => 'pcs',
'price' => 182450000,
'count' => 310000,
'discount_percent' => 19900,
'vat_percent' => 0,
'sum' => 1587057200
),
array(
'product_id_' => 'ADS1550',
'name' => 'name',
'unit_name' => 'pcs',
'price' => 182450000,
'count' => 310000,
'discount_percent' => 19900,
'vat_percent' => 0,
'sum' => 1587057200
),
array(
'product_id_' => 'ADS1550',
'name' => 'name',
'unit_name' => 'pcs',
'price' => 182450000,
'count' => 310000,
'discount_percent' => 19900,
'vat_percent' => 0,
'sum' => 1587057200
),
array(
'product_id_' => 'ADS1550',
'name' => 'name',
'unit_name' => 'pcs',
'price' => 182450000,
'count' => 310000,
'discount_percent' => 19900,
'vat_percent' => 0,
'sum' => 1587057200
),
array(
'product_id_' => 'ADS1550',
'name' => 'name',
'unit_name' => 'pcs',
'price' => 182450000,
'count' => 310000,
'discount_percent' => 19900,
'vat_percent' => 0,
'sum' => 1587057200
),
array(
'product_id_' => 'ADS1550',
'name' => 'name',
'unit_name' => 'pcs',
'price' => 182450000,
'count' => 310000,
'discount_percent' => 19900,
'vat_percent' => 0,
'sum' => 1587057200
),
array(
'product_id_' => 'ADS1550',
'name' => 'name',
'unit_name' => 'pcs',
'price' => 182450000,
'count' => 310000,
'discount_percent' => 19900,
'vat_percent' => 0,
'sum' => 1587057200
),
array(
'product_id_' => 'ADS1550',
'name' => 'name',
'unit_name' => 'pcs',
'price' => 182450000,
'count' => 310000,
'discount_percent' => 19900,
'vat_percent' => 0,
'sum' => 1587057200
),
array(
'product_id_' => 'ADS1550',
'name' => 'name',
'unit_name' => 'pcs',
'price' => 182450000,
'count' => 310000,
'discount_percent' => 19900,
'vat_percent' => 0,
'sum' => 1587057200
),
array(
'product_id_' => 'ADS1550',
'name' => 'name',
'unit_name' => 'pcs',
'price' => 182450000,
'count' => 310000,
'discount_percent' => 19900,
'vat_percent' => 0,
'sum' => 1587057200
),
array(
'product_id_' => 'ADS1550',
'name' => 'name',
'unit_name' => 'pcs',
'price' => 182450000,
'count' => 310000,
'discount_percent' => 19900,
'vat_percent' => 0,
'sum' => 1587057200
),
array(
'product_id_' => 'ADS1550',
'name' => 'name',
'unit_name' => 'pcs',
'price' => 182450000,
'count' => 310000,
'discount_percent' => 19900,
'vat_percent' => 0,
'sum' => 1587057200
),
array(
'product_id_' => 'ADS1550',
'name' => 'name',
'unit_name' => 'pcs',
'price' => 182450000,
'count' => 310000,
'discount_percent' => 19900,
'vat_percent' => 0,
'sum' => 1587057200
),
array(
'product_id_' => 'ADS1550',
'name' => 'name',
'unit_name' => 'pcs',
'price' => 182450000,
'count' => 310000,
'discount_percent' => 19900,
'vat_percent' => 0,
'sum' => 1587057200
),
array(
'product_id_' => 'ADS1550',
'name' => 'name',
'unit_name' => 'pcs',
'price' => 182450000,
'count' => 310000,
'discount_percent' => 19900,
'vat_percent' => 0,
'sum' => 1587057200
),
array(
'product_id_' => 'ADS1550',
'name' => 'name',
'unit_name' => 'pcs',
'price' => 182450000,
'count' => 310000,
'discount_percent' => 19900,
'vat_percent' => 0,
'sum' => 1587057200
),
array(
'product_id_' => 'ADS1550',
'name' => 'name',
'unit_name' => 'pcs',
'price' => 182450000,
'count' => 310000,
'discount_percent' => 19900,
'vat_percent' => 0,
'sum' => 1587057200
),
array(
'product_id_' => 'ADS1550',
'name' => 'name',
'unit_name' => 'pcs',
'price' => 182450000,
'count' => 310000,
'discount_percent' => 19900,
'vat_percent' => 0,
'sum' => 1587057200
),
array(
'product_id_' => 'ADS1550',
'name' => 'name',
'unit_name' => 'pcs',
'price' => 182450000,
'count' => 310000,
'discount_percent' => 19900,
'vat_percent' => 0,
'sum' => 1587057200
),
array(
'product_id_' => 'ADS1550',
'name' => 'name',
'unit_name' => 'pcs',
'price' => 182450000,
'count' => 310000,
'discount_percent' => 19900,
'vat_percent' => 0,
'sum' => 1587057200
),
array(
'product_id_' => 'ADS1550',
'name' => 'name',
'unit_name' => 'pcs',
'price' => 182450000,
'count' => 310000,
'discount_percent' => 19900,
'vat_percent' => 0,
'sum' => 1587057200
),
array(
'product_id_' => 'ADS1550',
'name' => 'name',
'unit_name' => 'pcs',
'price' => 182450000,
'count' => 310000,
'discount_percent' => 19900,
'vat_percent' => 0,
'sum' => 1587057200
),
array(
'product_id_' => 'ADS1550',
'name' => 'name',
'unit_name' => 'pcs',
'price' => 182450000,
'count' => 310000,
'discount_percent' => 19900,
'vat_percent' => 0,
'sum' => 1587057200
),
array(
'product_id_' => 'ADS1550',
'name' => 'name',
'unit_name' => 'pcs',
'price' => 182450000,
'count' => 310000,
'discount_percent' => 19900,
'vat_percent' => 0,
'sum' => 1587057200
),
array(
'product_id_' => 'ADS1550',
'name' => 'name',
'unit_name' => 'pcs',
'price' => 182450000,
'count' => 310000,
'discount_percent' => 19900,
'vat_percent' => 0,
'sum' => 1587057200
),
array(
'product_id_' => 'ADS1550',
'name' => 'name',
'unit_name' => 'pcs',
'price' => 182450000,
'count' => 310000,
'discount_percent' => 19900,
'vat_percent' => 0,
'sum' => 1587057200
),
array(
'product_id_' => 'ADS1550',
'name' => 'name',
'unit_name' => 'pcs',
'price' => 182450000,
'count' => 310000,
'discount_percent' => 19900,
'vat_percent' => 0,
'sum' => 1587057200
),
array(
'product_id_' => 'ADS1550',
'name' => 'name',
'unit_name' => 'pcs',
'price' => 182450000,
'count' => 310000,
'discount_percent' => 19900,
'vat_percent' => 0,
'sum' => 1587057200
),
array(
'product_id_' => 'ADS1550',
'name' => 'name',
'unit_name' => 'pcs',
'price' => 182450000,
'count' => 310000,
'discount_percent' => 19900,
'vat_percent' => 0,
'sum' => 1587057200
),
array(
'product_id_' => 'ADS1550',
'name' => 'name',
'unit_name' => 'pcs',
'price' => 182450000,
'count' => 310000,
'discount_percent' => 19900,
'vat_percent' => 0,
'sum' => 1587057200
),
array(
'product_id_' => 'ADS1550',
'name' => 'name',
'unit_name' => 'pcs',
'price' => 182450000,
'count' => 310000,
'discount_percent' => 19900,
'vat_percent' => 0,
'sum' => 1587057200
),
array(
'product_id_' => 'ADS1550',
'name' => 'name',
'unit_name' => 'pcs',
'price' => 182450000,
'count' => 310000,
'discount_percent' => 19900,
'vat_percent' => 0,
'sum' => 1587057200
),
array(
'product_id_' => 'ADS1550',
'name' => 'name',
'unit_name' => 'pcs',
'price' => 182450000,
'count' => 310000,
'discount_percent' => 19900,
'vat_percent' => 0,
'sum' => 1587057200
),
array(
'product_id_' => 'ADS1550',
'name' => 'name',
'unit_name' => 'pcs',
'price' => 182450000,
'count' => 310000,
'discount_percent' => 19900,
'vat_percent' => 0,
'sum' => 1587057200
),
array(
'product_id_' => 'ADS1550',
'name' => 'name',
'unit_name' => 'pcs',
'price' => 182450000,
'count' => 310000,
'discount_percent' => 19900,
'vat_percent' => 0,
'sum' => 1587057200
),
array(
'product_id_' => 'ADS1550',
'name' => 'name',
'unit_name' => 'pcs',
'price' => 182450000,
'count' => 310000,
'discount_percent' => 19900,
'vat_percent' => 0,
'sum' => 1587057200
),
array(
'product_id_' => 'ADS1550',
'name' => 'name',
'unit_name' => 'pcs',
'price' => 182450000,
'count' => 310000,
'discount_percent' => 19900,
'vat_percent' => 0,
'sum' => 1587057200
),
array(
'product_id_' => 'ADS1550',
'name' => 'name',
'unit_name' => 'pcs',
'price' => 182450000,
'count' => 310000,
'discount_percent' => 19900,
'vat_percent' => 0,
'sum' => 1587057200
),
array(
'product_id_' => 'ADS1550',
'name' => 'name',
'unit_name' => 'pcs',
'price' => 182450000,
'count' => 310000,
'discount_percent' => 19900,
'vat_percent' => 0,
'sum' => 1587057200
)
);
}
$PDF = new File_PDF();
$PDF->generate();
答案 0 :(得分:20)
问题是在Cell()
方法(在MultiCell()
中调用)中,如果当前Y位置+新单元格的高度大于允许值,则FPDF总是添加新页面页面高度。
默认页面高度似乎为297,SetAutoPageBreak()
会从中减去150
。因此,当Y
+ cell_height
比147更为鲜明时,您在调用cnstr_cell()
时会获得新页面。
要防止这种情况,您需要自己致电AddPage()
。在add_product()
方法中添加此项检查:
$x = $this->width;
$y = $this->pdf->GetY();
if (($y + $this->line_height) >= 147) {
$this->pdf->AddPage();
$y = 0; // should be your top margin
}
顺便说一下。我最近也必须生成一个动态PDF,我最终使用wkhtmltopdf,它比所有PHP库更容易使用和自定义。我建议看看它。