Création d'un clic de SimpleCursorAdapter
Question
J'utilise ce code pour obtenir des données de la base de données et les afficher directement dans la liste personnalisée qui s'affiche correctement.Voici comment je l'ai fait en utilisant SimpleCursorAdapter
public void queryArticles(String querytext,Context mContext)
{
SQLiteDatabase db=this.getWritableDatabase();
Cursor cur=null;
String strquery="select rowid _id,part,A_name,italic,AS_name,Desc_art from Articles where AS_name LIKE '%"+querytext+"%'";
cur=db.rawQuery(strquery,null);
if(cur!=null&&cur.getCount() > 0)
{
do
{
String[] fromColumns = { "part", "A_name", "italic", "AS_name" };
int[] toViews = { R.id.textView1, R.id.textView2, R.id.textView3, R.id.textView4 };
SimpleCursorAdapter adapter = new SimpleCursorAdapter(mContext,R.layout.query_cell, cur, fromColumns, toViews, 0);
QueryFragment.listview1.setAdapter(adapter);
}
while(cur.moveToNext());
}
}
J'ai essayé de le faire en cliquant sur ceci
QueryFragment.listview1.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
}
});
à l'intérieur de la boucle while, en dehors de la condition if, dans mon activité également mais cela me donne cette exception.
07-29 13:24:22.970: E/AndroidRuntime(25608): FATAL EXCEPTION: main
07-29 13:24:22.970: E/AndroidRuntime(25608): java.lang.RuntimeException: Don't call setOnClickListener for an AdapterView. You probably want setOnItemClickListener instead
07-29 13:24:22.970: E/AndroidRuntime(25608): at android.widget.AdapterView.setOnClickListener(AdapterView.java:780)
07-29 13:24:22.970: E/AndroidRuntime(25608): at com.vivekwarde.indianconstitution.QueryFragment.onCreateView(QueryFragment.java:48)
07-29 13:24:22.970: E/AndroidRuntime(25608): at android.support.v4.app.Fragment.performCreateView(Fragment.java:1500)
07-29 13:24:22.970: E/AndroidRuntime(25608): at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:938)
07-29 13:24:22.970: E/AndroidRuntime(25608): at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1115)
07-29 13:24:22.970: E/AndroidRuntime(25608): at android.support.v4.app.BackStackRecord.run(BackStackRecord.java:682)
07-29 13:24:22.970: E/AndroidRuntime(25608): at android.support.v4.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:1478)
07-29 13:24:22.970: E/AndroidRuntime(25608): at android.support.v4.app.FragmentManagerImpl$1.run(FragmentManager.java:446)
07-29 13:24:22.970: E/AndroidRuntime(25608): at android.os.Handler.handleCallback(Handler.java:615)
07-29 13:24:22.970: E/AndroidRuntime(25608): at android.os.Handler.dispatchMessage(Handler.java:92)
07-29 13:24:22.970: E/AndroidRuntime(25608): at android.os.Looper.loop(Looper.java:137)
07-29 13:24:22.970: E/AndroidRuntime(25608): at android.app.ActivityThread.main(ActivityThread.java:4794)
07-29 13:24:22.970: E/AndroidRuntime(25608): at java.lang.reflect.Method.invokeNative(Native Method)
07-29 13:24:22.970: E/AndroidRuntime(25608): at java.lang.reflect.Method.invoke(Method.java:511)
07-29 13:24:22.970: E/AndroidRuntime(25608): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:789)
07-29 13:24:22.970: E/AndroidRuntime(25608): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:556)
07-29 13:24:22.970: E/AndroidRuntime(25608): at dalvik.system.NativeStart.main(Native Method)
Alors, j'ai utilisé setOnItemClickListener
comme ça
listview1.setOnItemSelectedListener(new OnItemSelectedListener() {
public void onItemSelected(AdapterView<?> arg0, View arg1, int arg2,
long arg3) {
Log.v("hi","not getting called ? ");
}
public void onNothingSelected(AdapterView<?> arg0) {
}
});
Mais l'événement setOnItemSelectedListener n'est toujours pas déclenché, une idée, comment résoudre ce problème ?
La solution
Votre problème est ici..
new OnItemSelectedListener() {
public void onItemSelected(AdapterView<?> arg0, View arg1, int arg2,.....
Change-le simplement en
listview1.setOnItemClickListener(new OnItemClickListener(){
public void onItemClick(AdapterView<?> parent, View view, int position, long id){
//do your task
}
}
Ici position
vous aidera à découvrir l'élément sélectionné..donc pas besoin de drainer le cerveau sélectionné et non sélectionné..
Autres conseils
Essayez de cette façon, j'espère que cela vous aidera à résoudre votre problème.
ListeView
listView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
}
});
Fileur
spinner.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() {
@Override
public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {
}
@Override
public void onNothingSelected(AdapterView<?> parent) {
}
});
N'importe quelle vue comme (bouton, TextView, ImageView, etc.)
yourView.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
}
});