尝试使用Canvas和DrawImage以90度显示低速率视频

时间:2012-02-04 05:17:54

标签: html5 video canvas rotation drawimage

我想以2帧/秒的速度显示旋转的摄像机视频。以下代码显示以90度旋转的240 x 320图像。除非我刷新浏览器,否则图像不会更新。正在改变的来源是cam_1.jpg。看来,一旦DrawImage有一个src图像,它确实会寻找更新。

我还没学到什么?感谢您的时间和专业知识。

<title>CamDisplay</title></head><body>
<canvas height="320" width="240"></canvas>
<script type="text/javascript" charset="utf-8">
    var cam = new Image;
    window.onload = function(){
        var c = document.getElementsByTagName('canvas')[0];
        var ctx = c.getContext('2d');
        setInterval(function(){
            ctx.save();
            ctx.clearRect( 0, 0, 240, 320 );
            ctx.translate( 240, 0);

            cam.src = 'cam_1.jpg?uniq='+Math.random();

            ctx.rotate( 1.57);
            ctx.drawImage( cam, 0, 0 );
                            ctx.restore();
        },500);
    };
</script>
</body>
</html>

1 个答案:

答案 0 :(得分:1)

图片没有时间加载。试试

var cam = new Image;
var c = document.getElementsByTagName('canvas')[0];
var ctx = c.getContext('2d');

cam.onload = function() {
        ctx.save();
         ctx.clearRect( 0, 0, 240, 320 );
         ctx.translate( 240, 0);
         ctx.rotate( 1.57);
         ctx.drawImage( this, 0, 0 );
        ctx.restore();  
    }

window.onload = function(){
    setInterval(function(){
        cam.src = 'cam_1.jpg?uniq='+Math.random();
    },500);
}