IllegalStateException : underflow in restore 例外が発生し、アプリケーションがクラッシュします。これは、Android 4.3 のアップデート後に発生し始めました。Android 3.0 - 4.2.x では正常に動作します。
例外は2番目に発生します
canvas.restore();
以下は私の描画コードです
private void doDraw(Canvas canvas) {
if(mTickerBackGround!=null && (!mTickerBackGround.isRecycled())){
canvas.drawBitmap(mTickerBackGround, 0, 0, null);
}
if((mBitMapBuffer!=null)){
canvas.save();
canvas.translate(mX, 0);
if(!mBitMapBuffer.isRecycled()){
canvas.drawBitmap(mBitMapBuffer, 0, 0, null);
}
canvas.restore();
if(bitMapWidth+mX<mCanvasWidth){
canvas.translate(bitMapWidth+mX, 0);
if(!mBitMapBuffer.isRecycled()){
canvas.drawBitmap(mBitMapBuffer, 0, 0, null);
}
canvas.restore();
}
if(bitMapWidth+mX<=0){
mX = 0;
}else if(Math.abs(mX)>(bitMapWidth)){
mX= mCanvasWidth;
}
mX-=TickerConstants.SCROLLING_SMOOTHNESS*density;;
}
if(mLogo!=null && (!mLogo.isRecycled())){
canvas.drawBitmap(mLogo, mCanvasWidth-(60*density), mLogo.getHeight()/6, null);
}
}
私の質問は
- このエラーの意味は何ですか?
- このエラーを修正するにはどうすればよいですか?
生成されたスタック トレース メッセージは です。165 行目は 2 番目の canvas.restore() に対応します。
08-13 18:13:09.083: E/AndroidRuntime(14139): FATAL EXCEPTION: Thread-506 08-13 18:13:09.083: E/AndroidRuntime(14139): java.lang.IllegalStateException: 復元でのアンダーフロー 08-13 18:13:09.083: E/AndroidRuntime(14139): android.graphics.Canvas.restore(ネイティブ メソッド) 08-13 18:13:09.083: E/AndroidRuntime(14139): com.my.package.name で。 ticker.TickerSurfaceView$TickerThread.doDraw(TickerSurfaceView.java:165) 08-13 18:13:09.083: E/AndroidRuntime(14139): com.my.package.name.ticker.TickerSurfaceView$TickerThread.run(TickerSurfaceView.java で:128)