de-vraag
  • Pertanyaan
  • Tag
  • Pengguna
Notifikasi
Imbalan
Registrasi
Setelah Anda mendaftar, Anda akan diberitahu tentang balasan dan komentar untuk pertanyaan Anda.
Gabung
Jika Anda sudah memiliki akun, masuk untuk memeriksa pemberitahuan baru.
Akan ada hadiah untuk pertanyaan, jawaban, dan komentar tambahan.
Lebih
Sumber
Sunting
Max  William Vitorino
Max William Vitorino
Question

HTML5 Canvas Memutar Gambar

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/

Saya punya masalah untuk memutar gambar 90 ° ke kanan atau ke kiri.

Saya menggunakan gambar di kanvas, layar yang sama akan memiliki beberapa kanvas yang sama dengan contoh, tetapi aku meninggalkannya sedekat mungkin ke proyek.

Saya bertanya, bagaimana cara memutar gambar 90 ° ke kiri atau kanan ketika saya klik "Putar Kiri" dan "Putar Kanan"?

Aku mencoba beberapa kode di internet tapi tidak bekerja.

61 2013-07-01T19:15:50+00:00 8
 meagar
meagar
Pertanyaan edit 24 Juni 2016 в 1:14
Pemrograman
rotation
image
html
canvas
html5-canvas
Solution / Answer
 markE
markE
1 Juli 2013 в 7:41
2013-07-01T19:41:46+00:00
Lebih
Sumber
Sunting
#19801974

Anda dapat menggunakan kanvas' konteks.menerjemahkan & konteks.memutar untuk melakukan memutar gambar anda

Berikut adalah fungsi untuk menggambar sebuah gambar yang diputar dengan yang ditentukan derajat:

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();
}

Berikut adalah kode dan Biola:

<!doctype html>
<html>
<head>
<link rel="stylesheet" type="text/css" media="all" href="css/reset.css" /> <!-- reset css -->
<script type="text/javascript" src="http://code.jquery.com/jquery.min.js"></script>

<style>
    body{ background-color: ivory; }
    canvas{border:1px solid red;}
</style>

<script>
$(function(){

    var canvas=document.getElementById("canvas");
    var ctx=canvas.getContext("2d");

    var angleInDegrees=0;

    var image=document.createElement("img");
    image.onload=function(){
        ctx.drawImage(image,canvas.width/2-image.width/2,canvas.height/2-image.width/2);
    }
    image.src="houseicon.png";

    $("#clockwise").click(function(){ 
        angleInDegrees+=30;
        drawRotated(angleInDegrees);
    });

    $("#counterclockwise").click(function(){ 
        angleInDegrees-=30;
        drawRotated(angleInDegrees);
    });

    function drawRotated(degrees){
        ctx.clearRect(0,0,canvas.width,canvas.height);
        ctx.save();
        ctx.translate(canvas.width/2,canvas.height/2);
        ctx.rotate(degrees*Math.PI/180);
        ctx.drawImage(image,-image.width/2,-image.width/2);
        ctx.restore();
    }

}); // end $(function(){});
</script>

</head>

<body>
    <canvas id="canvas" width=300 height=300></canvas><br>
    <button id="clockwise">Rotate right</button>
    <button id="counterclockwise">Rotate left</button>
</body>
</html>
125
0
 Blindman67
Blindman67
1 April 2017 в 9:23
2017-04-01T09:23:13+00:00
Lebih
Sumber
Sunting
#19801979

Tercepat 2D konteks metode rotasi gambar

Tujuan umum rotasi gambar, posisi, dan skala.

// 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);
} 

Jika anda ingin mengontrol rotasi titik menggunakan fungsi berikutnya

// 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);
} 

Untuk me-reset 2D konteks mengubah

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

Dengan demikian untuk memutar gambar ke kiri (anti searah jarum jam) 90 derajat

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

Dengan demikian untuk memutar gambar ke kanan (searah jarum jam) 90 derajat

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

Contoh menggambar 500 gambar yang diterjemahkan diputar skala

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);
34
0
Steve Farthing
Steve Farthing
1 April 2015 в 7:02
2015-04-01T19:02:54+00:00
Lebih
Sumber
Sunting
#19801976

Solusi lain karya besar untuk gambar persegi. Berikut ini adalah solusi yang akan bekerja untuk sebuah gambar dari setiap dimensi. Kanvas akan selalu sesuai dengan gambar daripada solusi lain yang dapat menyebabkan bagian-bagian dari gambar yang akan dipotong off.

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);
}

25
0
 CpnCrunch
CpnCrunch
11 Mei 2017 в 11:57
2017-05-11T23:57:02+00:00
Lebih
Sumber
Sunting
#19801980

