2016-09-08 4 views
0

Так что это прослушивало меня как неделю, и я еще не нашел ответа.
В принципе у меня есть эта MainActivity, которая содержит основной код и фрагмент, которые работают для listview.Вставить значение флажка (ListView) в базу данных

MainActivity.java

public class MainActivity extends AppCompatActivity { 

private Handler handler = new Handler(); 
private Toolbar toolbar; 
private TabLayout tabLayout; 
private ViewPager viewPager; 
private Button bNext; 

@Override 
protected void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.activity_main); 

    toolbar = (Toolbar) findViewById(R.id.toolbar); 
    setSupportActionBar(toolbar); 

    getSupportActionBar().setDisplayHomeAsUpEnabled(false); 

    viewPager = (ViewPager) findViewById(R.id.viewpager); 
    setupViewPager(viewPager); 

    tabLayout = (TabLayout) findViewById(R.id.tabs); 
    tabLayout.setupWithViewPager(viewPager); 
} 

private void setupViewPager(ViewPager viewPager) { 
    ViewPagerAdapter adapter = new ViewPagerAdapter(getSupportFragmentManager()); 
    adapter.addFragment(new RoomServer(), "Room Server"); 
    viewPager.setAdapter(adapter); 
} 

class ViewPagerAdapter extends FragmentPagerAdapter { 
    private final List<Fragment> mFragmentList = new ArrayList<>(); 
    private final List<String> mFragmentTitleList = new ArrayList<>(); 

    public ViewPagerAdapter(FragmentManager manager) { 
     super(manager); 
    } 

    @Override 
    public Fragment getItem(int position) { 
     return mFragmentList.get(position); 
    } 

    @Override 
    public int getCount() { 
     return mFragmentList.size(); 
    } 

    public void addFragment(Fragment fragment, String title) { 
     mFragmentList.add(fragment); 
     mFragmentTitleList.add(title); 
    } 

    @Override 
    public CharSequence getPageTitle(int position) { 
     return mFragmentTitleList.get(position); 
    } 
} 

    } 

RoomServer.java

public class RoomServer extends ListFragment implements OnItemClickListener{ 
    public RoomServer() { 
     // Required empty public constructor 
    } 
    @Override 
    public View onCreateView(LayoutInflater inflater, ViewGroup container,  Bundle savedInstanceState) { 
     View view = inflater.inflate(R.layout.fragment_rs, container, false); 
     return view; 
    } 

    @Override 
    public void onActivityCreated(Bundle savedInstanceState) { 
     super.onActivityCreated(savedInstanceState); 
     getListView().setChoiceMode(getListView().CHOICE_MODE_MULTIPLE); 
     getListView().setTextFilterEnabled(true); 
     ArrayAdapter adapter = ArrayAdapter.createFromResource(getActivity(), R.array.rs_list, android.R.layout.simple_list_item_checked); 
     setListAdapter(adapter); 
     getListView().setOnItemClickListener(this); 
    } 

    @Override 
    public void onItemClick(AdapterView<?> parent, View view, int position, long id) { 
     Toast.makeText(getActivity(), "Item: " + position, Toast.LENGTH_SHORT).show(); 
    } 
} 

Fragment_rs.xml

<?xml version="1.0" encoding="utf-8"?> 
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    xmlns:tools="http://schemas.android.com/tools" 
    android:orientation="vertical" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" 
    tools:context=".fragments.RoomServer"> 

    <ListView 
     android:id="@android:id/list" 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content" > 
    </ListView> 

    <TextView 
     android:id="@android:id/empty" 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content" > 
    </TextView> 

    <Button 
     android:id="@+id/bNext_rs" 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content" 
     android:text="@string/next" 
     android:layout_marginRight="39dp" 
     android:layout_marginEnd="39dp" 
     android:layout_marginBottom="60dp" 
     android:layout_alignParentBottom="true" 
     android:layout_alignParentRight="true" 
     android:layout_alignParentEnd="true" /> 

</RelativeLayout> 

activity_main.xml

<android.support.design.widget.CoordinatorLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    xmlns:app="http://schemas.android.com/apk/res-auto" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent"> 

    <android.support.design.widget.AppBarLayout 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content" 
     android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"> 

     <android.support.v7.widget.Toolbar 
      android:id="@+id/toolbar" 
      android:layout_width="match_parent" 
      android:layout_height="?attr/actionBarSize" 
      android:background="?attr/colorPrimary" 
      app:layout_scrollFlags="scroll|enterAlways" 
      app:popupTheme="@style/ThemeOverlay.AppCompat.Light" > 
     </android.support.v7.widget.Toolbar> 

     <android.support.design.widget.TabLayout 
      android:id="@+id/tabs" 
      android:layout_width="match_parent" 
      android:layout_height="wrap_content" 
      app:tabMode="scrollable" 
      app:tabGravity="fill"/> 
    </android.support.design.widget.AppBarLayout> 

    <android.support.v4.view.ViewPager 
     android:id="@+id/viewpager" 
     android:layout_width="match_parent" 
     android:layout_height="match_parent" 
     app:layout_behavior="@string/appbar_scrolling_view_behavior" /> 
</android.support.design.widget.CoordinatorLayout> 

Элементы г объявили списке следует внутри strings.xml

Как вы можете видеть, я использую CHOICE_MODE_MULTIPLE создать флажок в окне списка. И теперь я зациклился на том, как получить значение этого флажка. Я планирую использовать Volley для отправки значения в мою базу данных нажатием кнопки. Большая часть ответа, который я видел, это использование isChecked и прочее, но я действительно не понимаю, как реализовать его в моем адаптере массива.

+0

что вы вмятины понять ischeckd? –

ответ

0

Вы можете реализовать пользовательский массив адаптер самостоятельно, или использовать this метод в классе ListView получить SparseBooleanArray из индексов выбранных элементов:

//Submit button example 
submitButton.setOnClickListener(new View.OnClickListener() { 
    public void onClick(View v) { 
     //Get base list 
     String[] items = getActivity().getResources().getStringArray(R.array.rs_list); 

     //Get selected items & set intent args 
     SparseBooleanArray selectedItems = getListView().getCheckedItemPositions(); 
     ArrayList<String> argList = new ArrayList<>(); 
     for (int i = 0; i < selectedItems.size(); i++) { 
      argList.add(items[selectedItems.keyAt(i)]); 
     } 

     //Start activity 
     Intent intent = new Intent(); 
     intent.putStringArrayListExtra("SelectedItems", argList); 
     getActivity().startActivity(intent); 
    } 
}); 
+0

Будет ли этот код работать для кнопки внутри фрагмента? – DonDon

+0

Да, я просто добавил кнопку в качестве общего примера, чтобы получить событие click, а затем обновить отмеченные элементы в базе данных. В этом примере он запускает новое действие, но в качестве альтернативы вы можете взять элементы из 'argList' и обновить свою базу данных. – ajplumlee33

Смежные вопросы