Я создал список со вставленным в него текстовым полем.Я хочу отобразить элементы, которые уже были нажаты, но я не могу найти решение для этого.
Я пытался изменить его в событии при нажатии, но, похоже, оно не работает.
ниже приведен класс занятий.
Надеюсь, что кто-то может мне помочь. Заранее признателен за помощь
Моя деятельность
package com.example.tastease;
import android.content.SharedPreferences;
import android.support.annotation.NonNull;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.AdapterView;
import android.widget.ArrayAdapter;
import android.widget.ListView;
import android.widget.TextView;
import com.google.firebase.database.DataSnapshot;
import com.google.firebase.database.DatabaseError;
import com.google.firebase.database.DatabaseReference;
import com.google.firebase.database.FirebaseDatabase;
import com.google.firebase.database.ValueEventListener;
import java.util.ArrayList;
public class CheckAvailability extends AppCompatActivity {
ArrayList<String> selectedItems = new ArrayList<>();
ArrayList<String> items = new ArrayList<>();
private String UserID;
public static final String MY_PREFS_NAME = "MyPrefsFile";
private DatabaseReference database;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_check_availability);
SharedPreferences prefs = getSharedPreferences(MY_PREFS_NAME, MODE_PRIVATE);
UserID = prefs.getString("userid", "No ID defined");
ListView list1 = findViewById(R.id.check_list);
list1.setChoiceMode(ListView.CHOICE_MODE_MULTIPLE);
database = FirebaseDatabase.getInstance().getReference();
DatabaseReference useref = database.child(UserID).child("Item Details");
final DatabaseReference checkref = database.child(UserID).child("Availability");
final ArrayAdapter<String> adapter = new ArrayAdapter<>(this,R.layout.rowlayout,R.id.txt_lan,items);
list1.setAdapter(adapter);
list1.setOnItemClickListener(new AdapterView.OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
String selectedItem = ((TextView)view).getText().toString();
if(selectedItems.contains(selectedItem)){
selectedItems.remove(selectedItem);
database.child(UserID).child("Availability").child(selectedItem).setValue("0");
}else {
selectedItems.add(selectedItem);
database.child(UserID).child("Availability").child(selectedItem).setValue("1");
}
}
});
checkref.addListenerForSingleValueEvent(new ValueEventListener() {
@Override
public void onDataChange(@NonNull DataSnapshot dataSnapshot) {
for(DataSnapshot ds : dataSnapshot.getChildren()) {
if(ds.getValue().equals("1")){
items.add(ds.getKey());
adapter.notifyDataSetChanged();
}
}
}
@Override
public void onCancelled(@NonNull DatabaseError databaseError) {
}
});
}
public void getselectedItems(View view) {
}
}
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:orientation="vertical"
android:layout_height="match_parent"
tools:context=".CheckAvailability">
<ListView
android:id="@+id/check_list"
android:layout_width="match_parent"
android:layout_height="wrap_content"></ListView>
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/btn2"
android:layout_gravity="center"
android:text="Save Products"
android:onClick="getselectedItems"/>
</LinearLayout>