Ini adalah kode sederhana untuk menggambar diputar dan skala gambar:

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(-x-w/2, -y-h/2);
  ctx.drawImage(image, x, y, w, h);
  ctx.restore();
}
Mohammad Usman
Mohammad Usman
Jawaban edit 31 Mei 2017 в 10:09
5
0
 aleha
aleha
18 Oktober 2017 в 1:13
2017-10-18T13:13:33+00:00
Lebih
Sumber
Sunting
#19801981

Seperti @markE menyebutkan dalam bukunya jawaban

alternatif adalah untuk untranslate & unrotate setelah menggambar

Hal ini jauh lebih cepat dari konteks menyelamatkan dan memulihkan.

Berikut ini adalah sebuah contoh

// 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);
3
0
 Dr.Sai
Dr.Sai
20 April 2016 в 12:21
2016-04-20T12:21:10+00:00
Lebih
Sumber
Sunting
#19801977

Di sini adalah Sesuatu yang saya lakukan

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();
    }
}

penggunaan ****

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

HTML

<canvas id="canva" width="350" height="350" style="border:solid thin black;"></canvas>
2
0
 Dr.Sai
Dr.Sai
22 April 2016 в 8:49
2016-04-22T08:49:34+00:00
Lebih
Sumber
Sunting
#19801978

