NAME

Quiq::PhotoStorage - Foto-Speicher

BASE CLASS

Quiq::Hash

DESCRIPTION

Ein Objekt der Klasse repräsentiert einen Speicher für Fotos. Der Speicher besitzt folgende Eigenschaften:

  • Der Name der Foto-Datei bleibt als Bestandteil erhalten (nach Anwendung von: s/[^-_a-zA-Z0-9]/_/g)

  • Jedes Foto erhält eine fortlaufende, eindeutige Zahl als Präfix

  • Es wird der SHA1-Hash der Datei gebildet und gespeichert

  • Jede Datei wird nur einmal gespeichert, d.h. Dubletten werden zurückgewiesen

  • Andere Bildformate als JPEG werden nach JPEG konvertiert

METHODS

Klassenmethoden

new() - Konstruktor

Synopsis

$pst = $class->new($dir);

Description

Öffne den Fotospeicher in Verzeichnis $dir.

Das Verzeichnis hat den Aufbau:

$dir/pic/<NNNNNNN>-<NAME>.jpg  # Verzeichnis mit den Bildern
     cnt.txt                   # Stand der Nummer NNNNNNN
     sha1.hash                 # die SHA1-Hashes der Bilddateien

Objektmethoden

add() - Füge Fotodatei zum Speicher hinzu

Synopsis

$path = $pst->add($file,@opt);

Arguments

$file

Pfad der Fotodatei.

Options

-removeName = $bool (Default: 0)

Entferne den urprünglichen Dateinamen. Wenn nicht gesetzt, wird der ursprüngliche Dateiname (in Kleinschreibung und ohne "Sonderzeichen") mit "-" getrennt an den Zähler angefügt.

Returns

(String) Pfad der Datei im Speicher.

Description

Füge Fotodatei $file zum Speicher hinzu und liefere den Pfad der Datei im Speicher zurück.

addAllByTime() - Füge Fotodateien zum Fotospeicher hinzu

Synopsis

@paths = $pst->addAllByTime(@files,@opt);

Arguments

$file

Pfad der Fotodatei.

Options

-removeName = $bool (Default: 0)

Entferne den urprünglichen Dateinamen. Wenn nicht gesetzt, wird der ursprüngliche Dateiname (in Kleinschreibung und ohne "Sonderzeichen") mit "-" getrennt an den Zähler angefügt.

Returns

(Array of Strings) Liste der Pfade der Dateien im Speicher.

Description

Füge die Fotodateien @files in der Reihenfolge ihrer mtime zum Speicher hinzu und liefere die Pfade der Dateien im Speicher zurück.

VERSION

1.223

AUTHOR

Frank Seitz, http://fseitz.de/

COPYRIGHT

Copyright (C) 2024 Frank Seitz

LICENSE

This code is free software; you can redistribute it and/or modify it under the same terms as Perl itself.