当使用特殊(slovic)字符?时,PHP的TCPDF创建空PDF
我正在使用TCPDF生成PDF(显然).一切都很好,但现在我正在尝试制作一个带有“?”字符的PDF(显然是一个斯洛文字符).
数据是用户生成的,所以我不知道他们是否计划使用这些类型的字符 – 这就是为什么我认为我应该使用UTF-8.但显然这是不对的. PDF已创建,但它完全为空/白色. 这是我的相关代码: $pdf = new XTCPDF('P',PDF_UNIT,'Letter',true,'UTF-8',false); $pdf->SetPrintHeader(false); $pdf->SetPrintFooter(false); $pdf->SetDefaultMonospacedFont(PDF_FONT_MONOSPACED); $pdf->SetMargins($pageMargin,$pageMargin,$pageMargin); //PDF_MARGIN_LEFT,PDF_MARGIN_TOP,PDF_MARGIN_RIGHT $pdf->SetAutoPageBreak(TRUE,$pageMargin/2); $pdf->setImageScale(PDF_IMAGE_SCALE_RATIO); $pdf->SetFont('helvetica','',10,true); $pdf->AddPage(); $pdf->setJPEGQuality(70); 我找到了this answer但是换到这个也不起作用: $pdf = new XTCPDF('P',false,'ISO-8859-1',false); 我的数据片段(用户名,地址等)目前包含如下: trim(mb_convert_encoding($myHtml,"HTML-ENTITIES","UTF-8")) 问题: 我可以改变什么来做到这一点: >我可以创建一个像“?”这样的字符的PDF 解决方法
David van Driessche有
correctly identified the problem;使用的字体不支持?字符.
基本测试(注意我将此PHP脚本保存为UTF8文件): require './tcpdf/tcpdf.php'; function write($pdf) { $pdf->Write(0,'test ? ',0); $pdf->writeHTML(trim(mb_convert_encoding('test2 ?',"UTF-8")),''); } $pdf = new TCPDF('P',false); $pdf->AddPage(); $pdf->SetFont('helvetica',20); write($pdf); $pdf->SetFont('freesans',20); write($pdf); $pdf->Output(); 这给了我以下PDF输出(在Firefox中呈现): 查看TCPDF example for including an external UTF-8 text file,您可以看到以下非常有趣的内容: $pdf->SetFont('freeserif',12); 奇怪的是,freeserif并没有被列为standard TCPDF fonts之一,而是在与TCPDF一起分发的fonts文件夹中(在这个文件夹中也看到了freesans,所以我在上面的例子中使用了它).我只能假设文档不是最新的. 您似乎可以选择使用freesans或通过AddFont()方法加载第三方字体. 编辑:我测试了上面的一个稍微旧的TCPDF版本:6.0.099. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |