如何使用php和mysql在fpdf中动态创建多个id卡

时间:2018-06-03 08:20:47

标签: php mysql fpdf

我正在尝试使用fpdf创建身份证,其中id卡中的数据来自mysql数据库,我已成功解决问题,我想生成许多ID卡,如10张身份证一次当我尝试打击代码时,它会生成身份证但是将一个放在另一个身上,我只能看到最后一张身份证:

A)所以,我怎么能动态地给他们不同的身份证位置? 下面是我的代码和显示输出的图像: output image

  <?php
         include('connect.php'); 
         require_once('fpdf/fpdf.php');

    if(ISSET($_POST['generate_id'])){   
            $semsec = $_POST['id']; 
    $result=$conn->query("SELECT * FROM `student` WHERE `semsec` = '$semsec'") or die(mysqli_error($conn));
    if ($result->num_rows == 0) {
        // output data of each row
     echo '
                    <script type = "text/javascript">
                    alert("Student Not Found For The Provided Semister and Section");
                        window.location = "home.php";
                    </script>
                ';
    } else {

    while($row=mysqli_fetch_array($result))
    {
    $cls[]=$row;
    }
    $json=json_encode($cls);
    $obj = json_decode($json,true);
    class PDF extends FPDF
    {

    }
        $pdf = new PDF();
        $pdf->AddPage();

        foreach($obj as $item) {

        $name=$item['firstname'];
        $lname=$item['lastname'];
        $id=$item['student_no'];
        $semsec=$item['semsec'];
        $profile=$item['image'];
        $qr=$item['barcode'];

            $pdf->Image('images/background2.jpg', 10, 10,100, 50);
            $pdf->Image($profile, 80, 15,25, 30);
            $pdf->Image($qr, 15, 45,20, 15);
            $pdf->AddFont('courier','','courier.php');  
            $pdf->SetFont('courier','b',10);
            $pdf->SetXY(33, 22.8);
            $pdf->SetFont('Arial','B',10);
            $pdf->Cell(9.5,7,$name,0,4,'L');
            $pdf->SetXY(33, 28);
            $pdf->SetFont('Arial','B',10);
            $pdf->Cell(9.5,7,$lname,0,4,'L');
            $pdf->SetXY(33, 33.5);
            $pdf->SetFont('Arial','B',10);
            $pdf->Cell(9.5,7,$id,0,4,'L');
            $pdf->SetXY(33, 39);
            $pdf->SetFont('Arial','B',10);
            $pdf->Cell(9.5,7,$semsec,0,4,'L');

            }
    $pdf->Output();
    }
    }

    ?>

1 个答案:

答案 0 :(得分:0)

问题是你将ID设置在彼此的顶部,没有每个ID的偏移或每个ID的新页面。

如果您需要每页ID,则需要在制作每个ID后调用$pdf->AddPage();。 这将创建一个新页面并将XY设置在页面的左上角。

如果你想要每页多个ID卡,例如每页X个数量,拆分id卡阵列,这样你就可以一次循环超过X量,PHP函数array_chunk会为你分割它,然后将XY坐标偏移你想要的数量,例如我做了这个

$pdf = new PDF();
$pdf->AddPage();

$input_array = array('a', 'b', 'c', 'd', 'e');

$farray = array_chunk($input_array, 2);
foreach($farray as $obj) {
    $yOffset = 0;
    foreach($obj as $item) {
        $pdf->SetXY(33, 28 + $yOffset);
        $pdf->SetFont('Arial', 'B', 10);
        $pdf->Cell(9.5, 7, $item, 0, 4, 'L');
        $yOffset += 40; // Y distance between letters
    }
    $pdf->AddPage();
}
$pdf->Output();