我在 A4 纸张上打印一些带有 24 标签的文字时遇到问题。
基本上,在每一行中都有3个标签,其中包含一个人的姓名,姓名和标签,该标签将用于邮件(这是贴在邮件上的粘性标签)。
所以这是论文。其特点:
height:0.5mm;
。height:36mm;
。width:70mm;
和height:36mm;
。text-align:center;
和vertical-align:middle;
。我正在使用normalize.css进行 css重置。
CSS
html,body,table{
width: 100%;
height: 100%;
}
.first, .last{
width: 100%;
height: 5mm;
}
.row{
width: 100%;
height: 36mm;
}
.cell{
width: 70mm;
height: 36mm;
text-align: center;
vertical-align: middle;
}
我正在使用 Chrome ,我在打印时关闭了边距。
但是,最后两行仍打印在下一页上。 我需要同一页面上的所有10行,并且如果有多个页面,它们的位置是固定的(不会移位)。
如何修复/实现这一目标?或者是否有更简单的解决方案?
以下是code。
的示例答案 0 :(得分:2)
我使用FPDF
类为我的标签创建了一个pdf。
require_once ABSPATH . '/path/to/fpdf.php';
class PDF_MC_Table extends FPDF{
var $widths;
var $aligns;
function SetWidths($w){
//Set the array of column widths
$this->widths=$w;
}
function SetAligns($a){
//Set the array of column alignments
$this->aligns=$a;
}
function Row($data){
//Calculate the height of the row
$nb=0;
for($i=0;$i<count($data);$i++)
$nb=max($nb,$this->NbLines($this->widths[$i],$data[$i]));
$h = 36;// again trial and error until you fnd the desired height of your label
//Issue a page break first if needed
$this->CheckPageBreak($h);
//Draw the cells of the row
for($i=0;$i<count($data);$i++){
$w=$this->widths[$i];
$a=isset($this->aligns[$i]) ? $this->aligns[$i] : 'L';
//Save the current position
$x=$this->GetX();
$y=$this->GetY();
//Draw the border. reset the parameters of the function below as you desire.
$this->Rect($x,$y,$w,$h);
//Print the text. reset the parameters of the function below as you desire. changing the values will resize the boxs.
$this->MultiCell($w,3,$data[$i],0,$a);
//Put the position to the right of the cell. reset the parameters of the function below as you desire. changing the $x and $y will shift the cells.
$this->SetXY($x+$w,$y);
}
//Go to the next line
$this->Ln($h+3);
}
function CheckPageBreak($h){
//If the height h would cause an overflow, add a new page immediately
if($this->GetY()+$h>$this->PageBreakTrigger)
$this->AddPage($this->CurOrientation);
}
function NbLines($w,$txt){
//Computes the number of lines a MultiCell of width w will take
$cw=&$this->CurrentFont['cw'];
if($w==0)
$w=$this->w-$this->rMargin-$this->x;
$wmax=($w-2*$this->cMargin)*1000/$this->FontSize;
$s=str_replace("\r",'',$txt);
$nb=strlen($s);
if($nb>0 and $s[$nb-1]=="\n")
$nb--;
$sep=-1;
$i=0;
$j=0;
$l=0;
$nl=1;
while($i<$nb){
$c=$s[$i];
if($c=="\n"){
$i++;
$sep=-1;
$j=$i;
$l=0;
$nl++;
continue;
}
if($c==' ')
$sep=$i;
$l+=$cw[$c];
if($l>$wmax){
if($sep==-1){
if($i==$j)
$i++;
}
else
$i=$sep+1;
$sep=-1;
$j=$i;
$l=0;
$nl++;
}
else
$i++;
}
return $nl;
}
}
$pdf=new PDF_MC_Table();
$pdf->SetMargins(4, 2);
$pdf->AddPage();
$pdf->SetFont('Arial','',8);
// displays the empty row in the top
$pdf->SetRightMargin(2);
$pdf->SetLeftMargin(4);
$pdf->Cell(0,10,'',1);
$pdf->Ln(10);
$pdf->SetWidths(array(50,50,50));// these are the widths of your cells. this is a trial and error process. increase the values until you find the suitable ones.
$count = 0;
$lables = array(); // your labels array
$l = array();
$j = 0;
// i used this foreach for breaking my plain array into a 2dimentional array- an array of arrays consisting 3 labels in each.
foreach($lables as $i=>$lbl ){
$l[$j][] = $lbl;
if($i%3==2){$j++;} // $i=0,1,2 > $j=0; $i=3,4,5 > $j=2 etc this will break the main labels array as 2D array.
}
// displays the empty row in the bottom.
$pdf->Ln(1);
$pdf->Cell(0,10,'',1);
$pdf->Output();
有关类和方法的更多信息,请参阅http://www.fpdf.org/最多您需要了解三种方法 - Multicell(),Cell()和Rect()方法。这些方法有很好的解释,并在网站上有例子。
在这里,我发布了我的解决方案,并根据您的问题更改了一些代码。大多数事情都是自我解释的。如果您需要进一步的帮助,请随时发表评论。感谢。
答案 1 :(得分:0)
如果您没有使用特定尺寸,则会减小单元格和行高度尺寸,即使关闭边距后会发生什么,打印数据超出纸张长度并且打印机会自动将其移动到另一页。
这是我认为你可以尝试的最佳解决方案。
p.s:这些粘性标签通常附带他们的设计软件cd,您通常用它来设置预览边距。如果你没有它,你唯一可以做的就是按照我上面所说的方式调整高度,在普通A4普通纸上打印并用粘性标签纸打开。我曾经也是这样做的......虽然为我工作
答案 2 :(得分:0)
如果您的打印机支持此功能,请尝试无边框打印。
答案 3 :(得分:0)
尝试添加下面的样式并使用@page属性进行播放。有关@page的更多信息,请访问:https://developer.mozilla.org/en-US/docs/CSS/@page
我很幸运使用下面定义的样式在8.5x11文档上完美打印,我可以设置自己的页边距并从浏览器中获得一致的结果。
<style type="text/css" media="print">
@page {
size: auto; /* auto is the initial value */
margin: 0mm; /* this affects the margin in the printer settings */
}
body {
background-color: #fff;
border: solid 1px #000 ;
margin: 0px; /* this affects the margin on the content before sending to printer */
padding: 0.25in 0.5in;
}
</style>