Mengapa tidak melakukannya untuk seluruh halaman. Di halaman memuat mendeteksi semua gambar dan terus menerus memutar semua dari mereka.

 var RotationCollection = {
    rotators: [],
    start_action: function (showBorders, isoverlap) {
        try {
            var canvasTemplate = '<canvas id="_ID_" width="350" height="350"  ></canvas>';

            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);

Silakan periksa untuk theApp.start_Action di mana semua tindakan dimulai HTML dapat sebagai berikut:

 <p>
    Deepika Padukone.<br />
    <img alt="deepika" src="" />
</p>

<p>
    Priyanka Chopra.<br />
    <img alt="Priyanka" src="" />
</p>

Beberapa pilihan untuk tumpang tindih rotasi, perbatasan juga menambahkan

1
0
 casamia
casamia
8 Agustus 2019 в 4:57
2019-08-08T16:57:15+00:00
Lebih
Sumber
Sunting
#19801982

Ini adalah penuh dengan derajat rotasi gambar kode. Saya sarankan anda untuk memeriksa di bawah ini contoh aplikasi di jsfiddle.

Proses aliran ini contoh aplikasi

  1. memuat Gambar, menghitung boundaryRad
  2. buat sementara kanvas
  3. memindahkan kanvas konteks asal ke posisi sendi yang diproyeksikan rect
  4. rotate canvas konteks dengan input sarjana jumlah
  5. menggunakan kanvas.toDataURL metode untuk membuat gambar blob
  6. menggunakan gambar blob, membuat Gambar baru dan membuat elemen

``js

fungsi init() { ... gambar.onload = function() { aplikasi.boundaryRad = Math.atan(gambar.lebar / gambar.tinggi); } ... }

/**

  • CATATAN : Ketika sumber rect diputar di beberapa rad atau derajat,
  • it's asli lebar dan tinggi tidak lagi digunakan di halaman aslinya.
  • Jadi, menghitung proyeksi rect ukuran, yang masing-masing tepi adalah jumlah dari
  • lebar proyeksi dan ketinggian proyeksi asli rect. */ fungsi calcProjectedRectSizeOfRotatedRect(ukuran, rad) { const { width, height } = ukuran;

const rectProjectedWidth = Math.abs(lebar Matematika.cos(rad)) + Math.abs(tinggi Matematika.sin(rad)); const rectProjectedHeight = Math.abs(lebar Matematika.sin(rad)) + Math.abs(tinggi Matematika.cos(rad));

kembali { width: rectProjectedWidth, tinggi: rectProjectedHeight }; }

/**

  • @callback rotatedImageCallback
  • @param {DOMString} dataURL - nilai kembali dari kanvas.toDataURL() */

/**

  • @param {HTMLImageElement} gambar
  • @param {benda} sudut
  • @property {jumlah} sudut.gelar
  • @property {jumlah} sudut.rad
  • @param {rotatedImageCallback} cb
  • */ fungsi getRotatedImage(gambar, angle, cb) { const kanvas = dokumen.createElement('kanvas'); const { derajat, rad: _rad } = sudut;

const rad = _rad || derajat * Matematika.PI / 180 || 0; debug('rad', rad);

const { width, height } = calcProjectedRectSizeOfRotatedRect( { width: gambar.lebar, tinggi: gambar.ketinggian }, rad ); debug('gambar ukuran', gambar.lebar, gambar.tinggi); debug('diproyeksikan ukuran', lebar, tinggi);

kanvas.width = Math.ceil(lebar); kanvas.tinggi = Math.ceil(tinggi);

const ctx = kanvas.getContext('2d'); ctx.save();

const sin_Height = gambar.tinggi Matematika.abs(Matematika.sin(rad)) const cos_Height = gambar.tinggi Matematika.abs(Matematika.cos(rad)) const cos_Width = gambar.lebar Matematika.abs(Matematika.cos(rad)) const sin_Width = gambar.lebar Matematika.abs(Matematika.sin(rad))

debug('sin_Height, cos_Width', sin_Height, cos_Width); debug('cos_Height, sin_Width', cos_Height, sin_Width);

mari xOrigin, yOrigin;

jika (rad < aplikasi.boundaryRad) { debug('case1'); xOrigin = Math.min(sin_Height, cos_Width); yOrigin = 0; } else if (rad < Matematika.PI / 2) { debug('case2'); xOrigin = Math.max(sin_Height, cos_Width); yOrigin = 0; } else if (rad < Matematika.PI / 2 + app.boundaryRad) { debug('case3'); xOrigin = lebar; yOrigin = Math.min(cos_Height, sin_Width); } else if (rad < Matematika.PI) { debug('case4'); xOrigin = lebar; yOrigin = Math.max(cos_Height, sin_Width); } else if (rad < Matematika.PI + app.boundaryRad) { debug('case5'); xOrigin = Math.max(sin_Height, cos_Width); yOrigin = tinggi; } else if (rad < Matematika.PI / 2 3) { debug('case6'); xOrigin = Math.min(sin_Height, cos_Width); yOrigin = tinggi; } else if (rad < Matematika.PI / 2 3 + aplikasi.boundaryRad) { debug('case7'); xOrigin = 0; yOrigin = Math.max(cos_Height, sin_Width); } else if (rad < Matematika.PI * 2) { debug('case8'); xOrigin = 0; yOrigin = Math.min(cos_Height, sin_Width); }

debug('xOrigin, yOrigin', xOrigin, yOrigin)

ctx.menerjemahkan(xOrigin, yOrigin) ctx.memutar(rad); ctx.drawImage(image, 0, 0); jika (DEBUG) drawMarker(ctx, 'merah');

ctx.mengembalikan();

const dataURL = kanvas.toDataURL('gambar/jpg');

cb(dataURL); }

fungsi render() { getRotatedImage(app.gambar, {gelar: aplikasi.gelar}, renderResultImage) } ``

 casamia
casamia
Jawaban edit 8 Agustus 2019 в 8:35
1
0
Related communities 4
HTML dan CSS Indonesia
HTML dan CSS Indonesia
4 425 pengguna
Silahkan bertanya terkait mengenai HTML maupun CSS. Membaca, menulis, berbagi. Baca dahulu pesan tersemat di pinned post.
Buka telegram
Pemrograman Web Indonesia (HTML CSS Javascript PHP MySQL)
Pemrograman Web Indonesia (HTML CSS Javascript PHP MySQL)
300 pengguna
Official Website : https://webcode.my.id Belajar Pemrograman Web (HTML CSS Javascript PHP MySQL) Grup Belajar Pemrograman Web. HTML + PHP + Javascript + MySQL DB Semoga menjadi forum belajar, menambah wawasan, peningkatan mutu personal kita semua.
Buka telegram
HTML INDONESIA
HTML INDONESIA
107 pengguna
Buka telegram
PHP HTML Indonesia
PHP HTML Indonesia
60 pengguna
~ Menerima Jasa Pembuatan Website untuk : Tugas & Instansi 💻 ~ Forum Diskusi Belajar Bersama ✅ ~ Promosi Jasa Minimal 1x Sehari ✅ ~ Dilarang Berbicara Kotor 🚫 ^ Other Grup : Whatsapp Group : Chat Admin untuk masuk ke Grup Whatsapp ^^
Buka telegram
Tambahkan pertanyaan
Kategori
Semua
Teknologi
Budaya / Rekreasi
Kehidupan / Seni
Ilmu Pengetahuan
Profesional
Bisnis
Pengguna
Semua
Baru
Populer
1
Roxana Elizabeth CASTILLO Avalos
Terdaftar 4 hari yang lalu
2
Hideo Nakagawa
Terdaftar 5 hari yang lalu
3
Sergiy Tytarenko
Terdaftar 6 hari yang lalu
4
shoxrux azadov
Terdaftar 1 minggu yang lalu
5
Koreets Koreytsev
Terdaftar 1 minggu yang lalu
ID
JA
RU
TR
© de-vraag 2022
Sumber
stackoverflow.com
di bawah lisensi cc by-sa 3.0 dengan atribusi