Преобразование изображений Javascript? [масштабировать и вращать] - PullRequest
1 голос
/ 22 апреля 2010

Я собираюсь создать инструмент преобразования изображений с помощью Javascript. Нечто, которое использует ручки вокруг изображения, аналогичные Photoshop, и позволяет пользователю масштабировать и вращать. Я ищу, чтобы это работало в IE 6 и выше, Firefox 3+ и Safari 3+.

Кто-нибудь знает библиотеку или инструмент, который может помочь с этим? Я видел много инструментов, которые используют элемент Canvas, но не используют ИТ. Я также видел библиотеку Рафаэля, которая может работать. Есть еще варианты?

Ответы [ 2 ]

0 голосов
/ 26 октября 2013

Посмотрите на этот роторзум. Он вращается, увеличивает скорость, и я могу сделать еще несколько ударов.

http://codepen.io/hex2bin/pen/tHwhF

var requestId = 0;
var animationStartTime = 0;
var img = new Image();
initimg(img);

dst = document.getElementById("dst").getContext("2d");
dst.drawImage(img, 0, 0, 256, 256);
// read the width and height of the canvas
i = 0;

var imageDataDst = dst.getImageData(0, 0, 1024, 512);
var bufDst = new ArrayBuffer(imageDataDst.data.length);
var buf8Dst = new Uint8ClampedArray(bufDst);
var data32Dst = new Uint32Array(bufDst);
var data32Src = new Uint32Array(256*256);	

var scan1=0;
var scan4=0
  
// fill the source array with the image
for (var y = 0; y < 256; ++y) {
  scan4=y*1024*4;  
  for (var x = 0; x < 256; ++x) {        
        data32Src[scan1++] =
        (255   << 24) +    // alpha
        (imageDataDst.data[scan4+2] << 16) +    // blue
        (imageDataDst.data[scan4+1] <<  8) +    // green
        imageDataDst.data[scan4];               // red			 
		scan4=scan4+4;
    }  
}

 animationStartTime = window.performance.now();
 requestId = window.requestAnimationFrame(animate);
 var j=0;    


function animate(time) {	
	var height=512;
	var width=1024;	
	j=j+1;	
    var  timestamp = j / 100;       
    var pos;    
    var startY = 128;
    var startX = 128;	
	  var i=0;    
    var scaledHeight = 512 + Math.sin(timestamp*1.4) * 500;
    var scaledWidth = 512 + Math.sin(timestamp*1.4) * 500
    var angleRadians = timestamp;
    var deltaX1 = Math.cos(angleRadians) * scaledHeight / 256;
    var deltaY1 = Math.sin(angleRadians) * scaledHeight / 256;
	  var deltaY1x256=deltaY1*256;
    var deltaX2 =Math.sin(angleRadians ) * scaledWidth / 256;
    var deltaY2 =-  Math.cos(angleRadians ) * scaledWidth / 256;   
    var h = height;
    while (h--) {
      var x =262144+ startX+deltaX1*-512+deltaX2*-256;
      var y =262144+ startY+deltaY1*-512+deltaY2*-256;
	  var y256=y*256;
      var w = width;
      while (w--) {
        //Optimised inner loop. Can it be done better?
        pos =(y256>>0&0xff00)+(x>>0&0xff);
        data32Dst[i++] =data32Src[pos];                    
        x += deltaX1;
        y256 += deltaY1x256;        
        //end of inner loop
      }
      startX += deltaX2
      startY += deltaY2;
    }
    
    imageDataDst.data.set(buf8Dst);
    dst.putImageData(imageDataDst, 0, 0);
	
    requestId = window.requestAnimationFrame(animate);
}

function initimg(image1)
{
image1.src = '';
}
<body>
  <canvas id="dst" width="1024", height="512">
    Random Canvas
  </canvas>
</body>
0 голосов
/ 23 января 2012

Проверьте библиотеку Рафаэля на Github: https://github.com/DmitryBaranovskiy/raphael

...