HTML5 Rotation Image

jQuery('#carregar').click(function(){ var canvas = document.getElementById('canvas'); var image = document.getElementById('image'); var element = canvas.getContext("2d"); element.clearRect(0, 0, canvas.width, canvas.height); element.drawImage(image, 0, 0, 300, 300); }); 

jsfiddle.net/braziel/nWyDE/

J’ai un problème pour faire pivoter une image de 90 ° vers la droite ou vers la gauche.

J’utilise une image sur la canvas, le même écran aura plusieurs canvass égales à celle de l’exemple, mais je l’ai laissé le plus près possible du projet.

Je demande, comment faire pivoter l’image de 90 ° vers la gauche ou vers la droite lorsque je clique sur “Rotate Left” et “Rotate Right”?

J’ai essayé plusieurs codes sur internet mais aucun n’a fonctionné.

Vous pouvez utiliser canvas ‘context.translate & context.rotate pour faire pivoter votre image

entrer la description de l'image ici

Voici une fonction pour dessiner une image qui est pivotée par les degrés spécifiés:

 function drawRotated(degrees){ context.clearRect(0,0,canvas.width,canvas.height); // save the unrotated context of the canvas so we can restore it later // the alternative is to untranslate & unrotate after drawing context.save(); // move to the center of the canvas context.translate(canvas.width/2,canvas.height/2); // rotate the canvas to the specified degrees context.rotate(degrees*Math.PI/180); // draw the image // since the context is rotated, the image will be rotated also context.drawImage(image,-image.width/2,-image.width/2); // we're done with the rotating so restore the unrotated context context.restore(); } 

Voici le code et un violon: http://jsfiddle.net/m1erickson/6ZsCz/

           

L’autre solution fonctionne parfaitement pour les images carrées. Voici une solution qui fonctionnera pour une image de n’importe quelle dimension. Le canevas s’adaptera toujours à l’image plutôt qu’à l’autre solution, ce qui peut entraîner la coupe de parties de l’image.

 var canvas; var angleInDegrees=0; var image=document.createElement("img"); image.onload=function(){ drawRotated(0); } image.src="http://greekgear.files.wordpress.com/2011/07/bob-barker.jpg"; $("#clockwise").click(function(){ angleInDegrees+=90 % 360; drawRotated(angleInDegrees); }); $("#counterclockwise").click(function(){ if(angleInDegrees == 0) angleInDegrees = 270; else angleInDegrees-=90 % 360; drawRotated(angleInDegrees); }); function drawRotated(degrees){ if(canvas) document.body.removeChild(canvas); canvas = document.createElement("canvas"); var ctx=canvas.getContext("2d"); canvas.style.width="20%"; if(degrees == 90 || degrees == 270) { canvas.width = image.height; canvas.height = image.width; } else { canvas.width = image.width; canvas.height = image.height; } ctx.clearRect(0,0,canvas.width,canvas.height); if(degrees == 90 || degrees == 270) { ctx.translate(image.height/2,image.width/2); } else { ctx.translate(image.width/2,image.height/2); } ctx.rotate(degrees*Math.PI/180); ctx.drawImage(image,-image.width/2,-image.height/2); document.body.appendChild(canvas); } 

http://jsfiddle.net/6ZsCz/1588/

Méthode de rotation d’image de contexte 2D la plus rapide

Une rotation d’image, une position et une échelle d’usage général.

 // no need to use save and restore between calls as it sets the transform rather // than multiply it like ctx.rotate ctx.translate ctx.scale and ctx.transform // Also combining the scale and origin into the one call makes it quicker // x,y position of image center // scale scale of image // rotation in radians. function drawImage(image, x, y, scale, rotation){ ctx.setTransform(scale, 0, 0, scale, x, y); // sets scale and origin ctx.rotate(rotation); ctx.drawImage(image, -image.width / 2, -image.height / 2); } 

Si vous souhaitez contrôler le sharepoint rotation, utilisez la fonction suivante

 // same as above but cx and cy are the location of the point of rotation // in image pixel coordinates function drawImageCenter(image, x, y, cx, cy, scale, rotation){ ctx.setTransform(scale, 0, 0, scale, x, y); // sets scale and origin ctx.rotate(rotation); ctx.drawImage(image, -cx, -cy); } 

Pour réinitialiser la transformation du contexte 2D

 ctx.setTransform(1,0,0,1,0,0); // which is much quicker than save and restore 

Ainsi pour faire pivoter l’image vers la gauche (anti-horaire) 90 degrés

 drawImage(image, canvas.width / 2, canvas.height / 2, 1, - Math.PI / 2); 

Ainsi pour faire pivoter l’image vers la droite (dans le sens des aiguilles d’une montre) 90 degrés

 drawImage(image, canvas.width / 2, canvas.height / 2, 1, Math.PI / 2); 

Exemple dessiner 500 images traduites à l’échelle

 var image = new Image; image.src = "https://i.stack.imgur.com/C7qq2.png?s=328&g=1"; var canvas = document.createElement("canvas"); var ctx = canvas.getContext("2d"); canvas.style.position = "absolute"; canvas.style.top = "0px"; canvas.style.left = "0px"; document.body.appendChild(canvas); var w,h; function resize(){ w = canvas.width = innerWidth; h = canvas.height = innerHeight;} resize(); window.addEventListener("resize",resize); function rand(min,max){return Math.random() * (max ?(max-min) : min) + (max ? min : 0) } function DO(count,callback){ while (count--) { callback(count) } } const sprites = []; DO(500,()=>{ sprites.push({ x : rand(w), y : rand(h), xr : 0, yr : 0, // actual position of sprite r : rand(Math.PI * 2), scale : rand(0.1,0.25), dx : rand(-2,2), dy : rand(-2,2), dr : rand(-0.2,0.2), }); }); function drawImage(image, spr){ ctx.setTransform(spr.scale, 0, 0, spr.scale, spr.xr, spr.yr); // sets scales and origin ctx.rotate(spr.r); ctx.drawImage(image, -image.width / 2, -image.height / 2); } function update(){ var ihM,iwM; ctx.setTransform(1,0,0,1,0,0); ctx.clearRect(0,0,w,h); if(image.complete){ var iw = image.width; var ih = image.height; for(var i = 0; i < sprites.length; i ++){ var spr = sprites[i]; spr.x += spr.dx; spr.y += spr.dy; spr.r += spr.dr; iwM = iw * spr.scale * 2 + w; ihM = ih * spr.scale * 2 + h; spr.xr = ((spr.x % iwM) + iwM) % iwM - iw * spr.scale; spr.yr = ((spr.y % ihM) + ihM) % ihM - ih * spr.scale; drawImage(image,spr); } } requestAnimationFrame(update); } requestAnimationFrame(update); 

C’est le code le plus simple pour dessiner une image tournée et mise à l’échelle:

 function drawImage(ctx, image, x, y, w, h, degrees){ ctx.save(); ctx.translate(x+w/2, y+h/2); ctx.rotate(degrees*Math.PI/180.0); ctx.translate(-xw/2, -yh/2); ctx.drawImage(image, x, y, w, h); ctx.restore(); } 

Voici quelque chose que j’ai fait

 var ImgRotator = { angle:parseInt(45), image:{}, src:"", canvasID:"", intervalMS:parseInt(500), jump:parseInt(5), start_action:function(canvasID, imgSrc, interval, jumgAngle){ ImgRotator.jump = jumgAngle; ImgRotator.intervalMS = interval; ImgRotator.canvasID = canvasID; ImgRotator.src = imgSrc ; var image = new Image(); var canvas = document.getElementById(ImgRotator.canvasID); image.onload = function() { ImgRotator.image = image; canvas.height = canvas.width = Math.sqrt( image.width* image.width+image.height*image.height); window.setInterval(ImgRotator.keepRotating,ImgRotator.intervalMS); //theApp.keepRotating(); }; image.src = ImgRotator.src; }, keepRotating:function(){ ImgRotator.angle+=ImgRotator.jump; var canvas = document.getElementById(ImgRotator.canvasID); var ctx = canvas.getContext("2d"); ctx.save(); ctx.clearRect(0,0,canvas.width,canvas.height); ctx.translate(canvas.width/2,canvas.height/2); ctx.rotate(ImgRotator.angle*Math.PI/180); ctx.drawImage(ImgRotator.image, -ImgRotator.image.width/2,-ImgRotator.image.height/2); ctx.restore(); } } 

usage

 ImgRotator.start_action("canva", "", 500,15 ); 

HTML

  

Comme @markE mentionne dans sa réponse

l’alternative est de déstructurer et de détacher après avoir dessiné

C’est beaucoup plus rapide que la sauvegarde et la restauration du contexte.

Voici un exemple

 // translate and rotate this.context.translate(x,y); this.context.rotate(radians); this.context.translate(-x,-y); this.context.drawImage(...); // untranslate and unrotate this.context.translate(x, y); this.context.rotate(-radians); this.context.translate(-x,-y); 

Pourquoi ne pas le faire pour toute la page. Au chargement de la page, détecter toutes les images et les faire pivoter en continu.

  var RotationCollection = { rotators: [], start_action: function (showBorders, isoverlap) { try { var canvasTemplate = ''; var ja = 5; $.each($("img"), function (index, val) { var newID = "can_" + index; var can = canvasTemplate.replace("_ID_", newID); if (showBorders == true) $(can).insertAfter($(val)).css({ "border": "solid thin black", "box-shadow": "5px 5px 10px 2px black", "border-raduis": "15px" }); else $(can).insertAfter($(val)); $(val).remove(); var curRot = new RotationClass(newID, $(val).attr('src'), ja * ((0 == index % 2) ? -1 : 1), isoverlap); RotationCollection.rotators[index] = curRot; ja += 5; //return false; }); window.setInterval(function () { $.each(RotationCollection.rotators, function (index, value) { value.drawRotatedImage(); }) }, 500); } catch (err) { console.log(err.message); } } }; function RotationClass(canvasID, imgSrc, jumgAngle, overlap) { var self = this; self.overlap = overlap; self.angle = parseInt(45); self.image = {}; self.src = imgSrc; self.canvasID = canvasID; self.jump = parseInt(jumgAngle); self.start_action = function () { var image = new Image(); var canvas = document.getElementById(self.canvasID); image.onload = function () { self.image = image; canvas.height = canvas.width = Math.sqrt(image.width * image.width + image.height * image.height); self.drawRotatedImage(self); }; image.src = self.src; } self.start_action(); this.drawRotatedImage = function () { var self = this; self.angle += self.jump; var canvas = document.getElementById(self.canvasID); var ctx = canvas.getContext("2d"); ctx.save(); if (self.overlap) ctx.clearRect(0, 0, canvas.width, canvas.height); ctx.translate(canvas.width / 2, canvas.height / 2); ctx.rotate(self.angle * Math.PI / 180); ctx.drawImage(self.image, -self.image.width / 2, -self.image.height / 2); ctx.restore(); } } var theApp = { start_Action: function () { RotationCollection.start_action(true, true); } }; $(document).ready(theApp.start_Action); 

S’il vous plaît vérifier pour theApp.start_Action où toute l’action commence Le HTML peut être comme suit:

  

Deepika Padukone.
deepika

Priyanka Chopra.
Priyanka

Some options to overlap rotations, borders are also added