Bilder werden im Kontext des print-core speziell behandelt. Statt einem base64-Bild oder einem Bildpfad in dem src-Attributes zu definieren, sollte \Brandbox\PrintCore\PrintDocument\Image\Manager::
get populateImage
verwendet werden. Diese Funktion gibt eine URL mit einem Request für das Ausliefern des Bilds zurück. Hintergrund ist, dass in der Webdarstellung Bilder wie .tiff in .png umgewandelt werden müssen und beim Generieren des PDFs die höchste Auflösung ausgeliefert werden sollte.
...
Codeblock | ||||||
---|---|---|---|---|---|---|
| ||||||
use Brandbox\Framework\Base\File; use Brandbox\PrintCore\PrintDocument\Image as PrintDocumentImage; use Brandbox\PrintStyleguide; public function get(Render\Lib\Struct\ScopeElement $scope): PrintStyleguide\Entity\PrintImage { $element = new PrintStyleguide\Entity\PrintImage(); $this->image($element, $scope->settings); return $element; } private function image(PrintStyleguide\Entity\PrintImage $element, array $settings): void { $file = $this->getFile($settings['image']); $image =if $this($file->getImage>exists($file); if ('' !== $image) { $element->settings['src'] = $image; } } private function getImage(File\lib\entity\mamFile $file): string { return $this $this ->staticController(PrintDocumentImage\Manager::class) ->get($file) ->populateImage($element, $file, []) ; ;} } private function getFile(string $path): File\lib\entity\mamFile { return $this ->staticController(File\Manager::class) ->findByPath($path, true) ; } |
...