Maison interface Web js tutoriel Comment utiliser JavaScript pour implémenter la fonction glisser et zoomer des images ?

Comment utiliser JavaScript pour implémenter la fonction glisser et zoomer des images ?

Oct 27, 2023 am 09:39 AM
javascript 图片 拖拽

如何使用 JavaScript 实现图片的拖拽缩放功能?

Comment utiliser JavaScript pour implémenter la fonction glisser et zoomer des images ?

Dans le développement Web moderne, faire glisser et zoomer des images est une exigence courante. En utilisant JavaScript, nous pouvons facilement ajouter des fonctions de glisser et de zoom aux images pour offrir une meilleure expérience utilisateur. Dans cet article, nous présenterons comment utiliser JavaScript pour implémenter cette fonction, avec des exemples de code spécifiques.

  1. Structure HTML

Tout d'abord, nous avons besoin d'une structure HTML de base pour afficher les images et ajouter des identifiants et des écouteurs d'événements aux images. En ajoutant un identifiant à l'image, nous pouvons facilement la sélectionner et la manipuler en JavaScript. Voici un exemple de structure HTML de base :

<div class="image-container">
  <img id="my-image" src="path/to/image.jpg" alt="我的图片">
</div>
Copier après la connexion
  1. Styles CSS de base

Pour rendre l'image déplaçable et zoomable, nous avons besoin de quelques styles CSS de base. Voici un exemple CSS de base qui peut être ajusté en fonction de vos besoins :

.image-container {
  width: 500px;
  height: 500px;
  position: relative;
  overflow: hidden;
}

#my-image {
  position: absolute;
  width: 100%;
  height: 100%;
  cursor: grab;
  user-select: none;
}
Copier après la connexion

Dans l'exemple ci-dessus, .image-container est un conteneur contenant une image, définie sur une largeur et une hauteur fixes, et Réglez sur le positionnement relatif. #my-image est l'élément d'image que nous voulons utiliser. Il est défini sur un positionnement absolu, remplit tout le conteneur et ajoute quelques styles de base, tels que cursor: grab. (lorsque la souris survole, affiche un curseur en forme de main lors du survol d'une image) et user-select: none (empêche l'utilisateur de sélectionner le texte de l'image). .image-container 是一个包含图片的容器,设置了固定的宽度和高度,并设置为相对定位。#my-image 是我们要操作的图片元素,设置为绝对定位,填充整个容器,并添加了一些基本样式,如cursor: grab(当鼠标悬停在图片上时显示手型光标)和user-select: none(禁止用户选取图片文本)。

  1. JavaScript 实现拖拽和缩放功能

接下来,我们将使用JavaScript来实现图片的拖拽和缩放功能。首先,我们需要选择图片元素,并为其添加事件监听:

const image = document.getElementById('my-image');

image.addEventListener('mousedown', startDrag);
image.addEventListener('mouseup', stopDrag);
Copier après la connexion

在上面的代码中,我们选择了ID为my-image的图片元素,并为mousedownmouseup事件添加了事件监听器。这两个事件分别在按下鼠标按钮和释放鼠标按钮时触发。

接下来,我们需要定义拖拽开始和结束时的逻辑:

let isDragging = false;
let startMouseX, startMouseY, startImageX, startImageY;

function startDrag(event) {
  isDragging = true;

  startMouseX = event.clientX;
  startMouseY = event.clientY;
  startImageX = image.offsetLeft;
  startImageY = image.offsetTop;
}

function stopDrag() {
  isDragging = false;
}
Copier après la connexion

在上面的代码中,我们定义了几个变量来记录拖拽过程的相关信息,如开始时的鼠标位置(startMouseX 和 startMouseY)、图片位置(startImageX 和 startImageY)。在拖拽开始时,我们将isDragging变量设置为true,同时记录鼠标和图片的起始位置。在拖拽结束时,我们将isDragging变量设置为false。

接下来,我们需要实现拖拽过程中图片跟随鼠标移动的功能:

document.addEventListener('mousemove', moveImage);

function moveImage(event) {
  if (!isDragging) return;

  const deltaX = event.clientX - startMouseX;
  const deltaY = event.clientY - startMouseY;
  const newImageX = startImageX + deltaX;
  const newImageY = startImageY + deltaY;

  image.style.left = newImageX + 'px';
  image.style.top = newImageY + 'px';
}
Copier après la connexion

在上面的代码中,我们为mousemove事件添加了事件监听器,并在拖拽过程中触发了moveImage函数。在moveImage函数中,我们首先检查isDragging变量是否为true,以确定是否在拖拽过程中。然后,我们计算鼠标偏移量(deltaX 和 deltaY),并根据起始图片位置和偏移量计算出新的图片位置(newImageX 和 newImageY)。最后,我们通过设置样式的方式,将图片移动到新的位置。

