Classe : générateur de miniature stricte optimisé

Soyez le premier à donner votre avis sur cette source.

Vue 4 561 fois - Téléchargée 308 fois

Description

Bonjour,

Une classe qui permet de générer une miniature (à partir d'un formulaire d'envoi) avec des dimensions strictes sans déformer l'image, et en découpant le minimum possible.

Elle (la classe) va essayer de comprendre ce qu'il y a en trop pour pouvoir prendre les dimensions voulues, et tenter de découper un minimum de chaque coté. (que ce soit en hauteur ou largeur).

Vous avez accès à ces paramètres :

Changer la hauteur de la miniature, Changer la largeur, Changer le chemin.

La classe propose aussi :

De générer un nom unique à la miniature (si cette fonction n'est pas appelée elle prendra le même nom que l'originale, si elle existe déjà dans le dossier de destination elle prendra le nom suivi d'un chiffre (0, +1... +n).

Dans la source à télécharger, vous avez aussi un fichier d'exemple comment utiliser la classe.

Source / Exemple :


<?php

/*

  • CGemini - Générateur de miniature - Thumbnail generator
  • @author : François Bouly
  • @date : 10/01/09
  • @Utilisation:
  • Démarrer l'instance :
  • $image = new CGemini($_FILES['string']); // Remplacer 'string' par le nom de l'input-file de votre formulaire.
  • Paramètres facultatifs :
  • $image->setLmaxi(int); (largeur de l'image);
  • $image->setHmaxi(int); (hauteur de l'image);
  • $image->setIPath('string/'); (dossier de l'image suivi de /)
  • $image->geneName(); (va générer un nom de fichier unique, sinon il utilise le nom du fichier tel qu'envoyé);
  • Génération de la miniature :
  • $image->geneMini();
  • Amusez-vous bien !
  • /
class CGemini { // Données membre private $image = array(); private $itemp; private $lfile; private $hfile; private $tfile; // Données paramètres private $lmaxi = '100'; private $hmaxi = '100'; private $ipath = 'images/'; private $iname = 'defaut'; // Données objet private $lrati; private $hrati; // Modifieurs public function setLmaxi($var) {$this->lmaxi = $var;} public function setHmaxi($var) {$this->hmaxi = $var;} public function setIpath($var) {$this->ipath = $var;} // Constructeur public function __construct($filevar) { if (getimagesize($filevar['tmp_name']) != false) { $infos = getimagesize($filevar['tmp_name']); switch($infos[2]) { case 1: $this->tfile = 'gif'; $this->image = imagecreatefromgif($filevar['tmp_name']); break; case 2: $this->tfile = 'jpg'; $this->image = imagecreatefromjpeg($filevar['tmp_name']); break; case 3: $this->tfile = 'png'; $this->image = imagecreatefrompng($filevar['tmp_name']); break; default: unlink($this->itemp); exit('Ce type d\'image n\'est pas supporté.'); } $this->itemp = $filevar['tmp_name']; $this->lfile = $infos[0]; $this->hfile = $infos[1]; $this->iname = $filevar['name']; } } // Méthodes principales public function geneMini() { // Calcul $lratio = $this->lfile/$this->lmaxi; $hratio = $this->hfile/$this->hmaxi; $fratio = min($lratio,$hratio); $lratio = $this->lfile/$fratio; $hratio = $this->hfile/$fratio; $l = $this->lmaxi - $lratio; $h = $this->hmaxi - $hratio; $border = max($l,$h); $srcX = 0; $srcY = 0; if ($border == $l && $border != 0) $srcX = $border/2; if ($border == $h && $border != 0) $srcY = $border/2; // Modification de l'image $tempim = imagecreatetruecolor($this->lmaxi,$this->hmaxi); imagecopyresampled($tempim, $this->image, 0, 0, $srcX, $srcY, $lratio, $hratio, $this->lfile, $this->hfile); $this->image = $tempim; // Verification de la disponibilité du nom $fonly = substr($this->iname, 0, -4); for ($i=0; file_exists($this->ipath . $this->iname); $i++) { $this->iname = $fonly; $this->iname .= $i .'.'; $this->iname .= $this->tfile; } // Copie de l'image switch ($this->tfile) { case 'gif': imagegif($this->image,$this->ipath .'/'. $this->iname); break; case 'jpg': imagejpeg($this->image,$this->ipath .'/'. $this->iname); break; case 'png': imagepng($this->image,$this->ipath .'/'. $this->iname); break; } unlink($this->itemp); return $this->iname; } public function geneName() { $uniqid = uniqid(rand(), true); $this->iname = $uniqid .'.'. $this->tfile; } } ?>

Conclusion :


N'hésitez pas à laisser un commentaire pour proposer une feature manquante.

Amusez-vous bien !

Codes Sources

A voir également

Ajouter un commentaire

Commentaires

GauldoMagique
Messages postés
8
Date d'inscription
lundi 15 décembre 2008
Statut
Membre
Dernière intervention
12 janvier 2009
-
Ok effectivement dans mon ancienne fonction, c'est bien un min() que j'ai... Je ne sais plus pourquoi j'avais modifier ceci. Merci.

En effet, ce que je trouve intéressant de phpcs, c'est de pouvoir faire évoluer des scripts par les commentaires... Moi des idées j'en ai trop et pas assez, c'est bordélique dans ma tête ; ce que j'aime c'est trouver des solutions à des problèmes, et non pas trouver des problèmes ^^

Merci beaucoup.
MangaII
Messages postés
129
Date d'inscription
dimanche 9 décembre 2001
Statut
Membre
Dernière intervention
12 janvier 2009
-
Ton problème de centrage viens de là :
$border = max($l,$h);
l'une des 2 valeurs est forcément = 0
L'autre est forcément négative (puisque tu croppe sur le plus petit coté, l'autre est donc plus grand et $this->hmaxi - $hratio; doit donner un résultat négatif).

Hors tu cherche le max des 2 ... mais un négatif est toujours plus petit que 0. Ce qui fait que c'est toujours 0 qui sort pour le border. Donc pas le bon coté !

Met un min à la place du max (tu aura un border négatif) et border/2 correspondra bien au décalage négatif pour déplacer l'image.

Je vois que mes suggestions t'on inspiré ...
GauldoMagique
Messages postés
8
Date d'inscription
lundi 15 décembre 2008
Statut
Membre
Dernière intervention
12 janvier 2009
-
Merci pour ce commentaire constructif. En réalité, j'ai fait cette classe pour les besoins d'un projet, donc c'était bien destiné à prendre le tableaux Files. Je note donc l'intérêt de faire évoluer cette classe, afin de prendre de nouveaux paramètres et donc... se rendre plus utile.

Je précise que l'image doit être centrée (d'où $srcX et $srcY, selon ce qui dépasse, la variable prendra la valeur bordure/2.) Il est possible que lors de la réecriture (à la base une fonction) j'ai fait une erreur à ce niveau.

Il me semble aussi pouvoir choisir le nom de la photo via $this->iname('$nom'); mais je n'ai pas testé. A voir.

Donc je compte travailler prochainement sur :

-Prendre autre chose qu'un tableau Files. Une méthode indépendante (optionnelle) sera rajoutée pour supporter les tableaux files.

-Le choix si on 'crop' ou pas, dans le cas négatif, si on force à la bonne taille et dans ce cas, choisir la couleur de fond.

-Choisir l'extension du fichier ainsi que des paramètres supplémentaires sur le format choisi.

-Le choix si on supprime l'image où non.

Quant à la dernière suggestion, je tiens à la clareté du code, et la ligne je la trouvais beaucoup trop longue...

Merci pour ces précieux conseils et ces encouragements.

N'hésitez pas à faire de nouvelles propositions !
MangaII
Messages postés
129
Date d'inscription
dimanche 9 décembre 2001
Statut
Membre
Dernière intervention
12 janvier 2009
-
Salut !

Plutot sympa
Dans ton source, dans le form, le nom du fichier n'est pas le bon (testmini au lieu de miniform)
Petit bug ? l'image est toujours coupées en bas ou à droite. Essaye de centrer l'image !

Le code est clair et simple.
Quelques suggestions, pour pouvoir le réutiliser :
- passe en paramêtre directement le nom du fichier source (et pas le tableau file). On ne redimensionne pas toujours une image uploadée.
- A priori, tu croppe toujours l'image. Mais il peut être intéressant au contraire de la réduire plus pour qu'elle rentre en entier. Via un paramêtre on peut demander à cropper ou pas. Ca amène quelques soucis supplémentaire : est-ce qu'on redimensionne la sortie (pour s'adapter aux proportions de l'image) ou est-ce qu'on force aux dimensions demandées. Et si on force les dimensions, il faut définir la couleur du fond (pour les bords).
- Un petit détail, tu supprime toujours l'image source. C'est vrai que pour un fichier uploadé, c'est mieux. Néanmoins, si tu l'utilise sur autre chose comme image, c'est dommage de supprimer l'original !
- Pour l'enregistrement du devrai mettre en paramêtre le format choisi (et le taux de compression pour le jpg) !
- Idem, dans la fonction geneMimi tu pourrais passer le nom désiré pour le fichier (optionnel). Ca permettrai de donner un nom précis (ex : identifiant de base de donnée)

Seul truc ... (test de disponibilité du nom ) 1 seule ligne, et évite les accolades :
$this->iname = $fonly.$i.'.'.$this->tfile;

Continue comme ça !

Vous n'êtes pas encore membre ?

inscrivez-vous, c'est gratuit et ça prend moins d'une minute !

Les membres obtiennent plus de réponses que les utilisateurs anonymes.

Le fait d'être membre vous permet d'avoir un suivi détaillé de vos demandes et codes sources.

Le fait d'être membre vous permet d'avoir des options supplémentaires.

Du même auteur (GauldoMagique)