Designed by NoKi !
46 en ligne   Boutique | Sites | Bar | Forum | PhpBB | Actu | Glossaire | Codes | Tips | Liens | Livres | Lettre  


 Recherche

 NewsLetter






   

Afficher ses images à la taille voulue

Utilisation du composant IMGSIZE





DB77
Devant la diversité des formats d'image actuels, il est parfois nécessaire de connaître les dimensions d'une image afin d'adapter les paramètres «width» et «height» lors de son affichage sur une des pages du site.
C'est notamment le cas si vous proposez à vos visiteurs de déposer sur votre site leur avatar.
Aurélien nous a déjà proposé une solution et vous trouverez deux liens sur ces deux articles un peu plus bas sur cette page.
En ASP, il existe un composant gratuit qui permet de connaître ces dimensions. En PHP, il suffit d'utiliser la fonction getimagsize ;

 

Voyons donc les étapes successsives de sa mise en oeuvre.

 Installation 
Comme beaucoup de composants, il s'agit d'une DLL à copier sur le serveur et à enregistrer dans la base de registre.
Il convient donc, dans un premier temps, de copier le fichier «IMGSIZE.DLL» sur le disque de votre serveur.
Dans un deuxième temps, il faut exécuter, sur le serveur, la commande «REGSVR32 chemin_d'_accès_à_la_DLL»
Exemple :
Si vous copiez le fichier «IMGSIZE.DLL» dans «C:\outils\IMGSIZE.DLL», il faudra exécuter la commande : «REGSVR32 C:\outils\IMGSIZE.DLL»
Le composant ImgSize

 Utilisation 
Voyons d'abord comment fonctionne ImgSize

<% 
' Création d'un objet IMGSIZE
Set Picto=Server.CreateObject("ImgSize.Check")
' Déclaration de l'image à analyser
Picto.FileName="C:\Images\truc.gif"
' On teste s'il y a une erreur
if Picto.Error <> "" then
   Response.Write "Erreur : <b>" & Picto.Error & "</b>"
else
   ' Récupération des dimensions
   largeur=Picto.Width
   hauteur=Picto.Height
End if
' Libération de l'objet
Set Picto=Nothing
%>


 Concrètement 
Supposons que vous autorisez un avatar qui fasse 100 pixels de large sur 100 pixels de haut au maximum.
Comment faire pour conserver la proportionnalité de l'image uploadée par votre utilisateur ?
Tout d'abord, allez jeter un oeil sur les scripts d'Aurélien :
RedimImage  et :  AveImgClass
Maintenant, voici celui que je vous propose :

<% 
' Nous allons créer une procédure
Sub Redimimage(urlimg,maxX,maxY)
' Vérifier que l'image existe bien
Set FSO = Server.CreateObject("Scripting.FileSystemObject") 
dir = Server.MapPath("./") ' Vous mettrez ce que vous voulez
Fnm = dir & "\" & urlimg
if FSO.FileExists(Fnm) then
   ' Création d'un objet IMGSIZE
   Set Picto=Server.CreateObject("ImgSize.Check")
   ' Déclaration de l'image à analyser
   Picto.FileName=Server.Mappath("./"&urlimg)
   ' On teste s'il y a une erreur
   if Picto.Error <> "" then
      Response.Write "Erreur : <b>" & Picto.Error & "</b>"
   else
      ' Récupération des dimensions
      largeur=Picto.Width
      hauteur=Picto.Height
      ' Libération de l'objet
      Set Picto=Nothing
      ' Calculons le ratio idéal
      ratiox=largeur/maxX ' Ratio en largeur
      ratioy=hauteur/maxY ' Ratio en hauteur
      if(ratiox>ratioy) then ' Quel est le plus grand
         ratio=ratiox
      else
         ratio=ratioy
      end if
      response.write "<img src="&urlimg&" width="&Cint(largeur/ratio)&" height="&Cint(hauteur/ratio)&">"
   end if
end if
Set FSO=Nothing
end sub
'
' Et cette procédure sera appelée comme ceci :
'
Redimimage "photos/db77.gif",100,100
%>



A vos avatars...
Affichez bien vos images...

Pour pouvoir écrire dans ce forum, identifiez-vous !

 Lire  07/10/08 13:48 de fedebul
