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


 Recherche

 NewsLetter





   

Redimensionner une image en JavaScript

Creation d'image de previsualisation a la volee





Aurelien
Tout catalogue ou album photo qui se respecte possede des images de previsualisation. Deux methodes sont utilisees pour ce genre de process, soit vous faites une petite image par image a afficher ou alors, vous construisez ces petites images a l'affichage en temps reel.

Ce chapitre traitera la deuxieme possibilite.

Posons plus sérieusement le problème :

Pour homogeneise la page, nous allons donc nous baser sur une taille fixe maximale pour l'affichage de l'image et recalculer ses dimensions a la volee en JavaScript.

Exemple :

     

Ces images ont ete redimensionnees a la volee afin de creer des previsualisateur de petites tailles avec une taille maximale de 50 * 50.

Function JavaScript redimImage :

function redimImage(inImg, inMW, inMH)
{
  // Cette function recoit 3 parametres
  // inImg : Chemin relatif de l'image
  // inMW  : Largeur maximale
  // inMH   : Hauteur maximale
  var maxWidth = inMW;
  var maxHeight = inMH;
  // Declarations des variables "Nouvelle Taille"
  var dW = 0;
  var dH = 0;
  // Declaration d'un objet Image
  var oImg = new Image();
  // Affectation du chemin de l'image a l'objet
  oImg.src = inImg;
  // On recupere les tailles reelles
  var h = dH = oImg.height;
  var w = dW = oImg.width;
  // Si la largeur ou la hauteur depasse la taille maximale
  if ((h >= maxHeight) || (w >= maxWidth)) {
    // Si la largeur et la hauteur depasse la taille maximale
    if ((h >= maxHeight) && (w >= maxWidth)) {
      // On cherche la plus grande valeur
      if (h > w) {
        dH = maxHeight;
        // On recalcule la taille proportionnellement
        dW = parseInt((w * dH) / h, 10);
      } else {
        dW = maxWidth;
        // On recalcule la taille proportionnellement
        dH = parseInt((h * dW) / w, 10);
      }
    } else if ((h > maxHeight) && (w < maxWidth)) {
      // Si la hauteur depasse la taille maximale
      dH = maxHeight;
        // On recalcule la taille proportionnellement
      dW = parseInt((w * dH) / h, 10);
    } else if ((h < maxHeight) && (w > maxWidth)) {
      // Si la largeur depasse la taille maximale
      dW = maxWidth;
        // On recalcule la taille proportionnellement
      dH = parseInt((h * dW) / w, 10);
    }
  }
  // On ecrit l'image dans le document
  document.writeln("<img src=\"" + inImg + "\" width=\"" + dW + "\" height=\"" + dH + "\" border=\"0\">");
};


Syntaxe d'utilisation :

<body>
<script language="JavaScript">
redimImage('unRepertoire/uneImage.gif', 100, 100);
</script>

</body>


Telecharger l'exemple complet

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

 Lire  13/02/2008 de Aquel
