[Android] Fix the handling of orientation changes for the Fragments related to the game list. Now screen orientation changes don't kick you back to the root view.

This commit is contained in:
Lioncash 2013-11-16 01:48:17 -05:00
parent e8a4cc0f71
commit 777b5a109b
1 changed files with 23 additions and 17 deletions

View File

@ -9,7 +9,7 @@ package org.dolphinemu.dolphinemu.gamelist;
import android.app.Activity; import android.app.Activity;
import android.app.AlertDialog; import android.app.AlertDialog;
import android.app.Fragment; import android.app.Fragment;
import android.app.FragmentManager; import android.app.FragmentTransaction;
import android.content.DialogInterface; import android.content.DialogInterface;
import android.content.Intent; import android.content.Intent;
import android.content.res.Configuration; import android.content.res.Configuration;
@ -23,6 +23,7 @@ import android.view.MenuItem;
import android.view.View; import android.view.View;
import android.widget.AdapterView; import android.widget.AdapterView;
import android.widget.ListView; import android.widget.ListView;
import org.dolphinemu.dolphinemu.AboutFragment; import org.dolphinemu.dolphinemu.AboutFragment;
import org.dolphinemu.dolphinemu.NativeLibrary; import org.dolphinemu.dolphinemu.NativeLibrary;
import org.dolphinemu.dolphinemu.R; import org.dolphinemu.dolphinemu.R;
@ -103,10 +104,16 @@ public final class GameListActivity extends Activity
}; };
mDrawerLayout.setDrawerListener(mDrawerToggle); mDrawerLayout.setDrawerListener(mDrawerToggle);
// Display the game list fragment. // Display the game list fragment on activity creation,
mCurFragment = new GameListFragment(); // but only if no previous states have been saved.
FragmentManager fragmentManager = getFragmentManager(); if (savedInstanceState == null)
fragmentManager.beginTransaction().replace(R.id.content_frame, mCurFragment).commit(); {
mCurFragment = new GameListFragment();
FragmentTransaction ft = getFragmentManager().beginTransaction();
ft.replace(R.id.content_frame, mCurFragment);
ft.commit();
}
// Create an alert telling them that their phone sucks // Create an alert telling them that their phone sucks
if (Build.CPU_ABI.contains("arm") && !NativeLibrary.SupportsNEON()) if (Build.CPU_ABI.contains("arm") && !NativeLibrary.SupportsNEON())
@ -151,8 +158,9 @@ public final class GameListActivity extends Activity
mCurFragmentNum = 0; mCurFragmentNum = 0;
mCurFragment = new GameListFragment(); mCurFragment = new GameListFragment();
FragmentManager fragmentManager = getFragmentManager(); FragmentTransaction ft = getFragmentManager().beginTransaction();
fragmentManager.beginTransaction().replace(R.id.content_frame, mCurFragment).commit(); ft.replace(R.id.content_frame, mCurFragment);
ft.commit();
invalidateOptionsMenu(); invalidateOptionsMenu();
} }
break; break;
@ -161,8 +169,10 @@ public final class GameListActivity extends Activity
{ {
mCurFragmentNum = 1; mCurFragmentNum = 1;
mCurFragment = new FolderBrowser(); mCurFragment = new FolderBrowser();
FragmentManager fragmentManager = getFragmentManager(); FragmentTransaction ft = getFragmentManager().beginTransaction();
fragmentManager.beginTransaction().replace(R.id.content_frame, mCurFragment).commit(); ft.replace(R.id.content_frame, mCurFragment);
ft.addToBackStack(null);
ft.commit();
invalidateOptionsMenu(); invalidateOptionsMenu();
} }
break; break;
@ -178,8 +188,10 @@ public final class GameListActivity extends Activity
{ {
mCurFragmentNum = 3; mCurFragmentNum = 3;
mCurFragment = new AboutFragment(); mCurFragment = new AboutFragment();
FragmentManager fragmentManager = getFragmentManager(); FragmentTransaction ft = getFragmentManager().beginTransaction();
fragmentManager.beginTransaction().replace(R.id.content_frame, mCurFragment).commit(); ft.replace(R.id.content_frame, mCurFragment);
ft.addToBackStack(null);
ft.commit();
invalidateOptionsMenu(); invalidateOptionsMenu();
} }
break; break;
@ -281,10 +293,4 @@ public final class GameListActivity extends Activity
return super.onOptionsItemSelected(item); return super.onOptionsItemSelected(item);
} }
@Override
public void onBackPressed()
{
SwitchPage(0);
}
} }