/library/Zend/Barcode/Renderer/Pdf.php
https://github.com/Exercise/zf2 · PHP · 244 lines · 131 code · 22 blank · 91 comment · 15 complexity · 20a1c6b2bc0eaad1f0d8490fa3de0506 MD5 · raw file
- <?php
- /**
- * Zend Framework
- *
- * LICENSE
- *
- * This source file is subject to the new BSD license that is bundled
- * with this package in the file LICENSE.txt.
- * It is also available through the world-wide-web at this URL:
- * http://framework.zend.com/license/new-bsd
- * If you did not receive a copy of the license and are unable to
- * obtain it through the world-wide-web, please send an email
- * to license@zend.com so we can send you a copy immediately.
- *
- * @category Zend
- * @package Zend_Barcode
- * @subpackage Renderer
- * @copyright Copyright (c) 2005-2010 Zend Technologies USA Inc. (http://www.zend.com)
- * @license http://framework.zend.com/license/new-bsd New BSD License
- * @version $Id$
- */
- /**
- * @namespace
- */
- namespace Zend\Barcode\Renderer;
- use Zend\Pdf\Color,
- Zend\Pdf\PdfDocument,
- Zend\Pdf\Page,
- Zend\Pdf\Font,
- Zend;
- /**
- * Class for rendering the barcode in PDF resource
- *
- * @uses \Zend\Barcode\Renderer\Exception
- * @uses \Zend\Barcode\Renderer\AbstractRenderer
- * @uses \Zend\Pdf\PdfDocument
- * @uses \Zend\Pdf\Page
- * @uses \Zend\Pdf\Color\Rgb
- * @category Zend
- * @package Zend_Barcode
- * @copyright Copyright (c) 2005-2010 Zend Technologies USA Inc. (http://www.zend.com)
- * @license http://framework.zend.com/license/new-bsd New BSD License
- */
- class Pdf extends AbstractRenderer
- {
- /**
- * PDF resource
- * @var \Zend\Pdf\PdfDocument
- */
- protected $_resource = null;
- /**
- * Page number in PDF resource
- * @var integer
- */
- protected $_page = 0;
- /**
- * Module size rendering
- * @var float
- */
- protected $_moduleSize = 0.5;
- /**
- * Set an image resource to draw the barcode inside
- * @param resource $value
- * @return \Zend\Barcode\Renderer
- * @throw \Zend\Barcode\Renderer\Exception
- */
- public function setResource($pdf, $page = 0)
- {
- if (!$pdf instanceof PdfDocument) {
- throw new Exception(
- 'Invalid \Zend\Pdf\PdfDocument resource provided to setResource()'
- );
- }
- $this->_resource = $pdf;
- $this->_page = intval($page);
- if (!count($this->_resource->pages)) {
- $this->_page = 0;
- $this->_resource->pages[] = new Page(
- Zend\Pdf\Page::SIZE_A4
- );
- }
- return $this;
- }
- /**
- * Check renderer parameters
- *
- * @return void
- */
- protected function _checkParams()
- {
- }
- /**
- * Draw the barcode in the PDF, send headers and the PDF
- * @return mixed
- */
- public function render()
- {
- $this->draw();
- header("Content-Type: application/pdf");
- echo $this->_resource->render();
- }
- /**
- * Initialize the PDF resource
- * @return void
- */
- protected function _initRenderer()
- {
- if ($this->_resource === null) {
- $this->_resource = new PdfDocument();
- $this->_resource->pages[] = new Page(
- Page::SIZE_A4
- );
- }
- $pdfPage = $this->_resource->pages[$this->_page];
- $this->_adjustPosition($pdfPage->getHeight(), $pdfPage->getWidth());
- }
- /**
- * Draw a polygon in the rendering resource
- * @param array $points
- * @param integer $color
- * @param boolean $filled
- */
- protected function _drawPolygon($points, $color, $filled = true)
- {
- $page = $this->_resource->pages[$this->_page];
- foreach ($points as $point) {
- $x[] = $point[0] * $this->_moduleSize + $this->_leftOffset;
- $y[] = $page->getHeight() - $point[1] * $this->_moduleSize - $this->_topOffset;
- }
- if (count($y) == 4) {
- if ($x[0] != $x[3] && $y[0] == $y[3]) {
- $y[0] -= ($this->_moduleSize / 2);
- $y[3] -= ($this->_moduleSize / 2);
- }
- if ($x[1] != $x[2] && $y[1] == $y[2]) {
- $y[1] += ($this->_moduleSize / 2);
- $y[2] += ($this->_moduleSize / 2);
- }
- }
- $color = new Color\Rgb(
- (($color & 0xFF0000) >> 16) / 255.0,
- (($color & 0x00FF00) >> 8) / 255.0,
- ($color & 0x0000FF) / 255.0
- );
- $page->setLineColor($color);
- $page->setFillColor($color);
- $page->setLineWidth($this->_moduleSize);
- $fillType = ($filled)
- ? Page::SHAPE_DRAW_FILL_AND_STROKE
- : Page::SHAPE_DRAW_STROKE;
- $page->drawPolygon($x, $y, $fillType);
- }
- /**
- * Draw a polygon in the rendering resource
- * @param string $text
- * @param float $size
- * @param array $position
- * @param string $font
- * @param integer $color
- * @param string $alignment
- * @param float $orientation
- */
- protected function _drawText(
- $text,
- $size,
- $position,
- $font,
- $color,
- $alignment = 'center',
- $orientation = 0
- ) {
- $page = $this->_resource->pages[$this->_page];
- $color = new Color\Rgb(
- (($color & 0xFF0000) >> 16) / 255.0,
- (($color & 0x00FF00) >> 8) / 255.0,
- ($color & 0x0000FF) / 255.0
- );
- $page->setLineColor($color);
- $page->setFillColor($color);
- $page->setFont(Font::fontWithPath($font), $size * $this->_moduleSize * 1.2);
- $width = $this->widthForStringUsingFontSize(
- $text,
- Font::fontWithPath($font),
- $size * $this->_moduleSize
- );
- $angle = pi() * $orientation / 180;
- $left = $position[0] * $this->_moduleSize + $this->_leftOffset;
- $top = $page->getHeight() - $position[1] * $this->_moduleSize - $this->_topOffset;
- switch ($alignment) {
- case 'center':
- $left -= ($width / 2) * cos($angle);
- $top -= ($width / 2) * sin($angle);
- break;
- case 'right':
- $left -= $width;
- break;
- }
- $page->rotate($left, $top, $angle);
- $page->drawText($text, $left, $top);
- $page->rotate($left, $top, - $angle);
- }
- /**
- * Calculate the width of a string:
- * in case of using alignment parameter in drawText
- * @param string $text
- * @param \Zend\Pdf\Font $font
- * @param float $fontSize
- * @return float
- */
- public function widthForStringUsingFontSize($text, $font, $fontSize)
- {
- $drawingString = iconv('UTF-8', 'UTF-16BE//IGNORE', $text);
- $characters = array();
- for ($i = 0; $i < strlen($drawingString); $i ++) {
- $characters[] = (ord($drawingString[$i ++]) << 8) | ord($drawingString[$i]);
- }
- $glyphs = $font->glyphNumbersForCharacters($characters);
- $widths = $font->widthsForGlyphs($glyphs);
- $stringWidth = (array_sum($widths) / $font->getUnitsPerEm()) * $fontSize;
- return $stringWidth;
- }
- }