简体   繁体   English

Javascript图像转换? [缩放和旋转]

[英]Javascript Image Transform? [scale and rotate]

I'm looking to build an image transform tool with Javascript. 我正在寻找使用Javascript构建图像转换工具。 Something that utilizes handles around the image similar to Photoshop and allows the user to scale and rotate. 利用类似于Photoshop的图像周围的手柄进行处理的操作,并允许用户缩放和旋转。 I'm looking to make this work in IE 6 and up and Firefox 3+ and Safari 3+. 我希望在IE 6和更高版本以及Firefox 3+和Safari 3+中实现此功能。

Does anyone know of a library or tool that could help with this? 有谁知道可以帮助您解决此问题的库或工具? I've seen a lot of tools that utilize the Canvas element but that leaves out IT. 我已经看到了许多利用Canvas元素的工具,但这些工具都没有使用IT。 I've also seen the Raphael library which might work. 我还看到了可能有效的Raphael库。 Any other options out there? 还有其他选择吗?

Have a look at this rotorzoom. 看看这个转子变焦。 It rotates it zooms it's fast and i can do with a few more hits. 它旋转旋转,变焦很快,我可以再打几下。

http://codepen.io/hex2bin/pen/tHwhF 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> 

在Github上查看Raphael库: https : //github.com/DmitryBaranovskiy/raphael

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM