Подтвердить что ты не робот

Почему вызов заканчивается(), вызывая onCreate() для вызова, начиная новое действие?

(Да, я уже рассмотрел существующие вопросы, связанные с этой проблемой.)

Я вызываю finish() из прослушивателя кнопки Activity Up. Но хотя onDestroy() действительно приближается к вызову, сначала вызывается onPause(), а затем, что удивительно, onCreate(), что вызывает реальные проблемы. Почему новый ScanningActivity запускается вызовом метода finish() ScanningActivity?

Я регистрирую вызовы всех функций жизненного цикла, и порядок таков:

 inside onClick() Listener for up button.
         Inside onPause()
         Inside onCreate()  // this is what hosing everything
         Inside onStart()
         Inside onResume()
         Inside onWindowFocusChanged()
         Inside onStop()
         Inside onDestroy()

Почему я получаю эту последовательность событий после вызова finish()? Здесь код ScanningActivity, который вызывает finish(), заметьте в прослушивателе onclick (который назначен в методе onCreate()):

@Override
public void onCreate(Bundle savedInstanceState)
{
    . . .

    button.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) 
        {
            Log.i("ScanningActivity", "inside onClick() -- Listener for up button being executed.");

            android.widget.LinearLayout layt = (android.widget.LinearLayout) vCustView;

            View vTemp = layt.findViewById(R.id.scanning_up);
            if (null != vTemp)
            {
                Button btnUp = (Button) vTemp;
                if (!btnUp.getText().equals("End"))  
                {
                    setResult(RESULT_CANCELED);

                    finish();
                    return;
                }
            }
         }
    . . .
}

В соответствии с запросом Каракури вот манифест:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.calypso.myandroid">

    <uses-permission android:name="android.permission.INTERNET" />
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
    //
    <uses-permission android:name="android.permission.SET_DEBUG_APP" />
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />

        <uses-feature android:name="android.hardware.camera" />
        <uses-feature android:name="android.hardware.camera.autofocus" />

        <uses-permission android:name="android.permission.CAMERA" />

    <application
        android:allowBackup="true"
        android:icon="@drawable/ail_logo"
        android:label="@string/app_name"
        android:theme="@style/AssistTheme">
        <activity
            android:name=".HomeScreenActivity"
            android:label="@string/title_activity_home_screen"
            android:screenOrientation="portrait">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <activity
            android:name=".GradeActivity"
            android:label="@string/title_activity_grade_assessment"
            android:screenOrientation="portrait"
            android:parentActivityName=".HomeScreenActivity"
            android:noHistory="true"
            />
        <activity
            android:name=".ScanningActivity"
            android:label="@string/title_activity_scanning"
            android:screenOrientation="portrait"
            android:parentActivityName=".GradeActivity"
            />
    </application>


</manifest>

... и вот код вызова, который изначально запускает ScanningActivity из GradeActivity:

if (bFinishedSuccessfully)
{
    try
    {
        Log.i("GradeActivity", "SOMEHOW THIS IS AGAIN STARTING THE ScanningActivity!!!");

        Intent intent = new Intent(this, ScanningActivity.class);
        intent.putExtra("SessionInfo", m_hmActivate);
        startActivity(intent);
    }
    catch (Exception ex)
    {
        Log.i("GradeActivity", "ex: " + ex.getMessage());
    }
}

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

4b9b3361

Ответ 1

Я думаю, что проблема в вашем манифесте, параметры android:noHistory="true", добавленные в GradeActivity. setResult() в ScanningActivity попытается создать родительскую активность класса GradeActivity. Я думаю, что если вам не нужно сохранять GradeActivity в вашем стеке навигации, вам нужно запустить ScanningActivity из вашей HomeScreenActivity, используя startActivityForResult.

Ответ 2

Используйте setResult (RESULT_OK); вместо setResult (RESULT_CANCELED); внутри прослушивателя Click.

Как

@Override
public void onCreate(Bundle savedInstanceState)
{
    . . .

    button.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) 
        {
            Log.i("ScanningActivity", "inside onClick() -- Listener for up button being executed.");

            android.widget.LinearLayout layt = (android.widget.LinearLayout) vCustView;

            View vTemp = layt.findViewById(R.id.scanning_up);
            if (null != vTemp)
            {
                Button btnUp = (Button) vTemp;
                if (!btnUp.getText().equals("End"))  
                {
                    setResult(RESULT_OK);

                    finish();
                    return;
                }
            }
         }
    . . .
}