kurze Frage zum Image Manager, ich bin auf der Suche nache einer Möglichkeit die Breite und Höhe eines generierten Bildes über den Image Manager abzufragen, ohne dass Bild dabei zu generieren.
EDIT:
Hab's gelöst (manchmal sollte man einfach noch etwas ausprobieren, bevor man sich im Forum bloss stellt
Anyway, hab's nun so hinbekommen, keine Ahnung wieso's erst auf diesem Weg nicht geklappt hatte:
Code: Alles auswählen
$cachePath = $REX['GENERATED_PATH'] . '/files/' . 'image_manager__' . $typ . '_' . $img;
if(file_exists($cachePath)) {
$size = getimagesize( $cachePath );
} else {
$reximage = rex_image_manager::getImageCache($img, $type);
$size[0] = $reximage->getWidth();
$size[1] = $reximage->getHeight();
}
print_r($size);
Danke trotzdem
------
Ursprüngliche Frage:
Momentan mache ich das ungefähr so (wie im Redaxo Wiki beschrieben):
Code: Alles auswählen
$reximage = rex_image_manager::getImageCache($bild, $typ);
echo $reximage->getWidth() . " x " . $reximage->getHeight();
Sprich, gibt es eine Möglichkeit aus dem Frontend die grösse eines gecachten Bildes zu ermitteln und, falls dieses noch nicht gecached wurde, dieses zu cachen? Als Alternative würde es reichen, wenn ich die im Image Manager eingestellte Grösse über die Angabe des Typs ermitteln könnte. Ich kann mir diese MySQL Abfrage zwar selber schreiben, aber falls die Funktion bereits vorhanden ist, muss ich das nicht neu erfinden.
Ich hab auch schon versucht mir die Infos per getimagesize zu holen, aber aus dem Frontend hab ich scheinbar keinen Zugriff auf den generated Ordner. Jedenfalls hab ich das bis jetzt nicht hingekriegt (hab jetzt aber auch nicht etliche Stunden damit verplempert).
Hintergrund: ich baue z.Z. eine responsive Website wo, je nach Bildschirmgrösse, andere Bildtypen geladen werden. Das Ganze funktioniert per Media Queries bzw. window.matchmedia (sofern vorhanden), die Bilder werden also per JavaScript geladen, falls/wenn sie im Viewport ersichtlich sind (lazy load). Dazu muss ich vorab wissen wie gross die Bilder sind, zum Beispiel um das Seitenverhältnis zu berechnen.
Anfangs wollte ich mit srcset bzw. dem picture Element arbeiten, aber ich bin zum Schluss gekommen das die Umsetzung in Zusammenhang mit dem Image-Manager zu kompliziert ist (evtl. war das aber eine etwas voreilige Schlussfolgerung).