现在,我们已经实现了图片的拖拽功能。接下来,我们将添加图片的缩放功能。

const MIN_SCALE = 0.5;
const MAX_SCALE = 2;
let currentScale = 1;

document.addEventListener('wheel', scaleImage);

function scaleImage(event) {
  event.preventDefault();

  const scale = Math.exp(event.deltaY * -0.01);
  currentScale *= scale;

  if (currentScale < MIN_SCALE || currentScale > MAX_SCALE) return;

  image.style.transform = `scale(${currentScale})`;
}
Copier après la connexion

在上面的代码中,我们首先定义了最小缩放比例(MIN_SCALE)和最大缩放比例(MAX_SCALE)。然后,我们为wheel事件添加了事件监听器,并在滚动鼠标滚轮时触发了scaleImage函数。在scaleImage

    JavaScript pour implémenter les fonctions de glisser et de zoom

    Ensuite, nous utiliserons JavaScript pour implémenter les fonctions de glisser et de zoom des images. Tout d'abord, nous devons sélectionner l'élément image et y ajouter un écouteur d'événement :

    rrreee

    Dans le code ci-dessus, nous avons sélectionné l'élément image avec l'ID my-image et l'avons défini sur mousedown et <code>mouseup. Ces deux événements sont déclenchés respectivement lorsque le bouton de la souris est enfoncé et lorsque le bouton de la souris est relâché.

    🎜Ensuite, nous devons définir la logique au début et à la fin du glissement : 🎜rrreee🎜Dans le code ci-dessus, nous avons défini plusieurs variables pour enregistrer les informations pertinentes du processus de glissement, telles que la position de la souris au début (startMouseX et startMouseY), position de l'image (startImageX et startImageY). Lorsque le glisser commence, nous définissons la variable isDragging sur true et enregistrons les positions de départ de la souris et de l'image. A la fin du glissement, nous définissons la variable isDragging sur false. 🎜🎜Ensuite, nous devons implémenter la fonction de l'image suivant le mouvement de la souris pendant le processus de glisser : 🎜rrreee🎜Dans le code ci-dessus, nous avons ajouté un écouteur d'événement pour l'événement mousemove, et pendant le processus de glissement La fonction moveImage est déclenchée. Dans la fonction moveImage, nous vérifions d'abord si la variable isDragging est vraie pour déterminer si elle est en cours de glissement. Nous calculons ensuite le décalage de la souris (deltaX et deltaY) et calculons la nouvelle position de l'image (newImageX et newImageY) en fonction de la position et du décalage de départ de l'image. Enfin, nous déplaçons l'image vers un nouvel emplacement en définissant le style. 🎜🎜Maintenant, nous avons implémenté la fonction glisser-déposer des images. Ensuite, nous ajouterons la possibilité de zoomer et dézoomer sur l’image. 🎜rrreee🎜Dans le code ci-dessus, nous définissons d'abord le rapport de mise à l'échelle minimum (MIN_SCALE) et le rapport de mise à l'échelle maximum (MAX_SCALE). Ensuite, nous avons ajouté un écouteur d'événement pour l'événement wheel et déclenché la fonction scaleImage lorsque la molette de la souris était tournée. Dans la fonction scaleImage, nous empêchons d'abord le comportement de défilement par défaut pour éviter le défilement des pages. Nous calculons ensuite l'échelle en fonction de la valeur deltaY de la molette de la souris et l'appliquons à l'échelle actuelle. Enfin, nous appliquons une mise à l'échelle à l'élément d'image en le stylisant. 🎜🎜À ce stade, nous avons terminé la mise en œuvre des fonctions glisser et zoomer des images. Grâce à l'exemple de code ci-dessus, vous pouvez ajouter des images à votre page Web et implémenter les fonctions de glisser et de zoom des images. N'oubliez pas d'ajuster les styles CSS et la logique JavaScript en fonction de vos besoins spécifiques. 🎜🎜Résumé🎜🎜Cet article explique comment utiliser JavaScript pour implémenter les fonctions de glisser et de zoom des images. Nous pouvons facilement ajouter ces fonctionnalités interactives aux images des pages Web en sélectionnant des éléments d’image et en implémentant une logique de glisser-zoom lorsque des événements de souris sont déclenchés. J'espère que cet article vous sera utile ! 🎜

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Où trouver la courte de la grue à atomide atomique
1 Il y a quelques semaines By DDD

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Comment résoudre le problème de l'enregistrement automatique des images lors de la publication sur Xiaohongshu ? Où est l'image enregistrée automatiquement lors de la publication ? Comment résoudre le problème de l'enregistrement automatique des images lors de la publication sur Xiaohongshu ? Où est l'image enregistrée automatiquement lors de la publication ? Mar 22, 2024 am 08:06 AM

