voidcome Posté(e) 15 mars 2012 Share Posté(e) 15 mars 2012 Bonjour, Je développe depuis un petit temps sur Android et je suis aujourd'hui confronté à un petit problème. En résumé, il y a plusieurs listes déroulante (Spinner) sur ma vue et jusqu'à maintenant, elles étaient remplis avec un tableau de String. Aujourd'hui, j'ai avancé dans la conception de mon application et je souhaiterais faire quelques changements. En effet, les informations qui doivent figurer dans ces listes sont issus de mes bases SQLite. Le problème, c'est qu'il faudrait que je puisse afficher les noms dans la liste, tout en obtenant l'id correspondant à la base SQLite. Par exemple, imaginons que ma table soit : departement_id | departement_ nom ------------------------------------------ 1 | truc 42 | machin 103 | chose Il faudrait que la liste déroulante affiche les noms uniquement : > truc > machin > chose Et que lorsque l'utilisateur sélectionne un champ, je puisse obtenir le numéro correspond pour pouvoir traiter les infos avec d'autres tables SQLite. (Il peut y avoir des doublons dans les noms, alors que l'id est unique, c'est donc nécessaire). Je peux facilement obtenir un tableau de String avec tous les noms de ma table SQLite, mais je ne vois pas comment associer chaque nom à un id. Pouvez-vous m'aider ? Actuellement, le bout de code pour associer un tableau de String à la liste est : final DepartmentBDD departmentLite = new DepartmentBDD(this); departmentLite.open(); // Récupération du tableau String[] tabDep = departmentLite.getAllString(); // Référence sur la liste déroulante final Spinner listeDep = (Spinner)findViewById(R.id.listeDepartement); // Affectation du tableau à la liste déroulante ArrayAdapter adDep = new ArrayAdapter(this, android.R.layout.simple_dropdown_item_1line, tabDep); listeDep.setAdapter(adDep); Merci d'avance. Citer Lien vers le commentaire Partager sur d’autres sites More sharing options...
chpil Posté(e) 16 mars 2012 Share Posté(e) 16 mars 2012 Il faut que tu puisses fournir l'id de tes données au spinner, afin que celui-ci puisse te le retourner quand l'utilisateur aura sélectionné une entrée Pour ce faire, il faut que tu récupères le cursor de la requête BDD, cursor que tu peux ensuite utiliser pour construire un SimpleCursorAdapter, que tu fournis ensuite au Spinner Ensuite, l'id de l'item sélectionné te sera fourni dans le OnItemClickedListener, ou en appelant la méthode getSelectedItemId du Spinner Par contre, petite contrainte, pour que le spinner puisse retrouver l'id, le nom de la colonne de cet id doit être "_id" Citer Lien vers le commentaire Partager sur d’autres sites More sharing options...
voidcome Posté(e) 18 mars 2012 Auteur Share Posté(e) 18 mars 2012 Merci pour ta réponse. Citer Lien vers le commentaire Partager sur d’autres sites More sharing options...
Recommended Posts
Rejoignez la conversation
Vous pouvez poster maintenant et vous enregistrez plus tard. Si vous avez un compte, connectez-vous maintenant pour poster.