- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我有一个使用两个 fragment 的 Activity ,MainFragment
和 DetailFragment
。 MainFragment 有一个可扩展的 ListView ,其中公司名称作为组,位置名称作为子项。当用户从抽屉导航中选择一个类别时,它会更新适配器中的数据并更新可扩展列表,以显示正确的公司。
当用户选择一个位置时,它会打开包含有关该位置和员工信息的 DetailFragment。我遇到的问题是当我退后一步时。当我点击后退按钮时,它会重置为默认类别,我发现这是因为它再次调用了 onViewCreated()
方法,这是我设置 View 和适配器的地方。奇怪的是,它会记住哪些列表项是按索引展开的。因此,如果我在不同的类别中展开第三项,则默认类别中的第三项仍会展开。
我想知道的是,我怎样才能让它保持我按下后退时的设置?
我的主要 fragment
public class MainFragment extends Fragment implements ExpandableListView.OnChildClickListener, NavigationSelectedListener {
private CompaniesExpandableListAdapter adapter;
public MainFragment() {
// Required empty public constructor
}
@Override
public void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
}
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
// Inflate the layout for this fragment
return inflater.inflate(R.layout.fragment_main, container, false);
}
@Override
public void onViewCreated(View view, @Nullable Bundle savedInstanceState) {
super.onViewCreated(view, savedInstanceState);
connectViews(view);
}
private void connectViews(View view) {
final ExpandableListView companyListView = (ExpandableListView) view.findViewById(R.id.companyListView);
final Navigation navigationItem = ((MainActivity) getActivity()).getNavigationItems().first();
getActivity().setTitle(navigationItem.getTitle());
adapter = new CompaniesExpandableListAdapter(navigationItem.getCompanies());
companyListView.setAdapter(adapter);
companyListView.setOnChildClickListener(this);
}
// ExpandableListView.OnChildClickListener
@Override
public boolean onChildClick(ExpandableListView parent, View v, int groupPosition, int childPosition, long id) {
final DetailFragment detailFragment = new DetailFragment();
final Bundle args = new Bundle();
args.putInt(getString(R.string.extra_location_key), ((Locations) adapter.getChild(groupPosition, childPosition)).getPrimaryKey());
detailFragment.setArguments(args);
getFragmentManager()
.beginTransaction()
.replace(R.id.contentFrame, detailFragment, getString(R.string.tag_fragment_detail))
.addToBackStack(null)
.commit();
return false;
}
// NavigationSelectedListener
@Override
public void onNavigationItemSelected(Navigation navigationItem) {
// Go back to the main fragment.
getFragmentManager().popBackStack(getString(R.string.tag_fragment_main), FragmentManager.POP_BACK_STACK_INCLUSIVE);
// Send the selected item to the adapter.
adapter.updateData(navigationItem.getCompanies());
getActivity().setTitle(navigationItem.getTitle());
}
}
还有我的 MainActivity
public class MainActivity extends AppCompatActivity implements NavigationView.OnNavigationItemSelectedListener {
private NavigationSelectedListener navigationCallback;
private DrawerLayout drawerLayout;
private RealmResults<Navigation> navigationItems;
private MainFragment mainFragment = new MainFragment();
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
buildNavigationDrawer();
connectViews();
}
@Override
public void onBackPressed() {
if (drawerLayout.isDrawerOpen(GravityCompat.START)) drawerLayout.closeDrawer(GravityCompat.START);
else super.onBackPressed();
}
@Override
public boolean onNavigationItemSelected(@NonNull MenuItem item) {
navigationCallback.onNavigationItemSelected(navigationItems.get(item.getItemId()));
drawerLayout.closeDrawer(GravityCompat.START);
return true;
}
private void connectViews() {
navigationCallback = mainFragment;
getFragmentManager()
.beginTransaction()
.replace(R.id.contentFrame, mainFragment, getString(R.string.tag_fragment_main))
.commit();
}
private void buildNavigationDrawer() {
final Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
setSupportActionBar(toolbar);
drawerLayout = (DrawerLayout) findViewById(R.id.drawer_layout);
final ActionBarDrawerToggle toggle = new ActionBarDrawerToggle(this, drawerLayout, toolbar, R.string.navigation_drawer_open, R.string.navigation_drawer_close) {
@Override
public void onDrawerStateChanged(int newState) {
super.onDrawerStateChanged(newState);
// Hides the device keyboard when the navigation drawer is opened.
if (getCurrentFocus() != null) ((InputMethodManager) getSystemService(INPUT_METHOD_SERVICE)).hideSoftInputFromWindow(getCurrentFocus().getWindowToken(), 0);
}
};
drawerLayout.addDrawerListener(toggle);
toggle.syncState();
fillNavigationDrawer();
}
public RealmResults<Navigation> getNavigationItems() {
return navigationItems;
}
}
最佳答案
您应该在交易中使用add
而不是replace
。
关于android - 在 PopBackStack 上保留数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43647555/
我尝试使用 Android Navigation 组件并遇到了回栈问题。 我有 fragment A,B。 我写的: Navigation.findNavController(view).naviga
应用有 Viewpager,它有 四个标签 和 fragment 。第二个 fragment 具有框架布局“FL”,我将 fragment 与 ListView 放在一起。当用户单击 ListView
我在 fragment A 中有一个 edittext,用于在类别列表中进行静态搜索。当我用 fragment B 替换 fragment A 并单击返回按钮 edittext 仍然显示我在替换 fr
在我的应用程序中,我使用的是 BottomBar 菜单。快速选择菜单时,我会收到有关 crashlytics 的崩溃报告(仅在某些设备中)。这是堆栈跟踪 Non-fatal Exception: ja
我有两个 fragment 。 SecondFragment 和 ThirdFragment。实际上,我使用导航组件在 fragment 之间传递值。像这样: 第二个 fragment : val a
我有一个 Activity A。 Activity A 调用 fragment frag1。 frag1 调用 fragment frag2。最后 frag2 调用 frag3。 当我点击frag3中
我在使用 Fragments 并将它们弹出时遇到了一个奇怪的问题。 我有一个 fragment Activity : 第1步:我在名为Fragment A的Starting中的该Activity的on
我有一个 Activity ,我正在调用三个 fragment - 每个 fragment 相互依赖: A(ctivity) -> f1( fragment 一,标题 {is|should}:列表)-
情况 我提交数据setTripDeliver ,收集工作正常(触发加载,然后成功)。我按下一个按钮转到下一个 fragment B(使用 replace )。之后,我按下返回按钮(使用 popback
我在 SO 上看到了许多 popbackstack 问题,根据我的代码,我尝试做的事情看起来应该可行。 public class MainActivity extends ActionBarActiv
当我启动应用程序时(今天 = 30),结果是正确的。但是,如果我转到另一个 fragment 并使用后退按钮 (popbackstack),则day_of_month 的值始终为 1。 其余的总是正确
在我的应用程序中,我使用了 android 抽屉导航。基本上,它工作正常。在该用户中,用户可以使用抽屉导航导航到关于我们、主页等 fragment 。但是当我在标题栏上实现后退按钮时,它会打开抽屉导航
我正在使用 NavController:Navigation.findNavController(activity, R.id.statistic_host_fragment)。一切都很好,直到我旋转
我正在开发一个包含很多 fragment 的 Android 应用程序。但是我在它们之间切换时遇到了问题。 假设我有一个 fragment A,现在我想转到 fragment B,为此我这样做 --
我有两个 fragment A 和 B。 我已经使用以下代码从 A 切换到 B: FragmentManager fragmentManager; FragmentTransactio
我有一个主要的 TabActivity,它有两个选项卡,A 和 B(目前)。选项卡 A 加载一个 FragmentActivity(下面给出的代码),它只包含一个 FrameLayout,因此我可以在
我在 Activity 的 onCreate() 方法中调用了 popBackStack(),但是我得到了异常: Caused by java.lang.IllegalStateException:
我有一个使用两个 fragment 的 Activity ,MainFragment 和 DetailFragment。 MainFragment 有一个可扩展的 ListView ,其中公司名称作为
我想在打开和关闭时为 fragment 设置动画。我有淡入和淡出自定义动画 XML 文件。 我在我的支持 FragmentTransaction 上使用 setCustomAnimations,但它所
我遇到了一个问题,即我有一个包含多个 fragment 的 Activity。对于任何单个 fragment ,您可以执行搜索操作,效果很好......如果您从任何 fragment 中搜索,它将显示
我是一名优秀的程序员,十分优秀!