Accueil > > > GÉNÉRATION AUTOMATIQUE DE BOUTON
GÉNÉRATION AUTOMATIQUE DE BOUTON
Information sur la source
Description
Voici une petite classe qui génère automatiquement des boutons (image au format png) avec un motif et un texte. Le bouton est créé selon les contraintes graphiques pré-établies c'est à dire les 2 extrémités gauche et droite et un fond en png. Un schéma explique mieux que des mots : http://www.franquito.net/tutos/bouton.php C'est un classe qui peut s'avérer trés utile quand vous développez un site du style e-commerce et que vous avez la flemme de faire une 20aine de boutons à la main. Du reste, si votre site à plusieurs themes, c'est autant de temps de gagner !
Source
- <?php
- # //
- # // Boutons (juin 2006)
- # // Franck Maurin
- # // from Franquito.net
- # // http://www.franquito.net/tutos/bouton.php
- # //
- Class Bouton
- {
- var $dessin;
- var $alt;
- var $hauteur;
- var $largeur;
- var $nom;
-
- function Bouton($dessin, $alt)
- {
- $rep = "img/btn/"; //repertoire ou se trouve les boutons
-
- $this->dessin = $dessin;
- $this->alt = $alt;
- $this->nom = $rep.'btn_'.substr($this->dessin, 0, 3).'_'.$this->formater($this->alt).'.png';
-
- if(is_file($this->nom)) // Si le bouton existe déja, on renvoie les dimensions
- {
- $taille=getimagesize($this->nom);
- $this->largeur = $taille[0];
- $this->hauteur = $taille[1];
- }
- else // Sinon on va le créer
- {
- // Utilisation des ressources graphiques
- $fond=$rep.'fond.png';
- $taille_fond=getimagesize($fond);
- $img_fond = ImageCreateFromPng ($fond);
-
- $gauche=$rep.'gauche.png';
- $taille_gauche=getimagesize($gauche);
- $img_gauche = ImageCreateFromPng ($gauche);
-
- $droite=$rep.'droite.png';
- $taille_droite=getimagesize($droite);
- $img_droite = ImageCreateFromPng ($droite);
-
- $motif=$rep.''.$this->dessin.'.png';
- $taille_motif=getimagesize($motif);
- $img_motif = ImageCreateFromPng ($motif);
-
- // Paramêtres du bouton
- $this->hauteur = $taille_fond[1];
- $this->largeur = $taille_gauche[0] + $taille_motif[0] + (strlen($this->alt)+1)*imagefontwidth(3) + $taille_droite[0];
-
- // Création de l'image vierge
- $img = imageCreate($this->largeur,$this->hauteur);
- $couleur = ImageColorAllocate ($img, 100, 100, 100);
-
- // Elémente graphiques du bouton
- @imageCopyMerge($img, $img_fond, 0, 0, 0, 0, $this->largeur, $this->hauteur, 100);
- @imageCopyMerge($img, $img_gauche, 0, 0, 0, 0, $taille_gauche[0], $taille_gauche[1], 100);
- @imageCopyMerge($img, $img_droite, $this->largeur-$taille_droite[0], 0, 0, 0, $taille_droite[0], $taille_droite[1], 100);
- @imageCopyMerge($img, $img_motif, $taille_gauche[0], ($this->hauteur-$taille_motif[1])/2, 0, 0, $taille_motif[0], $taille_motif[1], 100);
-
- // Texte
- imageString($img,3,$taille_gauche[0]+$taille_motif[0],($this->hauteur-imagefontheight(3))/2,' '.stripslashes(trim($this->alt)),$couleur);
-
- //Création du bouton de type btn_[motif]_[alt].png
- Imagepng ($img,$this->nom);
- }
- }
-
- function formater($txt)
- {
- $a = "àáâãäåòóôõöøèéêëçìíîïùúûüÿñ@!?.:/ ";
- $b = "aaaaaaooooooeeeeciiiiuuuuyn_______";
- return (strtolower(strtr($txt, $a, $b)));
- }
- }
-
- ?>
<?php
# //
# // Boutons (juin 2006)
# // Franck Maurin
# // from Franquito.net
# // http://www.franquito.net/tutos/bouton.php
# //
Class Bouton
{
var $dessin;
var $alt;
var $hauteur;
var $largeur;
var $nom;
function Bouton($dessin, $alt)
{
$rep = "img/btn/"; //repertoire ou se trouve les boutons
$this->dessin = $dessin;
$this->alt = $alt;
$this->nom = $rep.'btn_'.substr($this->dessin, 0, 3).'_'.$this->formater($this->alt).'.png';
if(is_file($this->nom)) // Si le bouton existe déja, on renvoie les dimensions
{
$taille=getimagesize($this->nom);
$this->largeur = $taille[0];
$this->hauteur = $taille[1];
}
else // Sinon on va le créer
{
// Utilisation des ressources graphiques
$fond=$rep.'fond.png';
$taille_fond=getimagesize($fond);
$img_fond = ImageCreateFromPng ($fond);
$gauche=$rep.'gauche.png';
$taille_gauche=getimagesize($gauche);
$img_gauche = ImageCreateFromPng ($gauche);
$droite=$rep.'droite.png';
$taille_droite=getimagesize($droite);
$img_droite = ImageCreateFromPng ($droite);
$motif=$rep.''.$this->dessin.'.png';
$taille_motif=getimagesize($motif);
$img_motif = ImageCreateFromPng ($motif);
// Paramêtres du bouton
$this->hauteur = $taille_fond[1];
$this->largeur = $taille_gauche[0] + $taille_motif[0] + (strlen($this->alt)+1)*imagefontwidth(3) + $taille_droite[0];
// Création de l'image vierge
$img = imageCreate($this->largeur,$this->hauteur);
$couleur = ImageColorAllocate ($img, 100, 100, 100);
// Elémente graphiques du bouton
@imageCopyMerge($img, $img_fond, 0, 0, 0, 0, $this->largeur, $this->hauteur, 100);
@imageCopyMerge($img, $img_gauche, 0, 0, 0, 0, $taille_gauche[0], $taille_gauche[1], 100);
@imageCopyMerge($img, $img_droite, $this->largeur-$taille_droite[0], 0, 0, 0, $taille_droite[0], $taille_droite[1], 100);
@imageCopyMerge($img, $img_motif, $taille_gauche[0], ($this->hauteur-$taille_motif[1])/2, 0, 0, $taille_motif[0], $taille_motif[1], 100);
// Texte
imageString($img,3,$taille_gauche[0]+$taille_motif[0],($this->hauteur-imagefontheight(3))/2,' '.stripslashes(trim($this->alt)),$couleur);
//Création du bouton de type btn_[motif]_[alt].png
Imagepng ($img,$this->nom);
}
}
function formater($txt)
{
$a = "àáâãäåòóôõöøèéêëçìíîïùúûüÿñ@!?.:/ ";
$b = "aaaaaaooooooeeeeciiiiuuuuyn_______";
return (strtolower(strtr($txt, $a, $b)));
}
}
?>
Conclusion
Exemple d'utilisation :
include('classes/bouton.classe.php'); $bouton = new Bouton($dessin,$texte); echo '<img src="'.$bouton->nom.'" height="'.$bouton->hauteur.'" width="'.$bouton->largeur.'" alt="'.$bouton->alt.'" />';
Démo visible : http://www.franquito.net/tutos/bouton.php
Ce sont mes débuts en POO avec php, donc n'hésitez pas à critiquer ma classe, cela ne peut que me faire progresser !
Historique
- 01 juin 2006 17:21:29 :
- Ajout du .zip
- 02 juin 2006 02:47:56 :
- Quelques modifications suites aux remarques de Wizard512 :
Création d'un motif "enveloppe" et ajout des éléments @ : / et . dans le masque pour permettre le nommage du bouton.
Enfin, pour ne pas surcharger le serveur, j'ai ajouter un test qui vérifie si l'image existe déja ou non. Cela dit, comme les élements comme @ . ? ! : et ' ' sont traduit pas le meme élément ('_') il se peut que si vous demander le bouton "Des question !" vous ayez le bouton "Des questions ?" ! De même pour les accents, donc il faut veiller à ce que l'orthographe soit le bon dés le début :p
Si vous utiliser cette classe en local, ou que les ressources serveur ne vous effraie pas, supprimer tout simplement cette condition if(is_file())
Sources de la même categorie
Commentaires et avis
Discussions en rapport avec ce code source dans le forum
générer des miniatures avec gd 1.6 [ par vegetaline ]
muhaha alors là c'est rigolo, un super défi pour les programmeurs fous!ok j'ai le code pour générer des miniatures grâce au php, mais ça marche qu'ave
Pb de boutons ;) [ par Philenain1 ]
Lut a tous ,bon ben voila je suis en train de me faire un forum et j'utilise des images comme des boutons grace à:onClick=\"javascript:location.href='
[BLOB->GD] Redimensionner un "flux image binaire"... [ par arnal69130 ]
Bonjour à tous,Je cherche à faire une page pour afficher la carte d'identité d'un "agent", pour simplifier disons juste son nom et sa p
comment redimensionner à la volée des images grâce à la lib GD ??? [TITRE MODERE CAR BOURRE DE FAUTES] [ par fredericmaill ]
Bonjour, j'aimerais savoir comment redimentioné a la vollé des images, donc j'aimerais savoir quelle fonction de la lib gd utiilisé !!
générer un lien automatiquement [ par satellite34 ]
salut,je voudrais savoir un truc :j'ai un forum, comment faire un lien lorsque l'utilisateur a écris http://, automatiquement, si possible en utilisan
Les boutons images [ par raven44 ]
Bonjour à tous, J'ai un petit problème avec un bouton image, naturellement il faut savoir que le bouton image joue le role de submit mais o
redimmensionner des images ... [ par loupile ]
Bonjour, je vous explique sur mon site j'affiche des images hebergées sur des serveurs distants ... donc pas sur le mien :-) je voudrais pouvoir rédui
Générer automatiquement aide html [ par boromsikim ]
Bonjour,J'aurai souhaité mettre en ligne mes diverses documentations, et les présenter sous forme d'aide, un peu comme des fichiers *.chm, avec possib
Php et les images [ par SeNeO64 ]
Bonjour tout le monde.J'aurais voulu savoir s'il existait d'autre librairie que GD permettant de traiter des images.J'ai un script permettant de redim
Pb avec la lib GD [ par quentin2b ]
Bonjour a tous,Je cherchais un petit script pour protéger des images sur un de mes sites masi voila je rencontre un pb avec le code sources que j'ai t
|
Derniers Blogs
CSS CONTENT STATE SELECTORS (PERSONNAL DRAFT)CSS CONTENT STATE SELECTORS (PERSONNAL DRAFT) par FREMYCOMPANY
Bonjour à tous, Je viens de publier une proposition comprenant 5 pseudo-classes pour le CSS Working Group ayant trait à l'état de chargement d'un élément (ex: IMG,VIDEO,AUDIO,OBJECT pour l'HTML.). Si le c½ur vous en dit, vous pouvez retrouver cette p...
Cliquez pour lire la suite de l'article par FREMYCOMPANY MBA : POURQUOI FAIRE ET COMMENT LE CHOISIR ?MBA : POURQUOI FAIRE ET COMMENT LE CHOISIR ? par ROMELARD Fabrice
Formation initiale Durant la formation, le découpage classique est le suivant (je donnerai les équivalences Suisse lorsque je les connaîtrais) : Ecole primaire jusqu'au Collège : Formation générale permettant d'obtenir les méthodes...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice Y'A DES ERREURS QUI PEUVENT RENDRE LE DéVELOPPEUR VIOLENTY'A DES ERREURS QUI PEUVENT RENDRE LE DéVELOPPEUR VIOLENT par Aleks
Quand on a ce genre d'erreur sans log :
Et bas on a juste envie de choper le gas de Microsoft qu'a développé ça et lui foutre des baffes de Coboye ! ...
Cliquez pour lire la suite de l'article par Aleks [HYPER-V 3] PRéSENTATION DES COMMANDLETS POWERSHELL[HYPER-V 3] PRéSENTATION DES COMMANDLETS POWERSHELL par Pierrick CATRO-BROUILLET
Avec la sortie prochaine de la Beta Consumer Preview de Windows 8, j'avais envie de revenir sur une des fonctionnalités que j'attends le plus et que, en bon geek que je suis, j'utilise déjà : Hyper-V 3 ainsi son module PowerShell.
Il y a déjà pléthor...
Cliquez pour lire la suite de l'article par Pierrick CATRO-BROUILLET IIS7 - COMPRESSION GZIPIIS7 - COMPRESSION GZIP par cyril
La compression GZIP permet d'améliorer les performances de navigation en compressant ce qu'envoie le serveur à un client. Pour comprendre comment cela fonctionne, regardons ce qu'il se passe au niveau HTTP lorsqu'un client tente d'accéder à une ress...
Cliquez pour lire la suite de l'article par cyril
Logiciels
Easy-Planning (1.0.0.1)EASY-PLANNING (1.0.0.1)Basé sur les mêmes principes que MyPlanning, Easy-Planning permet de créer des plannings sous la ... Cliquez pour télécharger Easy-Planning Academy System (17.1.3.0)ACADEMY SYSTEM (17.1.3.0)Logiciel de gestion des établissements.
- élèves/étudiants (inscription, dossier, absence...)
-... Cliquez pour télécharger Academy System COLLECTOR PLUS (3.00B)COLLECTOR PLUS (3.00B)COLLECTOR PLUS version 3.00B est un logiciel utilisant une base de données alimentée par :
- L... Cliquez pour télécharger COLLECTOR PLUS PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO (V7.4)PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO (V7.4)PONAMEDIA TV DEVIENS HELLLOOO FLASH
LA TV SUR VOTRE ORDINATEUR.
Toute une plateforme Multi... Cliquez pour télécharger PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO LettresFaciles 2011 (8.0.0.1)LETTRESFACILES 2011 (8.0.0.1)LettresFaciles est un logiciel facilitant la création et la rédaction de lettres types.
Son inte... Cliquez pour télécharger LettresFaciles 2011
|