0

当我在我的应用程序中浏览时,有时会出现此错误。我不确定这个错误是随机出现的,我不知道为什么。日志没有显示任何特定于我的应用程序的内容?

我希望有人能给我提示或提示为什么会发生此错误。(最后一次是当我尝试打开一个弹出窗口时,一个快速操作对话框,在第二次使用相同的快速操作对话框后,它在我第三次尝试后再次工作。现在它一直工作,再次?)

08-01 11:09:15.980: ERROR/AndroidRuntime(9579): FATAL EXCEPTION: main
08-01 11:09:15.980: ERROR/AndroidRuntime(9579): java.lang.NullPointerException
08-01 11:09:15.980: ERROR/AndroidRuntime(9579):     at android.widget.PopupWindow$PopupViewContainer.dispatchKeyEvent(PopupWindow.java:1445)
08-01 11:09:15.980: ERROR/AndroidRuntime(9579):     at android.view.ViewRoot.deliverKeyEventToViewHierarchy(ViewRoot.java:2664)
08-01 11:09:15.980: ERROR/AndroidRuntime(9579):     at android.view.ViewRoot.deliverKeyEvent(ViewRoot.java:2629)
08-01 11:09:15.980: ERROR/AndroidRuntime(9579):     at android.view.ViewRoot.handleMessage(ViewRoot.java:1935)
08-01 11:09:15.980: ERROR/AndroidRuntime(9579):     at android.os.Handler.dispatchMessage(Handler.java:99)
08-01 11:09:15.980: ERROR/AndroidRuntime(9579):     at android.os.Looper.loop(Looper.java:143)
08-01 11:09:15.980: ERROR/AndroidRuntime(9579):     at android.app.ActivityThread.main(ActivityThread.java:4196)
08-01 11:09:15.980: ERROR/AndroidRuntime(9579):     at java.lang.reflect.Method.invokeNative(Native Method)
08-01 11:09:15.980: ERROR/AndroidRuntime(9579):     at java.lang.reflect.Method.invoke(Method.java:507)
08-01 11:09:15.980: ERROR/AndroidRuntime(9579):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
08-01 11:09:15.980: ERROR/AndroidRuntime(9579):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
08-01 11:09:15.980: ERROR/AndroidRuntime(9579):     at dalvik.system.NativeStart.main(Native Method)

这里有更多细节:

QuickAction qa = QuickactionBuilder.showSaveForgetQuickaction();

                qa.setOnActionItemClickListener(new QuickAction.OnActionItemClickListener() {
                    @Override
                    public void onItemClick(int pos) {
                        if (pos == 0) { // SAVE
                            Toast.makeText(ctxHolder.getCtx(), "TODO SAVE", Toast.LENGTH_SHORT).show();
                        } else if (pos == 1) { // REJECT
                            Toast.makeText(ctxHolder.getCtx(), "REJECTED", Toast.LENGTH_SHORT).show();
                        } else { // CANCEL
                            Toast.makeText(ctxHolder.getCtx(), "CANCEL", Toast.LENGTH_SHORT).show();
                        }
                    }
                });

                qa.show(v);

QuickactionBuilder 只为我创建 QuickAction 对话框。这很简单:(仅展示该方法的基础知识)

QuickAction qa = new QuickAction
ActionItem ai = new ActionItem() 
// some setters ...

qa.add(ai)

return qa;
4

3 回答 3

1

我在使用 QuickAction 时遇到了同样的问题,尽管我无法在我的设备上重现它们,但我收到了来自用户的崩溃,所以如果有人仍然需要解决方案,我很乐意分享

这个想法是避免在 PopupWindow 中使用 PopupViewContainer,因为崩溃错误在它的 dispatchKeyEvent(KeyEvent event) 方法中。我能做到这一点的唯一方法是保持 backgroundDrawable == null。然后你必须自己处理外部触摸和返回按钮。

弹出窗口类:

public PopupWindows(Context context) {
    mContext    = context;

    mWindow     = new PopupWindow(context);
    mWindow.setBackgroundDrawable(null);
    ......
}

protected void onShow() {   

    if (mRootView == null) {
        return;
    }

    if (mRootView instanceof CustomRelativeLayout) {
        ((CustomRelativeLayout)mRootView).setDispatchKeyEventListener(new CustomRelativeLayout.OnDispatchKeyEventListener() {

            @Override
            public void onDispatchKeyEvent(KeyEvent event) {
                if (event.getKeyCode() == KeyEvent.KEYCODE_BACK && event.getRepeatCount() == 0 && mWindow.isShowing()) {
                    dismiss();
                }
            }
        });
    }       

    mRootView.setOnTouchListener(new View.OnTouchListener() {

        @Override
        public boolean onTouch(View v, MotionEvent event) {
            if (event.getAction() == MotionEvent.ACTION_DOWN && mWindow.isShowing()) {
                dismiss();
                return true;
            }
            return false;
        }
    });

}

不要在此处设置任何可绘制对象:

protected void preShow() {
    if (mRootView == null) 
        throw new IllegalStateException("setContentView was not called with a view to display.");

    onShow();

    mWindow.setWidth(WindowManager.LayoutParams.WRAP_CONTENT);
    mWindow.setHeight(WindowManager.LayoutParams.WRAP_CONTENT);
    mWindow.setTouchable(true);
    mWindow.setFocusable(true);
    mWindow.setOutsideTouchable(true);

    mWindow.setContentView(mRootView);
}

接下来的一切都是经典

自定义相对布局:

public class CustomRelativeLayout extends RelativeLayout {

public CustomRelativeLayout(Context context, AttributeSet attrs, int defStyle) {
    super(context, attrs, defStyle);
}

public CustomRelativeLayout(Context context, AttributeSet attrs) {
    super(context, attrs);
}

public CustomRelativeLayout(Context context) {
    super(context);
}

private OnDispatchKeyEventListener mOnDispatchKeyEventListener;



public void setDispatchKeyEventListener(OnDispatchKeyEventListener listener) {
    mOnDispatchKeyEventListener = listener;
}

@Override
public boolean dispatchKeyEvent(KeyEvent event) {
    if (mOnDispatchKeyEventListener != null) {
        mOnDispatchKeyEventListener.onDispatchKeyEvent(event);
    }
    return super.dispatchKeyEvent(event);
}

@Override
public boolean onTouchEvent(MotionEvent event) {
    return super.onTouchEvent(event);
}   

public static interface OnDispatchKeyEventListener {
    public void onDispatchKeyEvent(KeyEvent event);
}
}

popup_vertical.xml 和 popup_horizo​​ntal.xml:

只需使用 com.your.package.CustomRelativeLayout 而不是顶级 RelativeLayout

希望这会有所帮助

于 2012-06-07T22:58:35.170 回答
0

这个答案现在很老了。我得出的解决方案是这个问题是由 Quickaction Library istelf 引起的。我的解决方案是使用不同的库。

这是不同的,但它也很好用。该库还具有更多功能。

看看: http: //greendroid.cyrilmottier.com/

于 2012-02-05T16:36:41.270 回答
0

您必须在 UI 线程上执行一些昂贵的操作。我建议您将这些操作移至单独的非 UI 线程。发布更多代码以识别疼痛区域。

于 2011-08-01T09:24:38.460 回答