Avec le développement continu des médias sociaux, Xiaohongshu est devenue une plateforme permettant à de plus en plus de jeunes de partager leur vie et de découvrir de belles choses. De nombreux utilisateurs sont gênés par des problèmes de sauvegarde automatique lors de la publication d’images. Alors, comment résoudre ce problème ? 1. Comment résoudre le problème de l'enregistrement automatique des images lors de la publication sur Xiaohongshu ? 1. Vider le cache Tout d'abord, nous pouvons essayer de vider les données du cache de Xiaohongshu. Les étapes sont les suivantes : (1) Ouvrez Xiaohongshu et cliquez sur le bouton « Mon » dans le coin inférieur droit (2) Sur la page du centre personnel, recherchez « Paramètres » et cliquez dessus (3) Faites défiler vers le bas et recherchez « ; "Vider le cache". Cliquez sur OK. Après avoir vidé le cache, entrez à nouveau dans Xiaohongshu et essayez de publier des photos pour voir si le problème de sauvegarde automatique est résolu. 2. Mettez à jour la version Xiaohongshu pour vous assurer que votre Xiaohongshu

Comment publier des photos dans les commentaires TikTok ? Où se trouve l'entrée des photos dans la zone commentaire ? Comment publier des photos dans les commentaires TikTok ? Où se trouve l'entrée des photos dans la zone commentaire ? Mar 21, 2024 pm 09:12 PM

Avec la popularité des courtes vidéos Douyin, les interactions des utilisateurs dans la zone de commentaires sont devenues plus colorées. Certains utilisateurs souhaitent partager des images en commentaires pour mieux exprimer leurs opinions ou émotions. Alors, comment publier des photos dans les commentaires TikTok ? Cet article répondra à cette question en détail et vous fournira quelques conseils et précautions connexes. 1. Comment publier des photos dans les commentaires Douyin ? 1. Ouvrez Douyin : Tout d'abord, vous devez ouvrir l'application Douyin et vous connecter à votre compte. 2. Recherchez la zone de commentaire : lorsque vous parcourez ou publiez une courte vidéo, recherchez l'endroit où vous souhaitez commenter et cliquez sur le bouton "Commentaire". 3. Saisissez le contenu de votre commentaire : saisissez le contenu de votre commentaire dans la zone de commentaire. 4. Choisissez d'envoyer une photo : Dans l'interface de saisie du contenu des commentaires, vous verrez un bouton « image » ou un bouton « + », cliquez sur

6 façons de rendre les images plus nettes sur iPhone 6 façons de rendre les images plus nettes sur iPhone Mar 04, 2024 pm 06:25 PM

Les iPhones récents d'Apple capturent des souvenirs avec des détails, une saturation et une luminosité nets. Mais parfois, vous pouvez rencontrer des problèmes qui peuvent rendre l’image moins claire. Bien que la mise au point automatique sur les appareils photo iPhone ait parcouru un long chemin, vous permettant de prendre des photos rapidement, l'appareil photo peut se concentrer par erreur sur le mauvais sujet dans certaines situations, rendant la photo floue dans les zones indésirables. Si vos photos sur votre iPhone semblent floues ou manquent globalement de netteté, l’article suivant devrait vous aider à les rendre plus nettes. Comment rendre les images plus claires sur iPhone [6 méthodes] Vous pouvez essayer d'utiliser l'application Photos native pour nettoyer vos photos. Si vous souhaitez plus de fonctionnalités et d'options

Comment faire sortir les images ppt une par une Comment faire sortir les images ppt une par une Mar 25, 2024 pm 04:00 PM

Dans PowerPoint, il est courant d'afficher les images une par une, ce qui peut être réalisé en définissant des effets d'animation. Ce guide détaille les étapes de mise en œuvre de cette technique, y compris la configuration de base, l'insertion d'images, l'ajout d'une animation et l'ajustement de l'ordre et du timing de l'animation. De plus, des paramètres et ajustements avancés sont fournis, tels que l'utilisation de déclencheurs, l'ajustement de la vitesse et de l'ordre de l'animation et la prévisualisation des effets d'animation. En suivant ces étapes et conseils, les utilisateurs peuvent facilement configurer les images pour qu'elles apparaissent les unes après les autres dans PowerPoint, améliorant ainsi l'impact visuel de la présentation et attirant l'attention du public.