bonjour, auriez une version de ce script en php ? me...
  • 07/10/08 14:10 de DB77 Là : http://www.asp-php.net/tutorial/asp-ph...
  • 07/10/08 14:25 de fedebul merci beaucoup , de plus j'ai un tit p...
  • 07/10/08 14:38 de DB77 Regarde sur la ligne d'avant s'il ne manque...
  • 07/10/08 14:40 de DB77 Fais un copier/coller de ça : echo "<tr>...
  •   v1.3p © ASP-PHP.net 2002  

    DB77 le 23/06/2008 (8 678 hits)
    Didier Testez gratuitement la plateforme web de Windows Server 2008 !
    Gagnez un voyage aux Etats-Unis pour la MS Project Conference !
    Au fil des news  
    Adobe - Adobe annonce MAX 2009 !
    [MAJ] Dreamweaver MX + Php + MySql - Les formulaires - partie 3
    Mise à jour du code, par DB 77, affichage du code erreur, dans la page erreur.php, traduction des ...
    PHP - News avec photo - Système de gestion - affichage
    Gestion - Administration - Affichage d'une "News", "Actualité", "Info", ... avec : - mise en forme ...
    Dreamweaver Php Mysql - Région répétée imbriquée
    Je rebondis, sur un post du forum, pour vous montrer comment obtenir grâce à l'extension Simulated ...
    Gérer les bases de contenu SharePoint - Gérer la croissance du volume des données
    Dans le cadre de la gestion quotidienne de ferme SharePoint, il existe une partie qu'il faut ...
    PHP - Le Coach PHP sur Visual Studio
    .NET - Ecrire une application .NET utilisant MySQL
    PHP - Utilisation de PHP dans le monde Microsoft
    Magazines - Le n° 119 de Programmez est disponible
    Adobe - Adobe annonce Photoshop Marketplace
    [MAJ] Tutoriel AJAX simple - En avant vers le WEB2.0
    Mis à jour le 20/04/2009
    Captcha «maison» sans extension - Et en plus, c'est gratuit ;)
    Un ami m'a demandé de l'aide ce matin pour insérer un captcha dans un formulaire pour son site ...
    Dreamweaver CS4 - Photoshop CS4 - Alliance parfaite pour la gestion des images
    Pour changer un peu des pages de code, je vous propose de voir ensemble, la fonctionnalité très ...
    JavaScript - Calcul automatique d'une facture
    Amélioration du Search MOSS: Manipulation XSL - Utilisation du XSL dans l'affichage des résultats
    Parmi tous les articles sur l'amélioration du moteur de recherche de Microsoft Office SharePoint ...
    Outils - Editeur d'icônes IcoFX
    Magazines - Le n°118 de Programmez est disponible
    JavaScript - Imprimer une autre page que celle en cours
    CSS - div pour imiter frame (Bandeau/Menu FIXES)
    [MAJ] [PHP] Un calendrier très complet -
    ajout des événements au calendrier
    PowerShell - Winforms pour l'aide des commandes GET PowerShell
    Adobe - Adobe Photoshop Lightroom 2 est offert ....
    Amélioration du Search MOSS: synonyme et Best Bet - La gestion des synonymes dans MOSS Search
    Le moteur de recherche de MOSS permet la configuration d'une liste de synonymes. Nous verrons donc ...
    AJAX - récup champs formulaires pour POST en AJAX
    PowerShell - Un windows Forms pour SharePoint en PowerShell
    Sondage associatif (compatibilité) - Qui va bien avec qui ?
    Cette fois, c'est un petit sondage que je vous propose. Il pourra bien sûr être adaptée à vos ...
    ASP - Hashage MD5 (cryptage irréversible)
    Adobe - 80% de réduction sur les versions Adobe Creative
    CSharp - Interroger un serveur Whois
    CSharp - Equivalent de la fonction PHP htmlentities()
    CSharp - Somme de contrôle CRC32
    Magazines - Le n°117 de Programmez est disponible
    Hebergement - Hébergement ASP et ASP.Net
    MOSS - Mon Profil - Personnalisation des profils utilisateurs de MOSS
    La gestion des profils utilisateurs de SharePoint fait partie des fonctionnalités de base de ...
    Dreamweaver CS3 + Php + Mysql - Le Jeu d'Enregistrements - Les fondamentaux Part-3
    La 3ème partie des fondamentaux, traitera essentiellement du jeu d'enregistrements ou Recordset. ...
    Mon mini-site @ Home - avec Windows, Free, Wamp & DynDNS
    Envie d'héberger votre petit site chez vous, sur votre ordinateur ? de partager des fichiers avec ...
    Magazines - Le n°116 de Programmez est disponible
    Recevoir ses identifiants par mél - Bien pratique pour les petites têtes
    Encore une question posée sur le forum et zou... Le problème est simple : On a oublié ses ...
    ASP.NET - code pour le bouton enregistrer
    Microsoft - Grand jeu-concours MSDN : l'indice d'ASP-PHP.net !
    Tutorial : HTML | Scripting | ASP-PHP | ASP.net | SQL Server | XML
    Sharepoint | XAML | Pocket | Dreamweaver | VML | Divers
      Scripts : Scripting | ASP-PHP | ASP.net | Divers
      Boutique | Annuaire | Bannières | Météo | Tribune | Partenariats
    v3b © Didier 2003   
     

    Corpo Sciences de Reims Partitions gratuites Carte, météo, annonces
     Groupes Utilisateurs Microsoft Codes Sources ASP-magazine El Roubio The Inquirer FR TechNet Wygwam DotNet Project CodePPC MVP