Диалоговое окно оповещения вызывает сбой приложения при выборе параметра (Android) - PullRequest
0 голосов
/ 23 января 2012

Просто хочу, чтобы все знали, что это первое приложение, которое я пытаюсь создать. Поэтому, если я задам глупые вопросы, я прошу прощения Я пытаюсь создать диалоговое окно с предупреждением, которое вернет номер для использования позже в приложении. Диалоговое окно отображается на эмуляторе, но при выборе одного из параметров приложение вылетает.

01-22 17:37:43.925: I/Process(443): Sending signal. PID: 443 SIG: 9
01-22 17:52:47.395: D/dalvikvm(480): GC_EXTERNAL_ALLOC freed 42K, 53% free 2550K/5379K, external 1625K/2137K, paused 48ms
01-22 17:53:01.145: W/KeyCharacterMap(480): No keyboard for id 0
01-22 17:53:01.145: W/KeyCharacterMap(480): Using default keymap: /system/usr/keychars/qwerty.kcm.bin
01-22 17:53:02.205: D/AndroidRuntime(480): Shutting down VM
01-22 17:53:02.205: W/dalvikvm(480): threadid=1: thread exiting with uncaught exception (group=0x40015560)
01-22 17:53:02.225: E/AndroidRuntime(480): FATAL EXCEPTION: main
01-22 17:53:02.225: E/AndroidRuntime(480): java.lang.NumberFormatException: unable to parse 'null' as integer
01-22 17:53:02.225: E/AndroidRuntime(480):  at java.lang.Integer.parseInt(Integer.java:356)
01-22 17:53:02.225: E/AndroidRuntime(480):  at java.lang.Integer.parseInt(Integer.java:332)
01-22 17:53:02.225: E/AndroidRuntime(480):  at com.ciltild.mtgcardsandrules.PlayerTools.setAlertVar(PlayerTools.java:81)
01-22 17:53:02.225: E/AndroidRuntime(480):  at com.ciltild.mtgcardsandrules.PlayerTools$1.onClick(PlayerTools.java:41)
01-22 17:53:02.225: E/AndroidRuntime(480):  at com.android.internal.app.AlertController$ButtonHandler.handleMessage(AlertController.java:159)
01-22 17:53:02.225: E/AndroidRuntime(480):  at android.os.Handler.dispatchMessage(Handler.java:99)
01-22 17:53:02.225: E/AndroidRuntime(480):  at android.os.Looper.loop(Looper.java:123)
01-22 17:53:02.225: E/AndroidRuntime(480):  at android.app.ActivityThread.main(ActivityThread.java:3683)
01-22 17:53:02.225: E/AndroidRuntime(480):  at java.lang.reflect.Method.invokeNative(Native Method)
01-22 17:53:02.225: E/AndroidRuntime(480):  at java.lang.reflect.Method.invoke(Method.java:507)
01-22 17:53:02.225: E/AndroidRuntime(480):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
01-22 17:53:02.225: E/AndroidRuntime(480):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
01-22 17:53:02.225: E/AndroidRuntime(480):  at dalvik.system.NativeStart.main(Native Method)

Ниже приведен код для диалогового окна предупреждения:

    @Override
protected Dialog onCreateDialog(int id){
    switch(id){

    case playerLifeDialog:
        LayoutInflater factory = LayoutInflater.from(this);
        final View playerSetLifeView = factory.inflate(R.layout.toolslifedialog, null);
        return new AlertDialog.Builder(PlayerTools.this)
            .setTitle("Set Life to:")
            .setView(playerSetLifeView)
            .setPositiveButton("Add", new DialogInterface.OnClickListener() {
                public void onClick(DialogInterface dialog, int addButton) {
                    setAlertVar(toolsDialogText);
                    tempLifeVar = alertVar + playerLifeVar;
                }
            })
            .setNegativeButton("Subtract", new DialogInterface.OnClickListener() {
                public void onClick(DialogInterface dialog, int setButton) {
                    setAlertVar(toolsDialogText);
                    tempLifeVar = playerLifeVar - alertVar;
                }
            })
            .setNeutralButton("Set", new DialogInterface.OnClickListener() {
                public void onClick(DialogInterface dialog, int subButton) {
                    setAlertVar(toolsDialogText);
                    tempLifeVar = alertVar;
                }
            })
            .create();
        default:
    }
    return null;
}

Я потратил неделю на просмотр вопросов, которые задавали другие, и на документе для разработчиков Google, чтобы попытаться выяснить это. Если бы я знал больше о Java, я уверен, что это не было бы так сложно. Но я застрял на этом слишком долго. Кроме того, это моя вторая попытка создания этого приложения. Буду очень признателен за любую помощь.

Это код setAlertVar:

public void setAlertVar(String toolsDialogText) throws NumberFormatException{
    alertVar = Integer.parseInt(toolsDialogText);
}

Ответы [ 2 ]

0 голосов
/ 23 января 2012

где устанавливают значение для toolsDialogText перед передачей его в setAlertVar (toolsDialogText);

Так что, если вы не устанавливаете его, оно имеет нулевое значение, которое не может быть проанализировано классом Integer ...Лучшая проверка для

`if (! TextUtil.isEmpty (toolsDialogText)) {

alertVar = Integer.parseInt (toolsDialogText);

}

returnalertVar; `

0 голосов
/ 23 января 2012

Ваша проблема в методе setAlertVar(), в строке 81 (трудно сказать что-либо еще без кода setAlertVar ()):

 at com.ciltild.mtgcardsandrules.PlayerTools.setAlertVar(PlayerTools.java:81)

Если вы знаете, что у вас могут быть неправильные числа, попробуйтеокружающий код, который выдает исключение выше:

try {
  int b = Integer.parseInt(string);
} catch (Exception e) {
  //handle the exception if necessary
}
...