monsieur, comment puis-je actualiser ma liste personnalisée à l'aide de baseadapter. Je ne sais pas quoi placer ni où le placer dans mon code. Aidez-moi, s'il vous plaît. Merci d'avance
public class EditDetails extends Activity{
public String nameChanged;
public String numChanged;
public String name;
public String num;
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.editdetails);
final EditText sqlName = (EditText)findViewById(R.id.editName);
final EditText sqlNumber = (EditText)findViewById(R.id.editNumber);
name = CustomListView.name;
num = CustomListView.number;
Button bUpdate = (Button)findViewById(R.id.editUpdate);
Button bView = (Button)findViewById(R.id.editView);
sqlName.setText(name);
sqlNumber.setText(num);
bUpdate.setOnClickListener(new OnClickListener() {
public void onClick(View arg0) {
nameChanged = sqlName.getText().toString();
numChanged = sqlNumber.getText().toString();
GroupDb info = new GroupDb(EditDetails.this);
info.open();
long rowid = info.getRowId(name, num);
info.updateNameNumber(rowid, nameChanged, numChanged);
ArrayList<Contact> searchResults = info.getView();
MyCustomBaseAdapter mcba = new MyCustomBaseAdapter(EditDetails.this, searchResults);
Toast.makeText(getApplicationContext(), "Update Successful!", Toast.LENGTH_LONG).show();
info.close();
}
});
bView.setOnClickListener(new OnClickListener() {
public void onClick(View arg0) {
Intent intent = new Intent();
intent.setClass(EditDetails.this, CustomListView.class);
startActivityForResult(intent, 0);
}
});
}
}
voici où j'ai affiché ma listview
public class CustomListView extends Activity {
final Context context = this;
public static String name;
public static String number;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
GroupDb info = new GroupDb(this);
info.open();
ArrayList<Contact> searchResults = info.getView();
final ListView lv = (ListView) findViewById(R.id.srListView);
lv.setAdapter(new MyCustomBaseAdapter(this, searchResults));
info.close();
lv.setOnItemClickListener(new OnItemClickListener() {
public void onItemClick(AdapterView<?> a, View v, int position, long id) {
// TODO Auto-generated method stub
Object o = lv.getItemAtPosition(position);
final Contact fullObject = (Contact)o;
AlertDialog.Builder alertDialogBuilder = new AlertDialog.Builder(context);
alertDialogBuilder
.setMessage("Select action")
.setCancelable(false)
.setPositiveButton("Edit", new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog,int id) {
Toast.makeText(getApplicationContext(), "Edit ", Toast.LENGTH_LONG).show();
name = fullObject.getName();
number = fullObject.getPhoneNumber();
Intent contactIntent = new Intent("myfolder.proj.EDITDETAILS");
startActivity(contactIntent);
}
})
et voici ma classe d'adaptateur de base
public class MyCustomBaseAdapter extends BaseAdapter {
private static ArrayList<Contact> searchArrayList;
private LayoutInflater mInflater;
public MyCustomBaseAdapter(Context context, ArrayList<Contact> results) {
searchArrayList = results;
mInflater = LayoutInflater.from(context);
}
public int getCount() {
return searchArrayList.size();
}
public Object getItem(int position) {
return searchArrayList.get(position);
}
public long getItemId(int position) {
return position;
}
public View getView(int position, View convertView, ViewGroup parent) {
ViewHolder holder;
if (convertView == null) {
convertView = mInflater.inflate(R.layout.custom_row_view, null);
holder = new ViewHolder();
holder.txtName = (TextView) convertView.findViewById(R.id.name);
holder.txtPhone = (TextView) convertView.findViewById(R.id.phone);
holder.status = (TextView) convertView.findViewById(R.id.status);
convertView.setTag(holder);
} else {
holder = (ViewHolder) convertView.getTag();
}
holder.txtName.setText(searchArrayList.get(position).getName());
holder.txtPhone.setText(searchArrayList.get(position).getPhoneNumber());
holder.status.setText(searchArrayList.get(position).getStatus());
return convertView;
}
static class ViewHolder {
TextView txtName;
TextView txtPhone;
TextView status;
}
}
Deux options: soit conserver la référence pour la ArrayList
que vous avez transmise au constructeur afin de pouvoir modifier les données de liste réelles ultérieurement (la liste n'étant pas copiée, la modification des données hors de l'adaptateur met toujours à jour le pointeur auquel l'adaptateur fait référence). , ou réécrivez l'adaptateur pour permettre à la liste d'être réinitialisée sur un autre objet.
Dans les deux cas, une fois que ArrayList
a changé, vous devez appeler notifyDataSetChanged()
pour mettre à jour votre ListView
avec les modifications. Cela peut être fait à l'intérieur ou à l'extérieur de l'adaptateur. Donc, par exemple:
public class MyCustomBaseAdapter extends BaseAdapter {
//TIP: Don't make this static, that's just a bad idea
private ArrayList<Contact> searchArrayList;
private LayoutInflater mInflater;
public MyCustomBaseAdapter(Context context, ArrayList<Contact> initialResults) {
searchArrayList = initialResults;
mInflater = LayoutInflater.from(context);
}
public void updateResults(ArrayList<Contact> results) {
searchArrayList = results;
//Triggers the list update
notifyDataSetChanged();
}
/* ...The rest of your code that I failed to copy over... */
}
HTH
créer une méthode personnalisée dans BaseAdapter
comme:
public void updateAdapter(ArrayList<Contact> arrylst) {
this.arrylst= arrylst;
//and call notifyDataSetChanged
notifyDataSetChanged();
}
et cet appel de fonction où vous voulez appeler: par exemple
adapterObject.updateAdapter (Ici passe ArrayList);
terminé.
Merci les gars avec la solution ci-dessus a fonctionné pour moi. J'appelle la méthode listupdate dans chaque événement
public void updateResults(List<TalebeDataUser> results) {
talebeList = results;
//Triggers the list update
notifyDataSetChanged();
}
et après la mise à jour de la liste, j'actualise également l'action de mon bouton à chaque contact. Par exemple, j'ai beaucoup de boutons à cliquer dans mon élément listview pour que chaque touche chate les autres
private void setColor(TalebeDataUser talebeDataUser) {
if (talebeDataUser.isVar()) {
holder.mVar.setBackgroundResource(R.drawable.aw_secili);
holder.mGorevli.setBackgroundResource(R.drawable.aw_shadow);
holder.mYok.setBackgroundResource(R.drawable.aw_shadow);
holder.mIzinli.setBackgroundResource(R.drawable.aw_shadow);
holder.mHatimde.setBackgroundResource(R.drawable.aw_shadow);
} else if (talebeDataUser.isGorevli()) {
holder.mVar.setBackgroundResource(R.drawable.aw_shadow);
holder.mGorevli.setBackgroundResource(R.drawable.aw_secili);
holder.mYok.setBackgroundResource(R.drawable.aw_shadow);
holder.mIzinli.setBackgroundResource(R.drawable.aw_shadow);
holder.mHatimde.setBackgroundResource(R.drawable.aw_shadow);
} else if (talebeDataUser.isYok()) {
holder.mVar.setBackgroundResource(R.drawable.aw_shadow);
holder.mGorevli.setBackgroundResource(R.drawable.aw_shadow);
holder.mYok.setBackgroundResource(R.drawable.aw_secili);
holder.mIzinli.setBackgroundResource(R.drawable.aw_shadow);
holder.mHatimde.setBackgroundResource(R.drawable.aw_shadow);
} else if (talebeDataUser.isIzinli()) {
holder.mVar.setBackgroundResource(R.drawable.aw_shadow);
holder.mGorevli.setBackgroundResource(R.drawable.aw_shadow);
holder.mYok.setBackgroundResource(R.drawable.aw_shadow);
holder.mIzinli.setBackgroundResource(R.drawable.aw_secili);
holder.mHatimde.setBackgroundResource(R.drawable.aw_shadow);
} else if (talebeDataUser.isHatimde()) {
holder.mVar.setBackgroundResource(R.drawable.aw_shadow);
holder.mGorevli.setBackgroundResource(R.drawable.aw_shadow);
holder.mYok.setBackgroundResource(R.drawable.aw_shadow);
holder.mIzinli.setBackgroundResource(R.drawable.aw_shadow);
holder.mHatimde.setBackgroundResource(R.drawable.aw_secili);
}
}
Juste un exemple dans l'un de mes boutons
holder.mYok.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
//talebeList.remove(currentTalebe);
setOgrenciNameByDurum(talebeList.get(i));
talebeList.get(i).setYok(true);
//setOgrenciNameByDurum(currentTalebe);
talebeList.get(i).setVar(false);
talebeList.get(i).setGorevli(false);
talebeList.get(i).setIzinli(false);
talebeList.get(i).setHatimde(false);
updateResults(talebeList);
setColor(talebeList.get(i));
//saveCurrentTalebeOnShare(currentTalebe);
}
});
talebeList est juste de List<MyModel> talebeList
Simplement avec BaseAdapter, pas besoin d'utiliser le contexte
listsOfNotes.remove(listsOfNotes.get(position));
notifyDataSetChanged();
il suffit de placer ce code sur setOnClickListner
J'ai résolu ce problème en ajoutant cette fonction à mon adaptateur personnalisé
public void newCursor(Cursor cursor)
{
this.cursor=cursor;
this.notifyDataSetChanged();
}
À partir de ma classe principale, je crée un nouveau curseur en effectuant une nouvelle requête dans la base de données, puis je l'envoie à mon adaptateur personnalisé Via cette fonction.
bonne chance