我写了一个游戏,用户输入玩家人数,每个玩家都有一个带有空表的选项卡。
因此,我使用了PagerAdapterClass
(扩展FragmentStatePagerAdapter
)和viewpager
。
因此,每个玩家都有相同的fragmentView
。
现在,用户可以将变量放入表中,但是每次我在选项卡之间切换时,输入都会丢失。 好吧,我通过将其添加到我的pageradapter中来“解决”了这个问题:
@Override
public void destroyItem(ViewGroup container, int position, Object object) {
}
但是比实际保存数据更能阻止viewpager破坏。
我的主要目标是将这些内容真正保存在该表中。
我已经尝试过https://stackoverflow.com/a/17135346/11956040,但是我无法获得mContent,因为我无法获取该片段的引用,因为不是所有片段都是单独创建的,而是同时创建的(或类似的东西)。
我也不知道如何设置标签。 这样:https://stackoverflow.com/a/18993042/11956040 对我不起作用。
MainActivity:
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_game);
Toolbar toolbar = findViewById(R.id.toolbar2);
setSupportActionBar(toolbar);
...
//numPlayer = num of tabs
SectionsPagerAdapter adapter = new SectionsPagerAdapter(numPlayer, getSupportFragmentManager());
ViewPager viewPager = findViewById(R.id.view_pager);
viewPager.setAdapter(adapter);
TabLayout tabs = findViewById(R.id.tabs);
tabs.setupWithViewPager(viewPager);
if(numPlayer >= 5) {
tabs.setTabMode(TabLayout.MODE_SCROLLABLE);
}
}
PagerAdapter:
public class SectionsPagerAdapter extends FragmentStatePagerAdapter {
private int tabNum;
public SectionsPagerAdapter(int tabNum, FragmentManager fm) {
super(fm);
this.tabNum = tabNum;
}
@Override
public PlaceholderFragment getItem(int position) {
return PlaceholderFragment.newInstance(position);
}
@Nullable
@Override
public CharSequence getPageTitle(int position) {
int playerNum = position + 1;
return "Spieler " + playerNum;
}
@Override
public int getCount() {
// Show 2 total pages.
return tabNum;
}
@Override
public void destroyItem(ViewGroup container, int position, Object object) {
}
}
片段:
public static PlaceholderFragment newInstance(int index) {
PlaceholderFragment fragment = new PlaceholderFragment();
Bundle bundle = new Bundle();
bundle.putInt("player", index);
fragment.setArguments(bundle);
return fragment;
}
必须有解决方案,但我找不到或无法实现。 请帮助。
答案 0 :(得分:0)
这样解决了我的问题:
private ArrayList<ArrayList<Integer>> columnArray;
private int column;
onCreateView
(对于片段)设置column = 0
并将一个带有空列表的条目添加到columnArray
并在列rowList
的列索引上设置第一个columnArray
:pointArray.add(column, new ArrayList<Integer>());
final ArrayList<Integer> rowList = pointArray.get(column);
用0填充空白rowList
(也许它也可以用其他方式工作,但是我这样做是为了使空白EditText上具有0并可以轻松替换它们)
为所有这样的EditText定义View.OnFocusChangeListener
:
/*I dont know if I could set column final in general,
but you need to set a final int because you call this value in an inner class*/
final int pos = column
for (int i = 0; i <= getEditTexts(pos).size() - 1; i++) {
EditText editTexts = getEditTexts(pos).get(i);
final String editTextsTag = editTexts.getTag().toString();
View.OnFocusChangeListener listener = new View.OnFocusChangeListener() {
@Override
public void onFocusChange(View view, final boolean b) {
if (view.getTag().toString().equals(editTextsTag) && !b) {
//fills rowList
addEntries(pos, rowList);
//adds rowList to columnArray
columnArray.set(pos, rowList);
//save the columnsArray or use it
saveData(columnArray);
}
}
};
editTexts.setOnFocusChangeListener(listener);
private void addEntries(int pos, ArrayList<Integer> rowList) {
for(int i = 0; i <= 16; i++) {
//this requires EditText_label, i made them dynamically
String edit_label = "edit_" + pos + i;
EditText editText = table.findViewWithTag(edit_label);
String mEditTextString = editText.getText().toString();
try {
int thisValue = Integer.parseInt(mEditString);
rowList.set(j, thisValue);
} catch (NumberFormatException e) {
//maybe you do not need this, but I need it for something else
int thisValue = 0;
rowList.set(j, thisValue);
}
}
}
columnArray
的方法。我使用了一个接口将其提供给父活动:Here you can find how I made it
否则,您可以将columnArray
转换为字符串并将其保存在数据库中。 注意
我设置了列值,是因为我使用一种方法增加了运行时添加的每列的值。如果只有一列,则无需设置。只需使用0代替pos列