【发布时间】:2019-09-16 03:06:38
【问题描述】:
我有一个如下所示的 Sqlite 表。
我已经用 rawQuery 列出了一个列表:SELECT HEADER FROM MyData GROUP BY HEADER
ArrayAdapter arrayAdapter;
ArrayList<String> listItem = new ArrayList<>();
final ListView listView = (ListView) view.findViewById(R.id.list);
SQLiteDatabase sqLiteDatabase =
SqliteDatabase.getInstance(this.getContext()).getWritableDatabase();
Cursor cursor = sqLiteDatabase.rawQuery("SELECT HEADER FROM MyData GROUP BY
HEADER", new String[]{});
if (cursor.getCount() == 0) {
Toast.makeText(getActivity(), "No Data to show",
Toast.LENGTH_LONG).show();
} else {
while (cursor.moveToNext()) {
listItem.add(cursor.getString(0));
}
arrayAdapter = new ArrayAdapter<>(getActivity(),
android.R.layout.simple_list_item_1, listItem);
listView.setAdapter(arrayAdapter);
列表如下:
Letter
Number
Word
我的问题是当我点击列表项假设(Letter)时,SwipeViews 显示A,
当点击Number SwipeViews 显示B 和
当点击Word SwipeViews 显示C
我想得到,when I will click on Letter, SwipeViews will show only A,B,C
when I will click on Number, SwipeViews will show only 1,2,3
when I will click on Word, SwipeViews will show only Apple, Orange and Banana
这是 OnClickListener
listView.setOnItemClickListener(new OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> adapterView, View view, int i,
long l) {
Intent intent=new Intent(getActivity(), SwipeNav.class);
intent.putExtra(ID_EXTRA, String.valueOf(l));
startActivity(intent);
}
});
这是来自寻呼机适配器
public class MyPagerAdapter extends FragmentStatePagerAdapter {
private Context context;
public MyPagerAdapter(FragmentManager fm, Context context) {
super(fm);
this.context= context;}
@Override
public Fragment getItem(int i) {
ArrayList<String> listItem = new ArrayList<String>();
SQLiteDatabase sqLiteDatabase =
SqliteDatabase.getInstance(context).getWritableDatabase();
Cursor cursor = sqLiteDatabase.rawQuery("SELECT NAME FROM MyData", new
String[]{});
if (cursor.getCount() == 0) {
} else {
while (cursor.moveToNext()) {
listItem.add(cursor.getString(0));
}
}
Object[] mStringArray = listItem.toArray();
Fragment fragment = new AFragment();
Bundle args = new Bundle();
args.putString(AFragment.ARG_OBJECT, (String)mStringArray[i]);
fragment.setArguments(args);
return fragment;
}
在 SwipeNav Activity 中,我用下面来获取值
if (getIntent().hasExtra(ListNavAdapter.ID_EXTRA)){
String myInt = getIntent().getStringExtra(ListNavAdapter.ID_EXTRA);
listSwipePagerAdapter = new ListSwipePagerAdapter(getSupportFragmentManager(),this);
viewPager = (ViewPager) findViewById(R.id.pager);
viewPager.setAdapter(listSwipePagerAdapter);
【问题讨论】:
标签: android sqlite listview android-viewpager cursor