90 lines
3.2 KiB
PHP
90 lines
3.2 KiB
PHP
<?php
|
|
|
|
/**
|
|
* PHPExcel_Writer_PDF
|
|
*
|
|
* Copyright (c) 2006 - 2015 PHPExcel
|
|
*
|
|
* This library is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
* License as published by the Free Software Foundation; either
|
|
* version 2.1 of the License, or (at your option) any later version.
|
|
*
|
|
* This library is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
* Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
* License along with this library; if not, write to the Free Software
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
|
*
|
|
* @category PHPExcel
|
|
* @package PHPExcel_Writer_PDF
|
|
* @copyright Copyright (c) 2006 - 2015 PHPExcel (http://www.codeplex.com/PHPExcel)
|
|
* @license http://www.gnu.org/licenses/old-licenses/lgpl-2.1.txt LGPL
|
|
* @version ##VERSION##, ##DATE##
|
|
*/
|
|
class PHPExcel_Writer_PDF implements PHPExcel_Writer_IWriter
|
|
{
|
|
|
|
/**
|
|
* The wrapper for the requested PDF rendering engine
|
|
*
|
|
* @var PHPExcel_Writer_PDF_Core
|
|
*/
|
|
private $renderer = null;
|
|
|
|
/**
|
|
* Instantiate a new renderer of the configured type within this container class
|
|
*
|
|
* @param PHPExcel $phpExcel PHPExcel object
|
|
* @throws PHPExcel_Writer_Exception when PDF library is not configured
|
|
*/
|
|
public function __construct(PHPExcel $phpExcel)
|
|
{
|
|
$pdfLibraryName = PHPExcel_Settings::getPdfRendererName();
|
|
if (is_null($pdfLibraryName)) {
|
|
throw new PHPExcel_Writer_Exception("PDF Rendering library has not been defined.");
|
|
}
|
|
|
|
$pdfLibraryPath = PHPExcel_Settings::getPdfRendererPath();
|
|
if (is_null($pdfLibraryName)) {
|
|
throw new PHPExcel_Writer_Exception("PDF Rendering library path has not been defined.");
|
|
}
|
|
$includePath = str_replace('\\', '/', get_include_path());
|
|
$rendererPath = str_replace('\\', '/', $pdfLibraryPath);
|
|
if (strpos($rendererPath, $includePath) === false) {
|
|
set_include_path(get_include_path() . PATH_SEPARATOR . $pdfLibraryPath);
|
|
}
|
|
|
|
$rendererName = 'PHPExcel_Writer_PDF_' . $pdfLibraryName;
|
|
$this->renderer = new $rendererName($phpExcel);
|
|
}
|
|
|
|
|
|
/**
|
|
* Magic method to handle direct calls to the configured PDF renderer wrapper class.
|
|
*
|
|
* @param string $name Renderer library method name
|
|
* @param mixed[] $arguments Array of arguments to pass to the renderer method
|
|
* @return mixed Returned data from the PDF renderer wrapper method
|
|
*/
|
|
public function __call($name, $arguments)
|
|
{
|
|
if ($this->renderer === null) {
|
|
throw new PHPExcel_Writer_Exception("PDF Rendering library has not been defined.");
|
|
}
|
|
|
|
return call_user_func_array(array($this->renderer, $name), $arguments);
|
|
}
|
|
|
|
/**
|
|
* {@inheritdoc}
|
|
*/
|
|
public function save($pFilename = null)
|
|
{
|
|
$this->renderer->save($pFilename);
|
|
}
|
|
}
|