LoginSignup
3
3

More than 5 years have passed since last update.

一部Androidの標準ブラウザでclearRectすると描画がおかしくなる

Last updated at Posted at 2015-05-21

環境

端末: ARROWS Tab F-02F
OS: Android4.2.2
ブラウザ: ブラウザ

現象

Canvasでのアニメーション作成時に、フレームごとにCanvasサイズでclearRect()を掛けていたところ、ある瞬間からページ全体の描画がおかしくなる。

原因

before.js
canvas.width = 980;
canvas.height = 300;
setInterval(function(){
    ctx.clearRect( 0, 0, canvas.width, canvas.height )
}, 1000/30);

上のようにCanvasサイズぴったりにclearRect()を使うとこういった現象がおこるようです。

対策

clearRect()のサイズをcanvasサイズぴったりにしなければいい

after.js
canvas.width = 980;
canvas.height = 300;
setInterval(function(){
    ctx.clearRect( 0, 0, canvas.width+1, canvas.height+1 )
}, 1000/30);

これで無事にAndroidでの描画がおかしくなることがなくなりました。

参考サイト

ハマったこと:AndroidにおけるCreateJS/Canvasのバグ

3
3
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
3
3