正常に動作しているライブ壁紙があります。設定アクティビティを追加したかったので、必要な手順をすべて実行し、ライブ壁紙の選択画面に移動すると設定ボタンが表示されました。ただし、設定ボタンをクリックすると、次の例外が発生します。
11-23 16:12:53.158: E/AndroidRuntime(5141): FATAL EXCEPTION: main
11-23 16:12:53.158: E/AndroidRuntime(5141): java.lang.IllegalArgumentException
11-23 16:12:53.158: E/AndroidRuntime(5141): at android.view.Surface.nativeUnlockCanvasAndPost(Native Method)
11-23 16:12:53.158: E/AndroidRuntime(5141): at android.view.Surface.unlockCanvasAndPost(Surface.java:457)
11-23 16:12:53.158: E/AndroidRuntime(5141): at com.android.internal.view.BaseSurfaceHolder.unlockCanvasAndPost(BaseSurfaceHolder.java:215)
11-23 16:12:53.158: E/AndroidRuntime(5141): at com.gulshansingh.hackerlivewallpaper.HackerWallpaperService$HackerWallpaperEngine.draw(HackerWallpaperService.java:48)
11-23 16:12:53.158: E/AndroidRuntime(5141): at com.gulshansingh.hackerlivewallpaper.HackerWallpaperService$HackerWallpaperEngine.access$0(HackerWallpaperService.java:36)
11-23 16:12:53.158: E/AndroidRuntime(5141): at com.gulshansingh.hackerlivewallpaper.HackerWallpaperService$HackerWallpaperEngine$1.run(HackerWallpaperService.java:31)
11-23 16:12:53.158: E/AndroidRuntime(5141): at android.os.Handler.handleCallback(Handler.java:725)
11-23 16:12:53.158: E/AndroidRuntime(5141): at android.os.Handler.dispatchMessage(Handler.java:92)
11-23 16:12:53.158: E/AndroidRuntime(5141): at android.os.Looper.loop(Looper.java:137)
11-23 16:12:53.158: E/AndroidRuntime(5141): at android.app.ActivityThread.main(ActivityThread.java:5039)
11-23 16:12:53.158: E/AndroidRuntime(5141): at java.lang.reflect.Method.invokeNative(Native Method)
11-23 16:12:53.158: E/AndroidRuntime(5141): at java.lang.reflect.Method.invoke(Method.java:511)
11-23 16:12:53.158: E/AndroidRuntime(5141): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
11-23 16:12:53.158: E/AndroidRuntime(5141): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
11-23 16:12:53.158: E/AndroidRuntime(5141): at dalvik.system.NativeStart.main(Native Method)
これは、これまで正常に動作していた例外の原因となっているコードです (例外の原因となっている行が示されています)。
/** Draws all of the bit sequences on the screen */
private void draw() {
SurfaceHolder holder = getSurfaceHolder();
Canvas c = holder.lockCanvas();
if (c != null) {
try {
c.drawARGB(255, 0, 0, 0);
for (int i = 0; i < sequences.size(); i++) {
sequences.get(i).draw(c);
}
} finally {
holder.unlockCanvasAndPost(c); // line 48
}
}
// Remove the runnable, and only schedule the next run if visible
handler.removeCallbacks(drawRunnable);
if (visible) {
handler.post(drawRunnable);
} else {
stop();
}
}
sequences.get(i).draw()
方法は次のとおりです。
synchronized public void draw(Canvas canvas) {
paint.setAlpha(0);
float prevY = y;
for (int i = 0; i < bits.size(); i++) {
canvas.drawText(bits.get(i), x, y, paint);
y += TEXT_SIZE;
paint.setAlpha(paint.getAlpha() + INCREMENT);
}
y = prevY;
}
私の意見では、これが関連する唯一のコードですが、もっと見たい場合は、ここに投稿できます (反対票を投じる前に質問してください)。また、コード全体は Githubこちらで入手できます。