Youhou, il y a quelqu'un ici ou c'est mort de chez mo...
  • 15/02/2008 de twins20 Je pense que tu as raison Aquel pour l...
  • 15/02/2008 de Aquel Bonjour Twins et merci de pour ta réponse...
  •  Lire  22/01/2008 de Aquel
    Bonjour, j'ai exactement le même problème. La pho...
     Lire  11/12/2007 de jcp
    Bonjour, J’ai un programme x.php qui permet a l’uti...
      v1.3p © ASP-PHP.net 2002  

    Aurelien le 12/07/2003 (69 345 hits)
    Didier 11 logiciels Microsoft GRATUITS dont Visual Studio 2008 Pro,
    SQL Server 2005, Expression Studio, Windows Server 2003, Office project Pro, etc... !!!
    Au fil des news  
    Magazines - Le n°108 de Programmez est disponible
    Adobe - Téléchargez gratuitement le dossier spécial Adobe
    Magazines - Le N°107 de Programmez est disponible.
    Créer une Feature d'administration sous SharePoint - Comment créer un composant d'administration
    Dans les précédents articles, nous avons évoqué la création de pages personnalisées dans ...
    PHP - Afficher une date : multilangage et relative
    Agenda - Inscrivez-vous au WygDay [Wygwam] le 22/5 à Lille
    Sync Framework - Introduction au MS Sync Framework - Installation
    Microsoft, lors du Keynote du TechEd Europe 2007, a annoncé la mise à disposition d'un nouveau ...
    Reporting Services et SharePoint - Utiliser SharePoint comme source de données
    Dans un précédent article, nous avons pu apprendre comment créer un rapport utilisant une source de ...
    JavaScript - Affiche un calendrier sous une zone de saisie
    Adobe - Adobe lance la version bêta publique de Photoshop
    Microsoft Expression Web - Premier contact
    Je suis revenu des Techday's 2008 avec une idée en tête. Je voulais savoir comme travailler avec ...
    PHP & MySQLi - de Hello / Sector One
    Hello de Sector One propose un article avec PHP et MySQLi, la nouvelle extension de MySQL
    VBScript - Zip de fichiers automatique et efface la source
    Dreamweaver CS3 + Php + Mysql - Trucs et Astuces - Part 4 -
    Pour changer, deux nouvelles astuces pour vous . Alternate Colors. Inscription et envoi de mail
    Magazines - Le N°106 de Programmez est disponible.
    Divers - Zone Webmasters
    PHP5 - Classe de connexion à MySQL
    Agenda - 20/03 : Boostez vos applis PHP-Windows Server 2008
    Créer un thème graphique pour WSS V3 - Comment créer un thème graphique pour WSS V3
    Nous avons vu dans un précédent article comment créer une master page. Il peut parfois être ...
    Les plans de maintenance et SQL Server 2000 - Installer un plan de maintenance sous SQL Server
    Dans le cadre de la gestion d'instances SQL Server 2000 hébergeant SharePoint, il est intéressant ...
    PHP - PHP et MYSQL - MySQLi - PDO
    Jeux de l'été (et de 4) - Un petit jeu de Mastermind
    C'est reparti pour un tour... Il y avait longtemps que je n'étais pas venu vous proposer un petit ...
    Migration WSS avec un Site Template spécifique - Migration WSS avec un Site Template spécifique
    Les précédents articles nous ont permis de voir les différents modes de migration de WSS V2 vers ...
    DataBase Upgrade de WSS V2 vers WSS V3 - Upgrade de WSS V2 vers WSS V3 par la DataBase
    Parmi les trois modes de migration de Windows SharePoint Services V2 vers WSS V3, nous avons vu les ...
    Création de module DotNetNuke en C# - Source : Jerome Fortias sap-integration.net
    Je vous propose un nouvel article consacré au développement de modules pour DotNetNuke en C#. Il ...
    ASP-PHP.net - On sera aux MS TechDays 2008 ! et vous ?
    Créer son modèle de rapports SSRS - Créer son modèle de rapports Reporting Services
    Après la création du modèle de style pour Reporting Services, il est souhaitable aussi d'avoir un ...
    PHP - publipostage sur rtf préformaté avec mysql
    Créer son style de rapports SSRS - Créer son style de rapports Reporting Services
    Lorsqu'on travaille avec Reporting Services pour développer ses rapports, on veut très souvent ...
    .NET - C#2 et ASP.NET 2.0 - Développez un projet de A à Z
    SharePoint - MOSS 2007 - De l'intégration au développement
    PHP - PHP 5 MySQL 5 AJAX
    Découverte de Visual Studio 2008 -
    Microsoft a annoncé, lors du TechEd'07 organisé à Barcelone, la mise à disposition de la release de ...
    Adobe - Photoshop Elements 6 Version MAC
    Adobe - Adobe sur Intergraphic 2008
    Reporting Services et données XML - Utiliser des données XML dans Reporting Services
    Une demande récente que j'ai reçue : Comment utiliser des données provenant d'un flux XML dans ...
    Dreamweaver CS3 + XML + Ajax - Création d'une région détail
    Dans cet article, je vais vous montrer comment utiliser la technique région détail, avec Spry
    PHP - Jolie arborescence dynamique
    Magazines - Le N°104 de Programmez est disponible
    PHP - PhPBB 3.0.0 !!!
    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
    v3 © Didier 2003   
     

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