0.79と0.7.2の両方を使用すると、生成されたPDFは元のHTMLとは少し異なります。show_as_htmlフラグを追加すると、期待どおりに表示されますが、インラインスタイルはPDFでの処理と、HTMLプレビューでの処理が異なります。
特に私が抱えている問題は、フロートが正しくレンダリングされていない文字間隔宣言にあります。したがって、たとえば、文字間隔のある右側のfloat要素では、PDFは文字の間隔を広げすぎて、文字間隔の幅の違いのためにテキストがさらに左にぶつかるのではなく、テキストが画面から部分的に外れるように中央から配置します。 。
元のHTMLスニペットは次のとおりです。
<table width="800" border="0">
<tr>
<td colspan="3"><span style="font-family:Helvetica, Arial, sans-serif;font-size:10pt;margin-top:18px;text-transform:uppercase;float: right;letter-spacing:2pt">Winter 2013</span></td>
</tr>
</table>
レンダリングを行うコードは次のとおりです。
render :pdf => 'file_name',
:template => 'template.html.erb',
:layout => 'pdf.html'
レンダリングされたHTMLは次のとおりです:http://jsfiddle.net/wX4DQ/
出力されたPDFは次のとおりです:http://imgur.com/sdUPM
これについて、 wkhtmltopdfに関連していると思われるバグレポートがいくつかあることに気づきました。それがこの問題の原因である可能性がありますが、許容できる回避策は何ですか?
さまざまなフォントを試しましたが、実際にはHelveticaを使用する必要があります。
ここで何をするか、またはもっともらしい回避策について何か提案はありますか?