Irmãos,
Estou criando um formulário que contém os campos dinâmicos em sua quantidade e tipo.
Até aí beleza.
Mas estou com dois problemas.
1: Quando o meu formulário possui campos do Tipo Spinner não consigo enviar suas informações para o banco.
Os dados dos campos EditText estou pegando assim [code] infoAmostra.setVlInfo(editText[j].getEditableText().toString());[/code] e está retornando certinho.
Dúvida: Como pegar os IDs dos dados dos campos tipo Spinner?
2: Quando só possui campos do tipo EditText ele faz o upload somente do último campo.
Exemplo:
Possuo os Campos EditText Numero1 com o valor = 200 e logo abaixo o EditText Numero2 com o valor = 300.
O upload é realizado duas vezes com o valor do campo Numero2 ignorando o valor do Numero1
OBS: todos os dados do formulário serão salvos na mesma coluna da tabela.
Seguem as classes.
Método para realizar o upload
public boolean updateColeta(InfoAmostra infoAmostra, String idAmostra)
{
try {
String[] args = new String[]{idAmostra};
ContentValues valores = new ContentValues();
valores.put("VLINFO", infoAmostra.getVlInfo());
valores.put("FLOBRIGATORIO", infoAmostra.getFlObrigatorio());
int c= getWritableDatabase().update("INFOSAMOSTRA", valores, "CDAMOSTRA=? ", args);
if (c > 0) {
Log.i(CATEGORIA, "Dados cadastrados com sucesso!");
return true;
}
else
{
Log.i(CATEGORIA, "Erro ao cadastrar os dados!");
return false;
}
} catch (SQLException e) {
Log.i(CATEGORIA, "Erro SQLException no cadastro coleta" + e);
return false;
}
}
Parte do código com a chamada do método de upload
infoAmostra.setVlInfo(editText[j].getEditableText().toString());
infoAmostra.setFlObrigatorio("S");
if (coletaDao.updateColeta(infoAmostra, idAmostra)) {
Toast.makeText(TesteCadastroColeta_2.this, "OK", Toast.LENGTH_SHORT).show();
} else {
Toast.makeText(TesteCadastroColeta_2.this, "ERRO METODO UPDATE", Toast.LENGTH_SHORT).show();
}
Classe do formulário dinâmico completa
package br.com.mylims.controller;
import java.util.List;
import br.com.mylims.auxiliares.MeuSpinnerAdapter;
import br.com.mylims.bean.Info;
import br.com.mylims.bean.InfoAmostra;
import br.com.mylims.bean.OpcoesInfo;
import br.com.mylims.model.ColetaDao;
import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.view.ViewGroup.LayoutParams;
import android.widget.ArrayAdapter;
import android.widget.Button;
import android.widget.EditText;
import android.widget.LinearLayout;
import android.widget.RadioButton;
import android.widget.RadioGroup;
import android.widget.ScrollView;
import android.widget.Spinner;
import android.widget.Toast;
import android.widget.TextView;
public class TesteCadastroColeta_2 extends Activity{
private static final String CATEGORIA = "coleta";
private TextView nomeInfoTipo1;
private TextView nomeInfoTipo2;
private TextView nomeInfoTipo3;
private TextView nomeInfoTipo4;
private TextView nomeInfoTipo5;
private EditText[] editText;
private EditText[] texto;
private EditText[] numerico;
private EditText[] numericoFracionario;
private EditText[] dataHora;
private Spinner[] escolha;
// private List<OpcoesInfo> opcoesInfo;
ColetaDao coletaDao = new ColetaDao(this);
private InfoAmostra infoAmostra = new InfoAmostra();
public void onCreate(Bundle icicle){
super.onCreate(icicle);
Bundle extras = getIntent().getExtras();
final String idAmostra = extras.getString("idAmostra");
final List<Info> infos = coletaDao.listaColeta(idAmostra);
ScrollView s = new ScrollView(this);
s.setLayoutParams(new LayoutParams(LayoutParams.FILL_PARENT, LayoutParams.FILL_PARENT));
LinearLayout linearLayout = new LinearLayout(this);
linearLayout.setOrientation(LinearLayout.VERTICAL);
final int totalDados = coletaDao.listaColeta(idAmostra).size();
editText = new EditText[totalDados];
texto = new EditText[totalDados];
numerico = new EditText[totalDados];
dataHora = new EditText[totalDados];
numericoFracionario = new EditText[totalDados];
escolha = new Spinner[totalDados];
for (int i = 0; i < totalDados; i++){
try{
int recuperaTipoDado = infos.get(i).getCodTipoDado(); /**RECUPERA O ID DO TIPODADO**/
int recuperaIdInfo = infos.get(i).getCodInfo(); /**RECUPERA O CDINFO**/
/**CHAMA O METODO PARA POPULAR OS CAMPOS SPINNERS**/
nomeInfoTipo1 = new TextView(this);
nomeInfoTipo2 = new TextView(this);
nomeInfoTipo3 = new TextView(this);
nomeInfoTipo4 = new TextView(this);
nomeInfoTipo5 = new TextView(this);
editText[i] = new EditText(this); /**CAMPO DO TIPO TEXTO QUE RECEBERA OS SEGUINTES CAMPOS (1-TEXTO, 2-NUMERICO, 3-NUMERICO FRACIONARIO, 4-DATA E HORA)**/
texto[i] = new EditText(this); /**CAMPO DO TIPO TEXTO**/
numerico[i] = new EditText(this); /**CAMPO DO TIPO NUMERICO**/
numericoFracionario[i] = new EditText(this); /**CAMPO DO TIPO NUMERICO FRACIONARIO**/
dataHora[i] = new EditText(this); /**CAMPO DO TIPO **/
escolha[i] = new Spinner(this);
texto[i].setWidth(50);
numerico[i].setWidth(50);
numericoFracionario[i].setWidth(50);
dataHora[i].setWidth(50);
switch (recuperaTipoDado) {
case 1:
nomeInfoTipo1.setText(infos.get(i).getNomeInfo());
linearLayout.addView(nomeInfoTipo1);
editText[i] = texto[i];
editText[i].setText("");
editText[i].setHeight(40);
editText[i].setInputType(android.text.InputType.TYPE_CLASS_TEXT);
editText[i].setId(recuperaIdInfo);
linearLayout.addView(editText[i]);
break;
case 2:
nomeInfoTipo2.setText(infos.get(i).getNomeInfo());
linearLayout.addView(nomeInfoTipo2);
editText[i] = numerico[i];
editText[i].setText("");
editText[i].setHeight(40);
editText[i].setInputType(android.text.InputType.TYPE_CLASS_NUMBER);
editText[i].setId(recuperaIdInfo);
linearLayout.addView(editText[i]);
break;
case 3:
nomeInfoTipo3.setText(infos.get(i).getNomeInfo());
linearLayout.addView(nomeInfoTipo3);
editText[i] = numericoFracionario[i];
editText[i].setText("");
editText[i].setHeight(40);
editText[i].setInputType(android.text.InputType.TYPE_NUMBER_FLAG_DECIMAL);
editText[i].setId(recuperaIdInfo);
linearLayout.addView(editText[i]);
break;
case 4:
nomeInfoTipo4.setText(infos.get(i).getNomeInfo());
linearLayout.addView(nomeInfoTipo4);
editText[i] = dataHora[i];
editText[i].setText("");
editText[i].setHeight(40);
editText[i].setInputType(android.text.InputType.TYPE_CLASS_DATETIME);
editText[i].setId(recuperaIdInfo);
linearLayout.addView(editText[i]);
break;
case 5:
List<OpcoesInfo> opcInf = coletaDao.listaDadosSpinners(String.valueOf(recuperaIdInfo));
nomeInfoTipo5.setText(infos.get(i).getNomeInfo());
linearLayout.addView(nomeInfoTipo5);
ArrayAdapter adaptador = new ArrayAdapter(this, android.R.layout.simple_spinner_item, opcInf);
adaptador.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
escolha[i].setAdapter(new MeuSpinnerAdapter<OpcoesInfo>(this, opcInf, new String[] {"nomeOpcao" }));
linearLayout.addView(escolha[i]);
break;
} // fim swith
}catch (Exception ex) {
Log.i(CATEGORIA, "Exception ex" + ex + "FOR: " + (i));
}
} // fim for
LinearLayout linearLayout2 = new LinearLayout(this);
linearLayout2.setOrientation(LinearLayout.HORIZONTAL);
Button botaoCadastrar = new Button(this);
botaoCadastrar.setText("CADASTRAR");
linearLayout2.addView(botaoCadastrar);
Button botalVoltar = new Button(this);
botalVoltar.setText("VOLTAR");
linearLayout2.addView(botalVoltar);
/**BOTAO CADASTRAR**/
botaoCadastrar.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
try {
for (int j = 0; j < totalDados; j++)
{
int recuperaTipoDado = infos.get(j).getCodTipoDado(); /**RECUPERA O ID DO TIPODADO**/
int recuperaIdInfo = infos.get(j).getCodInfo(); /**RECUPERA O CDINFO**/
switch (recuperaTipoDado) {
case 1:
if (texto[j].getText().toString().equals("")) {
Toast.makeText(TesteCadastroColeta_2.this, "DIGITE UM TEXTO!", Toast.LENGTH_SHORT).show();
Log.i(CATEGORIA, "DIGITE UM TEXTO!");
}
break;
case 2:
if(numerico[j].getText().toString().equals("")){
Toast.makeText(TesteCadastroColeta_2.this, "DIGITE UM NÚMERO INTEIRO!", Toast.LENGTH_SHORT).show();
Log.i(CATEGORIA, "DIGITE UM NÚMERO INTEIRO!");
}
break;
case 3:
if (numericoFracionario[j].getText().toString().equals("")) {
Toast.makeText(TesteCadastroColeta_2.this, "DIGITE UM NÚMERO FRACIONÁRIO!", Toast.LENGTH_SHORT).show();
Log.i(CATEGORIA, "DIGITE UM NÚMERO FRACIONÁRIO!");
}
break;
case 4:
if (dataHora[j].getText().toString().equals("")) {
Toast.makeText(TesteCadastroColeta_2.this, "DIGITE UMA DATA!", Toast.LENGTH_SHORT).show();
Log.i(CATEGORIA, "DIGITE UMA DATA!");
}
break;
case 5:
// ARRUMAR
if (escolha[j].equals("")){
Toast.makeText(TesteCadastroColeta_2.this, "SELECIONE UMA OPÇÃO!", Toast.LENGTH_SHORT).show();
}
break;
} // fim with
// ATUALIZAR DADOS NO BANCO
infoAmostra.setVlInfo(editText[j].getEditableText().toString());
infoAmostra.setFlObrigatorio("S");
if (coletaDao.updateColeta(infoAmostra, idAmostra)) {
Toast.makeText(TesteCadastroColeta_2.this, "OK", Toast.LENGTH_SHORT).show();
} else {
Toast.makeText(TesteCadastroColeta_2.this, "ERRO METODO UPDATE", Toast.LENGTH_SHORT).show();
}
Log.i(CATEGORIA, "INFOAMOSTRA: " + infoAmostra);
Log.i(CATEGORIA, "ID INFO: " + recuperaIdInfo);
}
} catch (Exception e) {
Log.i(CATEGORIA, "Erro grave botao cadastroColeta" + e);
}
}
});
botalVoltar.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
//telaListaAmostra();
Log.i(CATEGORIA, "teste btn voltar");
}
});
linearLayout.addView(linearLayout2);
s.addView(linearLayout);
setContentView(s);
}
/**voltar para a tela de listagem das amostras**/
/*private void telaListaAmostra() {
Intent it = new Intent(this, CadastroUsuarioController.class);
startActivity(it);
}*/
}
Alguém consegue me ajudar?
Att