ボタンが押されたときにいくつかのダイアログを次々に表示しようとしていますが、2番目を表示できません。最初のものは、開発中の検証プロセスを置き換えるための単なる開発スタブです...
@Override
public void onCreate(Bundle savedInstanceState)
{
<snip>
btnLogin.setOnClickListener(new View.OnClickListener()
{
public void onClick(View v)
{
<snip>
VerifyLogin(userName,
password);
}
});
}
...と...
private void VerifyLogin(String userName,
String password)
{
boolean ok = false;
if ((userName.length() > 0) && (password.length() > 0))
ok = DevStub(); // <- Mimics server validation, allows dev. to choose success or not
<snip>
}
...と...
private boolean DevStub()
{
new AlertDialog.Builder(this)
.setTitle("DEVELOPMENT")
.setMessage("Login: Successful or Not")
.setPositiveButton("Successful",
<snip>
)
.setNegativeButton("Not Successful",
new DialogInterface.OnClickListener()
{
public void onClick(DialogInterface dialog, int which)
{
new AlertDialog.Builder(getApplicationContext())
.setTitle("Invalid Username/Password")
.setMessage("Try Again or Recover your password")
.setPositiveButton( <snip> )
.setNegativeButton( <snip> )
.show();
}
})
.show();
return success;
}
私が言うように、これは私がインターフェイスを開発している間だけであり、DevStub() は実際のログイン検証に置き換えられますが、ここで何が間違っているのかを理解したいと思います. 「失敗」ボタンをタップすると、単に例外が発生します。
内部ダイアログの getApplicationContext() と関係があると思いますが、やはりわかりません-何か提案はありますか?
ログキャット:
E/SKIA(12620): FimgApiStretch:stretch failed
D/AndroidRuntime(12620): Shutting down VM
W/dalvikvm(12620): threadid=1: thread exiting with uncaught exception (group=0x40c581f8)
E/AndroidRuntime(12620): FATAL EXCEPTION: main
E/AndroidRuntime(12620): android.view.WindowManager$BadTokenException: Unable to add window -- token null is not for an application
E/AndroidRuntime(12620): at android.view.ViewRootImpl.setView(ViewRootImpl.java:706)
E/AndroidRuntime(12620): at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:316)
E/AndroidRuntime(12620): at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:218)
E/AndroidRuntime(12620): at android.view.WindowManagerImpl$CompatModeWrapper.addView(WindowManagerImpl.java:143)
E/AndroidRuntime(12620): at android.app.Dialog.show(Dialog.java:278)
E/AndroidRuntime(12620): at android.app.AlertDialog$Builder.show(AlertDialog.java:932)
E/AndroidRuntime(12620): at com.mtbsoft.wud.LoginActivity$2.onClick(LoginActivity.java:62)
E/AndroidRuntime(12620): at com.android.internal.app.AlertController$ButtonHandler.handleMessage(AlertController.java:168)
E/AndroidRuntime(12620): at android.os.Handler.dispatchMessage(Handler.java:99)
E/AndroidRuntime(12620): at android.os.Looper.loop(Looper.java:137)
E/AndroidRuntime(12620): at android.app.ActivityThread.main(ActivityThread.java:4514)
E/AndroidRuntime(12620): at java.lang.reflect.Method.invokeNative(Native Method)
E/AndroidRuntime(12620): at java.lang.reflect.Method.invoke(Method.java:511)
E/AndroidRuntime(12620): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:993)
E/AndroidRuntime(12620): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:760)
E/AndroidRuntime(12620): at dalvik.system.NativeStart.main(Native Method)
D/dalvikvm(12620): GC_CONCURRENT freed 148K, 4% free 13223K/13639K, paused 2ms+4ms