我有5个片段:
-
TimerFragment
-
CounterFragment
-
GameFragment
-
NoteFragment
-
SettingsFragment
SettingsFragment
有4个开关,可控制其他4个片段的添加/删除。关闭开关会删除片段并将其打开会添加它。
问题是,当我尝试删除前4个片段中的任何一个时,ViewPager会删除SettingsFragment
。我只能在关闭并重新启动应用程序时看到更改。
同样,当我将删除的片段添加回列表中时,它添加了新的SettingsFragment
。再次,我必须关闭并重新启动我的应用以查看适当的更改。
这很奇怪,没有错误可以帮助我弄清楚是什么原因引起的。我想知道为什么会发生这种情况以及如何解决。谢谢。
这是我的代码:
在这里,我添加了片段:
frags = new String[]{".TimerFragment", ".CounterFragment", ".GameFragment",
".NoteFragment", ".SettingsFragment"};
final Bundle args = new Bundle();
boolean[] showArray = new boolean[4];
for (int i = 0; i < frags.length; i++) {
if (frags[i].equals(".SettingsFragment")) {
args.putBooleanArray("showing", showArray);
fragments.add(frags[i]);
} else {
boolean showing = sharedPrefs.getBoolean("Tooly" + frags[i] + ".Show",
true);
showArray[i] = showing;
if (showing) fragments.add(frags[i]);
}
fragIds[i] = View.generateViewId();
}
这是我的FragmentPagerAdapter
vpTools.setAdapter(new FragmentPagerAdapter(getSupportFragmentManager()) {
@Override
public Fragment getItem(int position) {
try {
Fragment fragment = (Fragment) Class.forName(getPackageName() +
fragments.get(position)).newInstance();
if (fragments.get(position).equals(".SettingsFragment"))
fragment.setArguments(args);
return fragment;
} catch (InstantiationException | IllegalAccessException |
ClassNotFoundException e) {
e.printStackTrace();
}
return null;
}
@Override
public int getItemPosition(@NonNull Object object) {
return POSITION_NONE;
}
@Override
public long getItemId(int position) {
return fragIds[position];
}
@Override
public int getCount() {
return fragments.size();
}
});
这是我添加和删除片段的代码:
@SuppressLint("ApplySharedPref")
@Override
public void onSettingChanged(int pos, boolean checked) throws Exception {
if (checked && !frags[pos].equals(fragments.get(pos))) fragments.add(pos, frags[pos]);
else if (!checked) fragments.remove(pos);
vpTools.getAdapter().notifyDataSetChanged();
sharedPrefs.edit().putBoolean("Tooly" + frags[pos] + ".Show", checked).commit();
}
如果您想知道为什么我有一个字符串列表并正在实例化pageradapter本身的新片段,那是因为我试图避免避免在您尝试添加片段相同的实例时发生的IllegalstateException,而不是更多一次。这里有几个问题:
IllegalstateException:无法更改片段的标签...
也有相同错误...
i还为每个片段都有一系列唯一的ID,每次调用getItemId()
时都会返回。这也是为了避免例外。
问题是我每次都相同的片段ID。关键是每次返回一个新的唯一ID。这是getItemId()
的更新代码:
@Override
public long getItemId(int position) {
return View.generateViewId();
}
generateViewId()
方法每次都会生成并返回一个新的独特的,非刷新的视图ID。