Versionen im Vergleich

Schlüssel

  • Diese Zeile wurde hinzugefügt.
  • Diese Zeile wurde entfernt.
  • Formatierung wurde geändert.

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 pngs .png umgewandelt werden müssen und beim Generieren des PDFs die höchste Auflösung ausgeliefert werden sollte.

Es gibt drei verschieden Fälle:

  • Web → Das Bild wird für das Web konvertiert. Statt .tiff-Dateien werden zum Beispiel .png-Dateien ausgeliefert.

  • Puppeteer → Es wird nur ein transparentes Platzhalter-Bild mit der angefragten Größe ausgeliefert

  • PdfReactor → Es wird das Bild im Originalformat in der angefragten Größe ausgeliefert

Codeblock
languagephp
themeRDark
use Brandbox\Framework\Base\File;
use Brandbox\Framework\Base\Image as BaseImage;
use Brandbox\PrintCore\PrintDocument\Image as PrintDocumentImage;
use Brandbox\PrintLayoutStandard\View\PrintImage;
use Brandbox\PrintStyleguide;

privatepublic function imageget(PrintStyleguide\Entity\PrintImage $element, PrintImage\Render\Lib\EntityStruct\PrintViewImageScopeElement $source$scope): voidPrintStyleguide\Entity\PrintImage
{
    $file$element = $this->getFile($source->image);
    $attributes = $this->getImageAttributes($file, $sourcenew PrintStyleguide\Entity\PrintImage();
    $image = $this->getImage>image($file, $source);

    if ('' !== $image) {
        $element->settings['src'] = $image;
        $element->settings['width'] = $attributes->getWidth($element, $scope->settings);

    return   $element->settings['height'] = $attributes->getHeight();
    }
}

private function getImageimage(FilePrintStyleguide\libEntity\entity\mamFilePrintImage $file$element, PrintImage\Lib\Entity\PrintViewImage $sourcearray $settings): stringvoid
{    
	$file $image = new PrintDocumentImage\Lib\Struct\ImageRequest($this->getFile($settings['image']);

   $image->file =if ($file;
    $image->width = $source->width;
    $image->height = $source->height;
    $image->crop = $source->crop;->exists()) {
       return $this
        			->staticController(PrintDocumentImage\Manager::class)
			->populateImage($element,        ->get($image)
$file, [])
		;
    ;}
}

private function getFile(string $path): File\lib\entity\mamFile
{
    return $this
        ->staticController(File\Manager::class)
        ->findByPath($path, true)
    ;
}

private function getImageAttributes(File\lib\entity\mamFile $file, PrintImage\Lib\Entity\PrintViewImage $source): BaseImage\Lib\Struct\ImageAttributes
{
    $params = [];
    if ($source->crop) {
        $params['crop'] = $source->crop;
    }

    $attributes = $this
  
     ->staticController(File\Manager::class)
        ->imageAttributes($file, $source->width, $source->height, $params)
    ;

    $source->width = $attributes->getWidth();
    $source->height = $attributes->getHeight();

    return $attributes;
}