0

我已经编写了一个活动,Theme.Holo.Dialog以便它可以作为AlertDialog登录/密码通知。我startActivityForResult(...)使用我定义的请求代码开始了这项活动。问题是,每当我开始活动时onActivityResult(...)立即触发,按钮被加载并且一切,但是一旦我按下它们,即使我知道活动正在工作,因为登录确实发生了,没有结果发送回第一个活动和我正在打电话setResult(...)finish()在按下按钮后。在此先感谢,第一次使用 startActivityForResult 所以我确定我一定遗漏了一些东西。

主要活动:

.
.
.
   Intent startDialogIntent = new Intent(this,SetIdDialogAlertActivity.class);
   startDialogIntent.setAction(getString(R.string.ACTION_START_ALERT_DIALOG_ACTIVITY));
   startDialogIntent.putExtra(getString(R.string.parcelable_status));
   IntentParcelable.configurationToParcelable(configuration, getBaseContext()));
   startActivityForResult(startDialogIntent,getResources().getInteger(R.integer.CREATE_USER));

.
.
.

public void onActivityResult(int requestCode, int resultCode,Intent data){
        super.onActivityResult(requestCode, resultCode, data);
        Toast.makeText(getBaseContext(),"returned from activity with request code " + requestCode + " and result code " + resultCode, Toast.LENGTH_SHORT).show();
        if(requestCode == getResources().getInteger(R.integer.CREATE_USER))
            switch (resultCode){
                case RESULT_NEW_USER:
                    Toast.makeText(getBaseContext(),getString(R.string.SU_CorrectPassword_message), Toast.LENGTH_SHORT).show();
                    refreshLabels(data);
                    break;
                case RESULT_WRONG_PASSWORD:
                    Toast.makeText(getBaseContext(),getString(R.string.SU_WrongPassword_message), Toast.LENGTH_SHORT).show();
                    break;
            }
    }

然后在子活动上:

public void onCreate(Bundle savedInstanceState){
        Logger.d(Messages.tag,System.nanoTime() + "_DIALOG_ALERT:_ON_CREATED");
        super.onCreate(savedInstanceState);
        setContentView(R.layout.user_id_alertdialog);
        Logger.d(Messages.tag,System.nanoTime() + "_DIALOG_ALERT:_VIEW_INFLATED");

        SU_passwordEditText = (EditText)findViewById(R.id.SU_passwordEditText);
        Button okAlarmButton = (Button)findViewById(R.id.okAlarmButton);
        Button cancelAlarmButton = (Button)findViewById(R.id.cancelAlarmButton);

        Logger.d(Messages.tag,System.nanoTime() + "_DIALOG_ALERT:_OK_BUTTON_LOADED");
        okAlarmButton.setOnClickListener(new View.OnClickListener() {

            public void onClick(View v) {
                Logger.d(Messages.tag,System.nanoTime() + "_DIALOG_ALERT:_OK_BUTTON_PRESSED");  
                String password = SU_passwordEditText.getText().toString();
                if(password.equals(getString(R.string.SU_password))){
                    Toast.makeText(getBaseContext(),getString(R.string.SU_CorrectPassword_message), Toast.LENGTH_SHORT).show();
                    userIdEditText = (EditText)findViewById(R.id.userIdEditText);
                    String newUserName = userIdEditText.getText().toString();
                    Logger.d(Messages.tag,System.nanoTime() + "_DIALOG_ALERT:_USERNAME_" + newUserName);                
                    Configuration configuration = IntentParcelable.parcelableToConfiguration((IntentParcelable)getIntent().getParcelableExtra(getString(R.string.parcelable_status))
                            , getBaseContext());
                    configuration.setId(newUserName);
                    Intent setUserIntent = new Intent();
                    setUserIntent.setAction(getString(R.string.ACTION_ACTIVITY_NEW_ID));
                    setUserIntent.putExtra(getString(R.string.INTENT_EXTRA_SENDER_NAME),"DIALOG_ACTIVITY");
                    setUserIntent.putExtra(getString(R.string.INTENT_EXTRA_NEW_CONFIG), IntentParcelable.configurationToParcelable(configuration, getBaseContext()));
                    exitActivity(RESULT_NEW_USER,setUserIntent);
                }else{
                    Toast.makeText(getBaseContext(),getString(R.string.SU_WrongPassword_message), Toast.LENGTH_SHORT).show();
                    exitActivity(RESULT_WRONG_PASSWORD);
                }
            }
        });

private void exitActivity(int exit_code, Intent data) {
    setResult(exit_code,data);
    finish();
}

private void exitActivity(int exit_code) {
    setResult(exit_code);
    finish();
}

很抱歉延迟发布代码。

[更新]

我已经尝试了所有我能想到的方法,但子 Activity 的行为仍然很奇怪。onActivityResult(...)自从父母触发以来,我认为它突然结束了。它没有完成,因为它仍然在堆栈的顶部,我可以看到它,并且它确实有效,因为我在Buttons 中实现的任何东西都完成了。但是当它再次完成时,它不会触发前一个onActivityResult(...)方法。

[更新]

一定是错过了什么。为了测试起见,我刚刚创建了一个全新Activity的 ,它除了创建自己之外什么都不做,将结果设置为 4 并完成。我在清单上声明为:

        <activity 
            android:name=".ActivityTest"
            android:screenOrientation="portrait"
            android:process=":gui_process"
            android:exported="false">
        </activity>

并像这样开始:

            Intent startDialogIntent = new Intent(this,ActivityTest.class);
            startActivityForResult(startDialogIntent,getResources().getInteger(R.integer.CREATE_USER));

在 my 上定义了一个新的 case 语句onActivityResult(...),它的行为就像原始活动一样。

4

1 回答 1

0

我在另一个线程中发现了这个问题。显然singleInstance,为其启动模式定义一个活动会导致子活动在启动后立即向父活动报告结果。我将父活动的启动模式恢复为标准,现在一切正常。开发者指南中应该有一些国王的注释。

于 2012-10-31T08:46:27.083 回答