2011-02-15 72 views
0

我正在试图通过jquery roate插件旋转图像来实现amimation。 不幸的是,这个插件没有改变它的旋转点,它总是居中.. ,它没有这个参数jquery旋转:改变旋转点可能吗? (变换画布功能)

我发现用canvas做这个可以用canvas.transform )功能。

我是一个使用canvas的初学者,但如果有人能给我一个例子如何做到这一点,我会大大apreciate它。

这里的图像旋转插件:http://wilq32.adobeair.pl/jQueryRotate/Wilq32.jQueryRotate.html

这里的帆布制成。(但trails.don't有种不好的,因为它的叶子知道为什么http://jsbin.com/ipeqi3/2

+0

见http://stackoverflow.com/questions/4697041/rotating-and-moving -an-image-in-a-canvas-element/4697139#4697139和http://stackoverflow.com/questions/4649836/using-html5-canvas-rotate-image-about-arbitrary-point/4650102#4650102 – Phrogz 2011-02-15 19:54:41

回答

0

这是我到目前为止,它确实通过改变旋转点来旋转图像(不是变换,我的坏...)

它不做它不会创建一个流畅的动画,它很粗糙..我怎么能完成那个?

另一件事我需要的是一个背景必须是透明的

这里是到目前为止我的代码:

<script> 
var degree=10; 

function docanvas() { 
    var canvas = document.getElementById('canvas'); 
var cContext = canvas.getContext('2d'); 

var img = new Image(); 
    // Create new Image object  
    img.src = 'http://www.gravatar.com/avatar/e555bd971bc2f4910893cd5b785c30ff?s=128&d=identicon&r=PG'; // Set source path // set img src 


var cw = img.width, ch = img.height, cx = 0, cy = 0; 


canvas.setAttribute('width', 300); 
canvas.setAttribute('height', 300); 

cContext.fillStyle = "rgba(0, 0, 255, .5)"; 
cContext.fillRect(0, 0, 300, 300); 

cContext.translate(150, 150); 


cContext.rotate(degree * Math.PI/180); 
cContext.drawImage(img, -64, -128,128,128); 

    degree+=5; 

} 
</script> 


</head> 
<body onload="setInterval('docanvas()',50);"> 
<canvas id="canvas"></canvas> 
<script> 
     docanvas(30); 
</script>  
</body> 
</html>