芝麻web文件管理V1.00
编辑当前文件:/home/qrafawbu/store.kwesioben.com/vendor/setasign/fpdi/src/Tcpdf/Fpdi.php
cleanUp(); } /** * Get the next template id. * * @return int */ protected function getNextTemplateId() { return $this->templateId++; } /** * Draws an imported page onto the page or another template. * * Give only one of the size parameters (width, height) to calculate the other one automatically in view to the * aspect ratio. * * @param mixed $tpl The template id * @param float|int|array $x The abscissa of upper-left corner. Alternatively you could use an assoc array * with the keys "x", "y", "width", "height", "adjustPageSize". * @param float|int $y The ordinate of upper-left corner. * @param float|int|null $width The width. * @param float|int|null $height The height. * @param bool $adjustPageSize * @return array The size * @see FpdiTrait::getTemplateSize() */ public function useTemplate($tpl, $x = 0, $y = 0, $width = null, $height = null, $adjustPageSize = false) { return $this->useImportedPage($tpl, $x, $y, $width, $height, $adjustPageSize); } /** * Draws an imported page onto the page. * * Give only one of the size parameters (width, height) to calculate the other one automatically in view to the * aspect ratio. * * @param mixed $pageId The page id * @param float|int|array $x The abscissa of upper-left corner. Alternatively you could use an assoc array * with the keys "x", "y", "width", "height", "adjustPageSize". * @param float|int $y The ordinate of upper-left corner. * @param float|int|null $width The width. * @param float|int|null $height The height. * @param bool $adjustPageSize * @return array The size. * @see Fpdi::getTemplateSize() */ public function useImportedPage($pageId, $x = 0, $y = 0, $width = null, $height = null, $adjustPageSize = false) { $size = $this->fpdiUseImportedPage($pageId, $x, $y, $width, $height, $adjustPageSize); if ($this->inxobj) { $importedPage = $this->importedPages[$pageId]; $this->xobjects[$this->xobjid]['importedPages'][$importedPage['id']] = $pageId; } return $size; } /** * Get the size of an imported page. * * Give only one of the size parameters (width, height) to calculate the other one automatically in view to the * aspect ratio. * * @param mixed $tpl The template id * @param float|int|null $width The width. * @param float|int|null $height The height. * @return array|bool An array with following keys: width, height, 0 (=width), 1 (=height), orientation (L or P) */ public function getTemplateSize($tpl, $width = null, $height = null) { return $this->getImportedPageSize($tpl, $width, $height); } /** * @inheritdoc * @return string */ protected function _getxobjectdict() { $out = parent::_getxobjectdict(); foreach ($this->importedPages as $pageData) { $out .= '/' . $pageData['id'] . ' ' . $pageData['objectNumber'] . ' 0 R '; } return $out; } /** * @inheritdoc * @throws CrossReferenceException * @throws PdfParserException */ protected function _putxobjects() { foreach ($this->importedPages as $key => $pageData) { $this->currentObjectNumber = $this->_newobj(); $this->importedPages[$key]['objectNumber'] = $this->currentObjectNumber; $this->currentReaderId = $pageData['readerId']; $this->writePdfType($pageData['stream']); $this->_put('endobj'); } foreach (\array_keys($this->readers) as $readerId) { $parser = $this->getPdfReader($readerId)->getParser(); $this->currentReaderId = $readerId; while (($objectNumber = \array_pop($this->objectsToCopy[$readerId])) !== null) { try { $object = $parser->getIndirectObject($objectNumber); } catch (CrossReferenceException $e) { if ($e->getCode() === CrossReferenceException::OBJECT_NOT_FOUND) { $object = PdfIndirectObject::create($objectNumber, 0, new PdfNull()); } else { throw $e; } } $this->writePdfType($object); } } // let's prepare resources for imported pages in templates foreach ($this->xobjects as $xObjectId => $data) { if (!isset($data['importedPages'])) { continue; } foreach ($data['importedPages'] as $id => $pageKey) { $page = $this->importedPages[$pageKey]; $this->xobjects[$xObjectId]['xobjects'][$id] = ['n' => $page['objectNumber']]; } } parent::_putxobjects(); $this->currentObjectNumber = null; } /** * Append content to the buffer of TCPDF. * * @param string $s * @param bool $newLine */ protected function _put($s, $newLine = true) { if ($newLine) { $this->setBuffer($s . "\n"); } else { $this->setBuffer($s); } } /** * Begin a new object and return the object number. * * @param int|string $objid Object ID (leave empty to get a new ID). * @return int object number */ protected function _newobj($objid = '') { $this->_out($this->_getobj($objid)); return $this->n; } /** * Writes a PdfType object to the resulting buffer. * * @param PdfType $value * @throws PdfTypeException */ protected function writePdfType(PdfType $value) { if (!$this->encrypted) { $this->fpdiWritePdfType($value); return; } if ($value instanceof PdfString) { $string = PdfString::unescape($value->value); $string = $this->_encrypt_data($this->currentObjectNumber, $string); $value->value = PdfString::escape($string); } elseif ($value instanceof PdfHexString) { $filter = new AsciiHex(); $string = $filter->decode($value->value); $string = $this->_encrypt_data($this->currentObjectNumber, $string); $value->value = $filter->encode($string, true); } elseif ($value instanceof PdfStream) { $stream = $value->getStream(); $stream = $this->_encrypt_data($this->currentObjectNumber, $stream); $dictionary = $value->value; $dictionary->value['Length'] = PdfNumeric::create(\strlen($stream)); $value = PdfStream::create($dictionary, $stream); } elseif ($value instanceof PdfIndirectObject) { /** * @var PdfIndirectObject $value */ $this->currentObjectNumber = $this->objectMap[$this->currentReaderId][$value->objectNumber]; } $this->fpdiWritePdfType($value); } /** * This method will add additional data to the last created link/annotation. * * It will copy styling properties (supported by TCPDF) of the imported link. * * @param array $externalLink * @param float|int $xPt * @param float|int $scaleX * @param float|int $yPt * @param float|int $newHeightPt * @param float|int $scaleY * @param array $importedPage * @return void */ protected function adjustLastLink($externalLink, $xPt, $scaleX, $yPt, $newHeightPt, $scaleY, $importedPage) { $parser = $this->getPdfReader($importedPage['readerId'])->getParser(); if ($this->inxobj) { // store parameters for later use on template $lastAnnotationKey = count($this->xobjects[$this->xobjid]['annotations']) - 1; $lastAnnotationOpt = &$this->xobjects[$this->xobjid]['annotations'][$lastAnnotationKey]['opt']; } else { $lastAnnotationKey = count($this->PageAnnots[$this->page]) - 1; $lastAnnotationOpt = &$this->PageAnnots[$this->page][$lastAnnotationKey]['opt']; } // ensure we have a default value - otherwise TCPDF will set it to 4 throughout $lastAnnotationOpt['f'] = 0; $values = $externalLink['pdfObject']->value; unset( $values['P'], $values['NM'], $values['AP'], $values['AS'], $values['Type'], $values['Subtype'], $values['Rect'], $values['A'], $values['QuadPoints'], $values['Rotate'], $values['M'], $values['StructParent'] ); foreach ($values as $key => $value) { try { switch ($key) { case 'BS': $value = PdfDictionary::ensure($value); $bs = []; if (isset($value->value['W'])) { $bs['w'] = PdfNumeric::ensure(PdfType::resolve($value->value['W'], $parser))->value; } if (isset($value->value['S'])) { $bs['s'] = PdfName::ensure(PdfType::resolve($value->value['S'], $parser))->value; } if (isset($value->value['D'])) { $d = []; foreach (PdfArray::ensure(PdfType::resolve($value->value['D'], $parser))->value as $item) { $d[] = PdfNumeric::ensure(PdfType::resolve($item, $parser))->value; } $bs['d'] = $d; } $lastAnnotationOpt['bs'] = $bs; break; case 'Border': $borderArray = PdfArray::ensure(PdfType::resolve($value, $parser))->value; if (count($borderArray) < 3) { continue 2; } $border = [ PdfNumeric::ensure(PdfType::resolve($borderArray[0], $parser))->value, PdfNumeric::ensure(PdfType::resolve($borderArray[1], $parser))->value, PdfNumeric::ensure(PdfType::resolve($borderArray[2], $parser))->value, ]; if (isset($borderArray[3])) { $dashArray = []; foreach (PdfArray::ensure(PdfType::resolve($borderArray[3], $parser))->value as $item) { $dashArray[] = PdfNumeric::ensure(PdfType::resolve($item, $parser))->value; } $border[] = $dashArray; } $lastAnnotationOpt['border'] = $border; break; case 'C': $c = []; $colors = PdfArray::ensure(PdfType::resolve($value, $parser))->value; $m = count($colors) === 4 ? 100 : 255; foreach ($colors as $item) { $c[] = PdfNumeric::ensure(PdfType::resolve($item, $parser))->value * $m; } $lastAnnotationOpt['c'] = $c; break; case 'F': $lastAnnotationOpt['f'] = $value->value; break; case 'BE': // is broken in current TCPDF version: "bc" key is checked but "bs" is used. break; } // let's silence invalid/not supported values } catch (FpdiException $e) { continue; } } // QuadPoints are not supported by TCPDF // if (count($externalLink['quadPoints']) > 0) { // $quadPoints = []; // for ($i = 0, $n = count($externalLink['quadPoints']); $i < $n; $i += 2) { // $quadPoints[] = $xPt + $externalLink['quadPoints'][$i] * $scaleX; // $quadPoints[] = $this->hPt - $yPt - $newHeightPt + $externalLink['quadPoints'][$i + 1] * $scaleY; // } // // ????? = $quadPoints; // } } }