我正在为 Honeycomb 3.0 开发动态壁纸,但我收到一个随机错误。
当我在壁纸选择器(带有“设置壁纸”和“设置...”按钮的窗口,要理解)和动态壁纸显示时,如果我旋转设备,壁纸应重新加载适合新方向的配置。有时会这样,有时它会崩溃。
错误在某种程度上与 BaseSurfaceHolder.unlockCanvasAndPost 方法有关,但我真的不知道是不是问题。我认为它无法正确加载一些资源..
这是错误日志:
07-21 16:07:38.490: WARN/WindowManager(292): java.lang.IllegalArgumentException: Requested window android.os.BinderProxy@40d19f28 does not exist
07-21 16:07:38.490: WARN/WindowManager(292): at com.android.server.wm.WindowManagerService.windowForClientLocked(WindowManagerService.java:6731)
07-21 16:07:38.490: WARN/WindowManager(292): at com.android.server.wm.WindowManagerService.windowForClientLocked(WindowManagerService.java:6722)
07-21 16:07:38.490: WARN/WindowManager(292): at com.android.server.wm.WindowManagerService.removeWindow(WindowManagerService.java:2414)
07-21 16:07:38.490: WARN/WindowManager(292): at com.android.server.wm.Session.remove(Session.java:149)
07-21 16:07:38.490: WARN/WindowManager(292): at android.view.IWindowSession$Stub.onTransact(IWindowSession.java:120)
07-21 16:07:38.490: WARN/WindowManager(292): at com.android.server.wm.Session.onTransact(Session.java:111)
07-21 16:07:38.490: WARN/WindowManager(292): at android.os.Binder.execTransact(Binder.java:320)
07-21 16:07:38.490: WARN/WindowManager(292): at dalvik.system.NativeStart.run(Native Method)
07-21 16:07:38.490: ERROR/AndroidRuntime(20768): FATAL EXCEPTION: main
07-21 16:07:38.490: ERROR/AndroidRuntime(20768): java.lang.IllegalArgumentException
07-21 16:07:38.490: ERROR/AndroidRuntime(20768): at android.view.Surface.unlockCanvasAndPost(Native Method)
07-21 16:07:38.490: ERROR/AndroidRuntime(20768): at com.android.internal.view.BaseSurfaceHolder.unlockCanvasAndPost(BaseSurfaceHolder.java:215)
07-21 16:07:38.490: ERROR/AndroidRuntime(20768): at mx.livewallpaper.clock.CubeWallpaper1$CubeEngine.drawFrame(CubeWallpaper1.java:686)
07-21 16:07:38.490: ERROR/AndroidRuntime(20768): at mx.livewallpaper.clock.CubeWallpaper1$CubeEngine$1.run(CubeWallpaper1.java:292)
07-21 16:07:38.490: ERROR/AndroidRuntime(20768): at android.os.Handler.handleCallback(Handler.java:587)
07-21 16:07:38.490: ERROR/AndroidRuntime(20768): at android.os.Handler.dispatchMessage(Handler.java:92)
07-21 16:07:38.490: ERROR/AndroidRuntime(20768): at android.os.Looper.loop(Looper.java:132)
07-21 16:07:38.490: ERROR/AndroidRuntime(20768): at android.app.ActivityThread.main(ActivityThread.java:4028)
07-21 16:07:38.490: ERROR/AndroidRuntime(20768): at java.lang.reflect.Method.invokeNative(Native Method)
07-21 16:07:38.490: ERROR/AndroidRuntime(20768): at java.lang.reflect.Method.invoke(Method.java:491)
07-21 16:07:38.490: ERROR/AndroidRuntime(20768): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:844)
07-21 16:07:38.490: ERROR/AndroidRuntime(20768): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:602)
07-21 16:07:38.490: ERROR/AndroidRuntime(20768): at dalvik.system.NativeStart.main(Native Method)
07-21 16:07:38.500: ERROR/android.os.Debug(292): Dumpstate > /data/log/dumpstate_app_error
编辑:下面的代码是第686行的drawFrame()方法:
void drawFrame() {
final SurfaceHolder holder = getSurfaceHolder();
Canvas c = null;
try {
c = holder.lockCanvas();
if (c != null) {
drawLogo3(c);
}
} finally {
if (c != null) holder.unlockCanvasAndPost(c);
}
这是所有动态壁纸中的默认方法ppresent,我是从Android SDK的CubeWallpaper动态壁纸示例中获取的。
编辑2:
这听起来像是缓冲区错误。如果我将帧速率设置为10fps而不是40fps,则动态壁纸选取器根本不会崩溃。是否可以仅为活动“动态壁纸选择器”编辑动态壁纸行为?
答案 0 :(得分:1)
在破坏曲面之前让线程连接
@Override
public void onSurfaceDestroyed(SurfaceHolder holder)
{
try
{
updater.join();
}
catch (InterruptedException e)
{
}
super.onSurfaceDestroyed(holder);
}
答案 1 :(得分:1)
当你改变设备的方向时,调用了函数“onsurfacechange()”。你必须在那里做某些事情。我猜你改变定向符的时候“surfaceholder”也改变了。我这样做:
@Override
public void onSurfaceChanged(SurfaceHolder holder, int format,
int width, int height) {
int lockwidth = 0;
int lockheight = 0;
mholder = holder;
try {
canvas = mholder.lockCanvas();
lockwidth = canvas.getWidth();
lockheight = canvas.getHeight();
if (width > height) {
Utils.Width = lockheight;
Utils.screenWidth = lockheight;
Utils.screenHeight = lockwidth;
Utils.isWidth = true;
if (width == 1280 && height == 720 && lockwidth == 800
&& lockheight == 480) {
Utils.screenWidth = 480;
Utils.screenHeight = 854;
}
} else {
Utils.Width = lockwidth;
Utils.screenWidth = lockwidth;
Utils.screenHeight = lockheight;
Utils.isWidth = false;
if (width == 720 && height == 1280 && lockwidth == 480
&& lockheight == 800) {
Utils.screenWidth = 480;
Utils.screenHeight = 854;
}
}
mholder.unlockCanvasAndPost(canvas);
} catch (Exception e) {
}
Utils.rateX = (float) Utils.Width / (float) Utils.FLA_Width;
Utils.ratio = Utils.screenWidth / Utils.FLA_Width;
Utils.Width = lockwidth;
Utils.Height = lockheight;
}