Maison interface Web Voir.js Vue et Canvas : Comment implémenter les fonctions de recadrage et de rotation d'images

Vue et Canvas : Comment implémenter les fonctions de recadrage et de rotation d'images

Jul 19, 2023 pm 11:27 PM
vue canvas 裁剪

Vue et Canvas : Comment implémenter des fonctions de recadrage et de rotation d'images

Dans le développement Web moderne, le traitement d'image est une exigence courante, comme le recadrage et la rotation des images. Vue et Canvas sont deux technologies frontales puissantes qui fonctionnent bien ensemble pour réaliser ces fonctions. Cet article expliquera comment utiliser Vue et Canvas pour implémenter des fonctions de recadrage et de rotation d'images, et fournira des exemples de code pour référence.

  1. Implémentation de la fonction de téléchargement d'images

Tout d'abord, nous devons implémenter la fonction de téléchargement d'images. Vous pouvez utiliser le composant Vue pour créer un simple bouton de téléchargement et utiliser l'attribut data de Vue pour enregistrer les données d'image téléchargées.

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

<template>

  <div>

    <input type="file" @change="handleFileChange">

    <div v-if="imageData">

      <img :src="imageData" alt="Uploaded image">

    </div>

  </div>

</template>

 

<script>

export default {

  data() {

    return {

      imageData: null

    }

  },

  methods: {

    handleFileChange(event) {

      const file = event.target.files[0];

      const reader = new FileReader();

 

      reader.onload = (e) => {

        this.imageData = e.target.result;

      }

 

      reader.readAsDataURL(file);

    }

  }

}

</script>

Copier après la connexion
  1. Utilisez Canvas pour le recadrage d'image

Ensuite, nous pouvons utiliser Canvas pour implémenter la fonction de recadrage d'image. Tout d'abord, vous devez ajouter un élément Canvas au composant Vue pour afficher le résultat du recadrage et utiliser l'attribut ref de Vue pour obtenir une référence à l'élément Canvas.

1

2

3

4

5

6

7

<template>

  <div>

    <!-- ... -->

    <canvas ref="canvas"></canvas>

    <button @click="cropImage">Crop</button>

  </div>

</template>

Copier après la connexion

Dans les méthodes du composant Vue, nous devons implémenter une méthode cropImage pour recadrer l'image. Tout d’abord, nous devons obtenir une référence à l’élément Canvas, puis utiliser la méthode getContext de Canvas pour obtenir le contexte 2D. Ensuite, nous pouvons utiliser la méthode drawImage de Canvas pour dessiner l'image téléchargée sur le Canvas.

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

<script>

export default {

  methods: {

    cropImage() {

      const canvas = this.$refs.canvas;

      const context = canvas.getContext('2d');

 

      const image = new Image();

      image.src = this.imageData;

 

      image.onload = () => {

        context.drawImage(image, 0, 0, canvas.width, canvas.height);

      }

    }

  }

}

</script>

Copier après la connexion

Maintenant, lorsque l'utilisateur clique sur le bouton "Recadrer", l'image téléchargée sera dessinée sur le canevas.

  1. Réaliser la fonction de rotation de l'image

En plus de la fonction de recadrage, nous pouvons également implémenter la fonction de rotation de l'image. En ajoutant un attribut d'angle de rotation aux données du composant Vue, nous pouvons facilement implémenter la fonction de rotation d'image.

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

<template>

  <div>

    <!-- ... -->

    <canvas ref="canvas"></canvas>

    <!-- ... -->

    <button @click="rotateImage">Rotate</button>

  </div>

</template>

 

<script>

export default {

  data() {

    return {

      imageData: null,

      angle: 0

    }

  },

  methods: {

    rotateImage() {

      this.angle += 90;

      this.drawRotatedImage();

    },

    drawRotatedImage() {

      const canvas = this.$refs.canvas;

      const context = canvas.getContext('2d');

 

      const image = new Image();

      image.src = this.imageData;

 

      image.onload = () => {

        context.clearRect(0, 0, canvas.width, canvas.height);

        context.save();

        context.translate(canvas.width / 2, canvas.height / 2);

        context.rotate((this.angle * Math.PI) / 180);

        context.drawImage(image, -canvas.width / 2, -canvas.height / 2, canvas.width, canvas.height);

        context.restore();

      }

    }

  }

}

</script>

Copier après la connexion

Maintenant, lorsque l'utilisateur clique sur le bouton "Rotation", l'image téléchargée sera pivotée de 90 degrés à chaque fois.

En combinant Vue et Canvas, nous pouvons rapidement implémenter des fonctions de recadrage et de rotation d'images. Dans cet article, nous utilisons la méthode drawImage et la fonction de transformation de rotation de Canvas pour implémenter respectivement ces deux fonctions et fournissons des exemples de code pour référence. J'espère que cet article pourra vous aider à comprendre comment utiliser Vue et Canvas pour traiter des images.

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

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
2 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Repo: Comment relancer ses coéquipiers
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
2 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Repo: Comment relancer ses coéquipiers
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD

Tags d'article chaud

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 utiliser les graphiques électroniques dans Vue Comment utiliser les graphiques électroniques dans Vue May 09, 2024 pm 04:24 PM

Comment utiliser les graphiques électroniques dans Vue

Le rôle de l'export par défaut dans vue Le rôle de l'export par défaut dans vue May 09, 2024 pm 06:48 PM

Le rôle de l'export par défaut dans vue

Comment utiliser la fonction map dans vue Comment utiliser la fonction map dans vue May 09, 2024 pm 06:54 PM

Comment utiliser la fonction map dans vue

La différence entre event et $event dans vue La différence entre event et $event dans vue May 08, 2024 pm 04:42 PM

La différence entre event et $event dans vue

Le rôle du monté en vue Le rôle du monté en vue May 09, 2024 pm 02:51 PM

Le rôle du monté en vue

La différence entre l'exportation et l'exportation par défaut dans vue La différence entre l'exportation et l'exportation par défaut dans vue May 08, 2024 pm 05:27 PM

La différence entre l'exportation et l'exportation par défaut dans vue

Que sont les crochets en vue Que sont les crochets en vue May 09, 2024 pm 06:33 PM

Que sont les crochets en vue

Pour quels scénarios les modificateurs d'événements dans vue peuvent-ils être utilisés ? Pour quels scénarios les modificateurs d'événements dans vue peuvent-ils être utilisés ? May 09, 2024 pm 02:33 PM

Pour quels scénarios les modificateurs d'événements dans vue peuvent-ils être utilisés ?

See all articles