1. java
  2. android
  3. c#
  4. .net
  5. javascript
  6. php
  7. jquery
  8. html
  9. sql

Usando Valores de Spinners Para Pesquisa Em um Banco de Dados

Bem explicarei meu problema direito, Eu tenho 3 spinners

1º - Possui valores "Escola, Hospital, Bairro"

3º - Possui valores "BairroA, BairroB,BairroC..."

Spinner1:

    lugar.add("Escola");
    lugar.add("Praca");
    lugar.add("Hospital");
    //Identifica o Spinner no layout

    spinner = (Spinner) findViewById(R.id.spinner);
    //Cria um ArrayAdapter usando um padrão de layout da classe R do android, passando o ArrayList lugar
    ArrayAdapter<String> arrayAdapter = new ArrayAdapter<String>(this, android.R.layout.simple_spinner_item, lugar);
    ArrayAdapter<String> spinnerArrayAdapter = arrayAdapter;
    spinnerArrayAdapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
     spinner.setAdapter(spinnerArrayAdapter);
    Spinner sp = (Spinner) findViewById(R.id.spinner);

Spinner3 ----(Este spinner3 só é preenchido quando alguém escolher alguma zona no spinner2)---

try {

    listaBairro = new ArrayList<Bairro>();

    listaBairro.add(new Bairro ("Bairro1", Zona.A));
    listaBairro.add(new Bairro ("Bairro2", Zona.A));
    listaBairro.add(new Bairro ("Bairro3", Zona.B));
    listaBairro.add(new Bairro ("Bairro4", Zona.B));
    listaBairro.add(new Bairro ("Bairro5", Zona.C));



    listazona = new ArrayList<String>();
    for (int i = 0; i < Zona.values().length; i++)
        listazona.add(Zona.values()[i].toString());

        listabairro = new ArrayList<String>();

        spinner1 = (Spinner) findViewById(R.id.spinner1);
        spinner2 = (Spinner) findViewById(R.id.spinner2);

        ArrayAdapter<String> arrayAdapter1 = new ArrayAdapter<String>(this, android.R.layout.simple_spinner_item, listazona);
        arrayAdapter1.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);spinner1.setAdapter(arrayAdapter1);

        spinner1.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() {
            public void onItemSelected(AdapterView<?> parent, View v, int posicao, long id) {

                //Só entra se a Zona escolhida for diferente do anterior

                if (!bairroToCompare.equals(parent.getItemAtPosition(posicao).toString())) {

                    //Se não estiver vazia, limpa os dados do 2º List

                    if (!listabairro.isEmpty())
                        listabairro.clear();

                    for (int i = 0; i < listaBairro.size(); i++) {

                        if (listaBairro.get(i).getZona().toString().equals(parent.getItemAtPosition(posicao).toString()))
                            listabairro.add(listaBairro.get(i).getBairro());
                    }

                    ArrayAdapter<String> arrayAdapter2 = new ArrayAdapter<String>(MainActivity.this, android.R.layout.simple_spinner_item, listabairro);
                    arrayAdapter2.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
                    spinner2.setAdapter(arrayAdapter2);

                }

                bairroToCompare = parent.getItemAtPosition(posicao).toString();
            }

            public void onNothingSelected(AdapterView<?> parent) { }
        });

} catch (Exception e) { }


@Override
protected void onRestart() {
    super.onRestart();
}

@Override
protected void onDestroy() {
    super.onDestroy();
}

Tenho 4 ClassesDAO(HospitalDAO, EscolaDAO, PracaDAO e BairroDAO). Cada um com seus respectivos query(s) e join(s). E uma classe DataBase. OS spinners estão funcionando direitinho.

Resumo da Obra, Como eu pego os valores desses 2 spinners (1 e 3) , pesquiso em um banco de dados e os resultados obtidos eu jogo em outra tela? Se possível me explicar com código usando os valores apresentados, pq eu sou iniciante em Android e demoro pra aprender..rs

  • Quando o usuário selecionar algo no Spinner3, o Spinner1 estará com algo selecionado?

    Felipe   23 de mai de 2013
  • sim. Escola, Hospital ou Praça!Ele tem que estar com 1 dos 3 selecionados :)

    Jéh Gomes   23 de mai de 2013
  1. Você vai ver essas setas em qualquer página de pergunta. Com elas, você pode dizer se uma pergunta ou uma resposta foram relevantes ou não.
  2. Edite sua pergunta ou resposta caso queira alterar ou adicionar detalhes.
  3. Caso haja alguma dúvida sobre a pergunta, adicione um comentário. O espaço de respostas deve ser utilizado apenas para responder a pergunta.
  4. Se o autor da pergunta marcar uma resposta como solucionada, esta marca aparecerá.
  5. Clique aqui para mais detalhes sobre o funcionamento do GUJ!

1 resposta

Não é a resposta que estava procurando? Procure outras perguntas com as tags android sql ou faça a sua própria pergunta.