TCPDF 导入 PDF 时首页丢失的解决方案

TCPDF 导入 PDF 时首页丢失的解决方案

使用 tcpdf + fpdi 导入现有 pdf 时,若首页未显示,通常是因为未在循环开始前调用 `addpage()`,导致第一页模板被绘制在不存在的页面上。正确做法是:每导入一页前先添加新页面。

在 TCPDF 结合 FPDI(如 TcpdfFpdi)进行 PDF 页面导入时,一个常见但容易被忽视的逻辑错误是:在调用 importPage() 和 useTemplate() 之前,未确保当前文档已存在目标页面。你的原始代码中,首次循环($i = 1)直接执行 importPage(1) 和 useTemplate(),但此时 PDF 文档尚无任何页面(AddPage() 尚未调用),因此该模板被静默丢弃——这就是首页“消失”的根本原因。

✅ 正确写法是:先 AddPage(),再 importPage(),最后 useTemplate()。每一页都严格遵循此顺序:

$pdf = new TcpdfFpdi('P', 'mm', 'A4', true, 'UTF-8', false, true);

$pdf->SetCreator('TCPDF Name');
$pdf->SetAuthor('TCPDF Author');
$pdf->SetTitle('TCPDF title');
$pdf->SetSubject('TCPDF Tutorial');
$pdf->SetKeywords('TCPDF, FPDI, PDF import');

// 加载源 PDF 并获取总页数
$pageCount = $pdf->setSourceFile('/path/to/source.pdf');

// 每页单独处理:先新建页,再导入并渲染模板
for ($i = 1; $i <= $pageCount; $i++) {
    $pdf->AddPage(); // ✅ 关键:为当前页创建空白画布
    $tplIdx = $pdf->importPage($i); // 导入第 i 页为模板
    $pdf->useTemplate($tplIdx, 0, 0, 210, 297); // 渲染到整页(A4 尺寸:210×297 mm)
}

$pdf->Output(public_path('merged.pdf'), 'F');

⚠️ 注意事项:

Viggle AI

Viggle AI

Viggle AI是一个AI驱动的3D动画生成平台,可以帮助用户创建可控角色的3D动画视频。

下载

  • AddPage() 必须在 useTemplate() 之前调用,且每次循环仅调用一次;
  • 不要对最后一页额外调用 AddPage()(即避免 $i
  • useTemplate() 的宽高参数建议使用实际纸张尺寸(如 A4 为 210, 297),单位需与初始化一致(本例为 ‘mm’);
  • 确保 TcpdfFpdi 类已正确继承并兼容 TCPDF v6+ 与 FPDI v2+(推荐使用 setasign/fpdi-tcpdf 官方组合包)。

通过这一调整,所有源 PDF 页面(包括第一页)都将被完整、准确地导入并渲染,彻底解决“首页丢失”问题。

https://www.php.cn/faq/1973224.html

发表回复

Your email address will not be published. Required fields are marked *