Как центрировать абсолютно позиционированные элементы в CSS для PDF - PullRequest
1 голос
/ 03 января 2012

Я пытаюсь центрировать имена (# box2) и тему (# box1) поверх изображения.

<?php require_once('seminar_config.php'); ?>

<a href="print.certificate.php">Print</a>

<body>
<?php
$participants = $db->get_results("SELECT participant FROM tbl_participants WHERE state=1");
$topics = $db->get_results("SELECT topic FROM tbl_topics");
if(!empty($participants)){
?>
<?php ob_start(); ?>
<div id="container">
<img src="certificate.jpg"/>
<?php foreach($topics as $a=>$b){ ?>
<?php foreach($participants as $k=>$v){ ?>
    <img src="certificate.jpg"/>
    <div id="box1" class="common"><?php echo $b->topic; ?></div>
    <div id="box2" class="common"><?php echo $v->participant; ?></div>
<?php } ?>
<?php } ?>  
</div>
<?php $_SESSION['certificates'] = ob_get_contents(); ?>
<?php ob_flush(); ?>    
<?php } ?>
</body>

А вот скрипт, который создает PDF:

<?php require_once('html2pdf/html2pdf.class.php'); ?>
<?php
$html2pdf = new HTML2PDF('L', 'A4', 'en');
$html2pdf->writeHTML('<style>

    #box1{  
        margin-top: 350px;
    }

    #box2{  
        margin-top: 200px;
    }

    .common{
        height: 20px;
        left: 630px;
        right: 630px;
        text-align: center;
        position: absolute;
        left: 0;
        top: 0;
        font-size:20px;
    }
</style>'.

$_SESSION['certificates']);
$html2pdf->Output('random.pdf');
?>

У меня нет проблем с центральным расположением имен и тем, если я не использую html2pdf для генерации pdf-файлов.Но если я использую html2pdf, все разрушается.Пожалуйста, помогите мне центрировать вещи в CSS при использовании html2pdf.

Ответы [ 5 ]

2 голосов
/ 21 июля 2014

Старый вопрос, но у меня была похожая проблема сегодня. Вот как я смог решить эту проблему после попытки каждого метода в истории html и css центрировать что-либо. Я использовал стол как JorisW:

<table style='width:100%' align='center'>
    <tr>
        <td>
            <img src="image.gif">
        </td>
    </tr>
</table>
2 голосов
/ 03 января 2012

Если вы хотите центрировать .common, попробуйте следующее:

    .common{
       position: absolute;
       left: 50%;
       top: 0;
       font-size:20px;
       width:600px;
       margin-left:-300px;
    }
2 голосов
/ 03 января 2012

Большинство обычных программ HTML-to-PDF либо не понимают CSS, либо плохо понимают CSS.Если ваш HTML работает, но плохо переводит в PDF с использованием html2pdf, вы можете попробовать wkhtmltopdf https://github.com/antialize/wkhtmltopdf

1 голос
/ 03 января 2012

Вот то, что я использую, чтобы расположить div в центре.

Скажем, вы хотите поместить div с id = test

CSS

#test {
   width: 500px;
   margin: 0 auto; //auto margin to left and right
}
1 голос
/ 03 января 2012

Попробуйте использовать таблицы и встроенные стили CSS

<table align="left" width="100%" style="page-break-after:always; margin-top:25px; margin-left:25px; font-family:tahoma; font-size:20px; ">
<tr><td>Your info</td></tr>
</table>
...