voidcome Posted March 15, 2012 Share Posted March 15, 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. Quote Link to comment Share on other sites More sharing options...
chpil Posted March 16, 2012 Share Posted March 16, 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" Quote Link to comment Share on other sites More sharing options...
voidcome Posted March 18, 2012 Author Share Posted March 18, 2012 Merci pour ta réponse. Quote Link to comment Share on other sites More sharing options...
Recommended Posts
Join the conversation
You can post now and register later. If you have an account, sign in now to post with your account.