PHPExcel:如何在第一页标题中插入图像并将其放大以适合其内容?

时间:2011-06-07 18:40:25

标签: php phpexcel

我有一个用PHPExcel制作的Excel文件,它有一个左对齐标识的标题和右对齐的日期&用户文字。对于第一页,我想要一个类似的标题(相同的标识和相同的日期和用户文本),但有一些添加的信息(文件的标题和参数集中在以后的情侣行)。

这就是我到目前为止所做的事情:

<?php

    $sheet = $this->_spreadsheet->getActiveSheet(); //_spreadsheet is an instance of PHPExcel

    $logo = new PHPExcel_Worksheet_HeaderFooterDrawing();
    $logo->setName('Logo');
    $logo->setPath(DOCUMENT_ROOT . '/public/logo.jpg'); //Path is OK & tested under PHP
    $logo->setHeight(38); //If image is larger/smaller than that, image will be proportionally resized
    $sheet->getHeaderFooter()->addImage($logo, PHPExcel_Worksheet_HeaderFooter::IMAGE_HEADER_LEFT);

    $sheet->getHeaderFooter()->setOddHeader('&L&G&RExport date: ' . date('Y-m-d H:i:s') . "\n" . 'User: ' . $user->name);

    if ($grid->getTitle() != '') {
        $sheet->getHeaderFooter()->setDifferentFirst(true);

        $sheet->getHeaderFooter()->addImage($logo, PHPExcel_Worksheet_HeaderFooter::IMAGE_HEADER_LEFT);
        $sheet->getHeaderFooter()->setFirstHeader('&L&G&C&"-,Bold"' . "\n\n\n" . $grid->getTitle() . "\n" . $grid->getParameters() . '&RExport date: ' . date('Y-m-d H:i:s') . "\n" . 'User: ' . $user->name);
    }

?>

对于“常规”标题,徽标和文字都在那里,所以一切都OK。对于第一页标题,我有两个问题:

  1. 徽标未显示在第一页标题上(但文字正常)。
  2. 由于居中的标题后面会跟一些文字(用 getParameters 动态加载),我希望第一页标题能够展开以适合它的内容。
  3. 如何使用PHPExcel执行此操作?

1 个答案:

答案 0 :(得分:2)

我没有回答为什么徽标没有显示在第一页标题上,而是伸展高度以适应手动更改页边距所需的内容。

我不确定最好的方法,无论是计算换行符还是什么。但是一旦你知道你有多少行,你就可以这样做:

$headerHeight = ( $imageHeight / 72 ) + ( $headerLineCount * $lineHeight );
$objPHPExcel->getActiveSheet()->getPageMargins()->setHeader( $margin );
$objPHPExcel->getActiveSheet()->getPageMargins()->setTop( $margin + $headerHeight );

**“$ imageHeight / 72”子句只是猜测如何将图像的屏幕高度转换为英寸。