Comment convertir des documents PDF en images jpg avec Foxit PDF Reader - Comment convertir des documents PDF en images jpg avec Foxit PDF Reader Comment convertir des documents PDF en images jpg avec Foxit PDF Reader - Comment convertir des documents PDF en images jpg avec Foxit PDF Reader Mar 04, 2024 pm 05:49 PM

Utilisez-vous également le logiciel Foxit PDF Reader ? Alors, savez-vous comment Foxit PDF Reader convertit les documents PDF en images jpg ? L'article suivant vous explique comment Foxit PDF Reader convertit les documents PDF en images jpg ? images jpg, venez jeter un oeil ci-dessous. Démarrez d'abord Foxit PDF Reader, puis recherchez « Fonctionnalités » dans la barre d'outils supérieure, puis sélectionnez la fonction « PDF vers autres ». Ensuite, ouvrez une page Web intitulée « Foxit PDF Online Conversion ». Cliquez sur le bouton « Connexion » en haut à droite de la page pour vous connecter, puis activez la fonction « PDF to Image ». Cliquez ensuite sur le bouton de téléchargement et ajoutez le fichier pdf que vous souhaitez convertir en image. Après l'avoir ajouté, cliquez sur "Démarrer la conversion".

Comment disposer deux images côte à côte dans un document wps Comment disposer deux images côte à côte dans un document wps Mar 20, 2024 pm 04:00 PM

Lors de l'utilisation du logiciel bureautique WPS, nous avons constaté que non seulement un formulaire est utilisé, mais que des tableaux et des images peuvent être ajoutés au texte, des images peuvent également être ajoutées au tableau, etc. Ceux-ci sont tous utilisés ensemble pour créer le contenu de l'ensemble du document. paraître plus riche, si vous devez insérer deux images dans le document et qu’elles doivent être disposées côte à côte. Notre prochain cours résoudra ce problème : comment placer deux images côte à côte dans un document wps. 1. Tout d'abord, vous devez ouvrir le logiciel WPS et trouver l'image que vous souhaitez ajuster. Faites un clic gauche sur l'image et une barre de menu apparaîtra, sélectionnez "Mise en page". 2. Sélectionnez « Emballage serré » dans l'habillage du texte. 3. Une fois que toutes les images dont vous avez besoin ont été confirmées comme étant définies sur « Habillage de texte serré », vous pouvez faire glisser les images vers la position appropriée et cliquer sur la première image.

Que dois-je faire si les images de la page Web ne peuvent pas être chargées ? 6 solutions Que dois-je faire si les images de la page Web ne peuvent pas être chargées ? 6 solutions Mar 15, 2024 am 10:30 AM

Certains internautes ont constaté que lorsqu'ils ouvraient la page Web du navigateur, les images de la page Web ne pouvaient pas être chargées pendant une longue période. Que s'est-il passé ? J'ai vérifié que le réseau est normal, alors quel est le problème ? L'éditeur ci-dessous vous présentera six solutions au problème de l'impossibilité de charger les images de pages Web. Les images de la page Web ne peuvent pas être chargées : 1. Problème de vitesse Internet La page Web ne peut pas afficher les images. Cela peut être dû au fait que la vitesse Internet de l'ordinateur est relativement lente et qu'il y a davantage de logiciels ouverts sur l'ordinateur et que les images auxquelles nous accédons sont relativement volumineuses. peut être dû à un délai de chargement. Par conséquent, l'image ne peut pas être affichée. Vous pouvez désactiver le logiciel qui utilise la vitesse du réseau et le vérifier dans le gestionnaire de tâches. 2. Trop de visiteurs Si la page Web ne peut pas afficher d'images, c'est peut-être parce que les pages Web que nous avons visitées ont été visitées en même temps.

Comment faire en sorte que Win11 affiche automatiquement une image au démarrage Comment faire en sorte que Win11 affiche automatiquement une image au démarrage Dec 31, 2023 pm 10:54 PM

Certains utilisateurs souhaitent ouvrir automatiquement une image lors de la mise sous tension de l'ordinateur sans changer le fond d'écran du bureau. Nous pouvons utiliser cette fonction pour profiter d'images ou de mémos rapides. En fait, la méthode de configuration est très simple. dans le dossier de démarrage. Jetons-y un coup d'œil ci-dessous. Comment ouvrir automatiquement une image au démarrage de Windows 11 : 1. Tout d'abord, nous devons double-cliquer pour ouvrir « Cet ordinateur » sur le bureau 2. Après avoir entré cet ordinateur, double-cliquez pour entrer dans le système « lecteur c » 3. . Localisez ensuite l'emplacement suivant "C:\Users\Administrator" \AppData\Roaming\Microsoft\Windows\StartMenu\Programs\Start.

See all articles