前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >TCPDF_TCP ACK

TCPDF_TCP ACK

作者头像
全栈程序员站长
发布2022-10-05 08:35:57
1.2K0
发布2022-10-05 08:35:57
举报
文章被收录于专栏:全栈程序员必看

大家好,又见面了,我是你们的朋友全栈君。

最近项目中使用报表,需要用到php来生成pdf文件,采用目前较流行的tcpdf插件,评论区有如何解决乱码的答案,如有问题,希望有机会评论交流。

调用tcpdf文件

代码语言:javascript
复制
require_once('tcpdf.php');

设置时区,否则会导致报错

代码语言:javascript
复制
date_default_timezone_set('Asia/Shanghai');

实例化tcpdf 页面方向(P =肖像,L =景观)、测量(mm)、页面格式

代码语言:javascript
复制
$pdf = new TCPDF('P', 'mm', 'A4', true, 'UTF-8', false); 

设置文档信息

代码语言:javascript
复制
$pdf->SetCreator('Helloweba');
$pdf->SetAuthor('yueguangguang');
$pdf->SetTitle('Welcome to helloweba.com!');
$pdf->SetSubject('TCPDF Tutorial');
$pdf->SetKeywords('TCPDF, PDF, PHP');

扩展,自定义页眉页脚 设置pdf背景图片

代码语言:javascript
复制
$image_file = K_PATH_IMAGES.'bkground.png';
$this->Image($image_file, 0, 0, 210, 15, '', '', '', false, 300, '', false, false, 0);

设置背景颜色(需要注意,只能设置一个)

代码语言:javascript
复制
$this->Rect(0,0,210,297,'F','',$fill_color = array(255, 255, 255));

设置字体(droidsansfallback该字体为导入字体,支持中文)

代码语言:javascript
复制
$this->SetFont('droidsansfallback', 'B', 13);

设置文本颜色

代码语言:javascript
复制
$this->SetTextColor(171,171,171);

设置表内内容距离边框的距离。分别左、上、右、下。

代码语言:javascript
复制
$this->setCellPaddings(15, 10, 5, 0);
$this->setCellMargins(0, 1, 0, 0);//
$this->Cell(180, 15, '测试', 0, true, 'L', 0, '', 0, true, 'M', 'M');
$this->SetFont('droidsansfallback', 'B', 8);

注意如想在不同位置设置文字,可多次使用setCellPaddings()不会产生冲突。 设置表内内容距离边框的距离。分别左、上、右、下。

代码语言:javascript
复制
$this->setCellPaddings(13, 10, 5, 2);

设置是否打印页眉页脚,即去掉默认横线

代码语言:javascript
复制
$pdf->setPrintHeader(true); //设置打印页眉
$pdf->setPrintFooter(false); //设置打印页脚

设置默认页眉页脚相关参数

代码语言:javascript
复制
$pdf->SetHeaderData(PDF_HEADER_LOGO, PDF_HEADER_LOGO_WIDTH, PDF_HEADER_TITLE.' 061', PDF_HEADER_STRING);
设置页眉页脚字体
$pdf->setHeaderFont(Array(PDF_FONT_NAME_MAIN, '', PDF_FONT_SIZE_MAIN));
$pdf->setFooterFont(Array(PDF_FONT_NAME_DATA, '', PDF_FONT_SIZE_DATA));
set default monospaced font
$pdf->SetDefaultMonospacedFont(PDF_FONT_MONOSPACED);
$pdf->SetHeaderMargin(PDF_MARGIN_HEADER);
$pdf->SetFooterMargin(PDF_MARGIN_FOOTER);

设置PDF页面边距(margin)

代码语言:javascript
复制
$pdf->SetMargins(1, 15, 1);//左、右、上
$pdf->SetAutoPageBreak(TRUE, 15);//下

设置图片缩放比例

代码语言:javascript
复制
$pdf->setImageScale(PDF_IMAGE_SCALE_RATIO);

添加一个页面包含结束符

代码语言:javascript
复制
$pdf->AddPage();
$pdf->lastPage();

设置行距

代码语言:javascript
复制
$pdf->Ln(4);

如何嵌套html的三种方式 此方法渲染html边框顶格

代码语言:javascript
复制
$pdf->writeHTML($html, true, false, true, false, '');
代码语言:javascript
复制
原型为 writeHTML($html, $ln=true, $fill=false, $reseth=false, $cell=false, $align='')
代码语言:javascript
复制
第一个参数为html格式的字符串;第三个参数设置是否填充背景色,值为false(不填充)或true(填充);

此方法渲染html会产生一定间距

代码语言:javascript
复制
$pdf->writeHTMLCell(80, '', '', $y, $left_column, 1, 0, 1, true, 'J',  true);
代码语言:javascript
复制
原型:writeHTMLCell($w, $h, $x, $y, $html='', $border=0, $ln=0, $fill=false,  $reseth=true, $align='', $autopadding=true),
代码语言:javascript
复制
参数可对照MultiCell(),分别为宽度,高 度,x坐标,y坐标,内容,是否右边框,与下一个单元格的相对为位置,是否填充背景色,是否重置高度,文本对齐方式,是否自动… 

此方法渲染html会居中效果,注意将$ishtml设置为true

代码语言:javascript
复制
$pdf->MultiCell(0, 5, $html, $border=0, $align='C',$fill=false, $ln=1, $x='', $y='',  $reseth=true, $stretch=0,$ishtml=true,$autopadding=true);

设置获取xy坐标

代码语言:javascript
复制
$pdf->setY()/getY()

设置直线,注意第二个参数和第四个参数保持一致时才为水平直线

代码语言:javascript
复制
$linestyle = array('width' => 0.1, 'cap' => 'butt', 'join' => 'miter', 'dash' => '', 'phase' => 0, 'color' => array(143,195,226));
$pdf->Line(6, 32, 200, 32, $linestyle);

设置左边距、右边距

代码语言:javascript
复制
$pdf->SetLeftMargin(0);
$pdf->SetRightMargin(0);

输出pdf(I为在浏览器上输出,D为下载、F为保存)

代码语言:javascript
复制
$pdf->Output('report_new.pdf', 'I');

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年9月8日 下,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
腾讯云 BI
腾讯云 BI(Business Intelligence,BI)提供从数据源接入、数据建模到数据可视化分析全流程的BI能力,帮助经营者快速获取决策数据依据。系统采用敏捷自助式设计,使用者仅需通过简单拖拽即可完成原本复杂的报表开发过程,并支持报表的分享、推送等企业协作场景。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档