Ir para conteúdo

Arquivado

Este tópico foi arquivado e está fechado para novas respostas.

ma_gr

Melhor abordagem neste caso (Android app)

Recommended Posts

Seguinte, estou desenvolvendo um app como experiencia e gostaria de saber de quem tem mais experiencia no desenvolvimento android, sobre qual seria a melhor abordagem:

 

O aplicativo seria semelhante ao de busca de restaurantes na cidade de interesse do usuário:

 

- Tenho a activity 1 com um EditText onde o usuário digita o Estado em que se encontra; esse dado é recebido na activity 2;

- A activity 2 recebe esse dado no topo e tem mais um EditText pro usuário digitar a cidade que deseja;

- Esses dois dados são transmitidos pra activity 3 que, de acordo com eles, vai resultar nos restaurantes que a cidade em questão possui e que serão exibidos num ListView;

 

Nada complicado, mas tenho dúvidas quanto à melhor opção de desenvolvimento.

Fiz um banco de dados php/mysql com wampserver e tudo já funciona usando uma navegação padrão no browser. Agora só falta no aplicativo.

 

Pensei em duas abordagens até agora. O que seria melhor?

- Fazer um json encode no arquivo php final? Se sim, é possível relacionar os dados vindos dos EditText e comparar no banco de dados pra apresentar os restaurantes de acordo com a Cidade em questão? Ou devo fazer um json encode em cada arquivo (o de busca Estado.php, o de busca Cidade.php e no listaeventos.php)?

 

- Ou seria melhor por comandos sql dentro da activity 3, ir buscar os dados no servidor e comparar pra apresentar os resultados corretos?!

Compartilhar este post


Link para o post
Compartilhar em outros sites

Bom, aí vai a solução que usei:

 

PS: o arquivo php acima na questão é lista_restaurantes.php, erro meu.

package com.habitodigital.restaurantes;

import java.io.BufferedReader;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.util.ArrayList;

import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.NameValuePair;
import org.apache.http.client.HttpClient;
import org.apache.http.client.entity.UrlEncodedFormEntity;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.impl.client.DefaultHttpClient;
import org.json.JSONArray;
import org.json.JSONObject;

import android.app.Activity;
import android.app.ProgressDialog;
import android.content.DialogInterface;
import android.content.DialogInterface.OnCancelListener;
import android.os.AsyncTask;
import android.os.Bundle;
import android.util.Log;
import android.view.Menu;
import android.view.MenuItem;
import android.widget.ArrayAdapter;
import android.widget.ListView;
import android.widget.TextView;
import android.widget.Toast;

public class ListRestaurantes extends Activity {
	
	private ListView listV;
	TextView estado, cidade, noRestaurante;
	
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_list_restaurantes);
		
		listV = (ListView) findViewById(R.id.listRest);
		
		estado = (TextView) findViewById(R.id.Estado);
		cidade = (TextView) findViewById(R.id.Cidade);
		noRestaurante = (TextView) findViewById(R.id.noRest);
		
		estado.setText(getIntent().getExtras().getString("state"));		
		cidade.setText(getIntent().getExtras().getString("city"));
		
		//String resultStt = estado.getText().toString();
		//String resultCty = cidade.getText().toString();
		
		Task task = new Task();
		task.execute();
	}

	public class Task extends AsyncTask<String, String, Void>{

		private ProgressDialog progressDialog = new ProgressDialog(ListRestaurantes.this);
		
		InputStream is = null;
		String result = "";
		
		protected void onPreExecute() {
			progressDialog.setMessage("Listando Restaurantes...");
			progressDialog.show();
			progressDialog.setOnCancelListener(new OnCancelListener() {
				
				@Override
				public void onCancel(DialogInterface dialog) {
					Task.this.cancel(true);
				}
			});
		};
		
		@Override
		protected Void doInBackground(String... params) {
			
			String url = "http://meuIP/webviews/jsonlist.php";
			
			HttpClient httpClient = new DefaultHttpClient();
			HttpPost httpPost = new HttpPost(url);
			
			ArrayList<NameValuePair> param = new ArrayList<NameValuePair>();
			
			try {
				httpPost.setEntity(new UrlEncodedFormEntity(param));
				
				HttpResponse httpResponse = httpClient.execute(httpPost);
				HttpEntity httpEntity = httpResponse.getEntity();
				
				// ler o conteudo
				is = httpEntity.getContent();
				
			} catch (Exception e) {
				Log.e("log_tag", "Erro ao conectar com o banco de dados " + e.toString());
				Toast.makeText(ListRestaurantes.this, "Tente novamente.", Toast.LENGTH_LONG).show();
			}
			
			try
			{
				BufferedReader br = new BufferedReader(new InputStreamReader(is));
				StringBuilder sb = new StringBuilder();
				String line = "";
				
				while((line = br.readLine()) != null){
					sb.append(line+"\n");
				}
					is.close();
					result = sb.toString();
				
			}catch(Exception e){
				Log.e("log_tag", "Erro ao converter o resultado " + e.toString());
			}
			return null;
		}
		
		protected void onPostExecute(Void v){
			
			try {
				JSONArray Jarray = new JSONArray(result);
				for (int i = 0; i < Jarray.length(); i++) {
					JSONObject jsonObject = null;
					jsonObject = Jarray.getJSONObject(i);
					
					// output na tela
					String id = jsonObject.getString("id");
					String nome= jsonObject.getString("nome");
					String endereco - jsonObject.getString("endereco");
					String city = jsonObject.getString("city");
					String statee = jsonObject.getString("state");
										
					if(estado.getText().toString().equalsIgnoreCase(statee) && 
							cidade.getText().toString().equalsIgnoreCase(city)){
						
						String[] values = new String[] {nome, endereco};
						
						ArrayAdapter<String> adapter = new ArrayAdapter<String>(ListRestaurantes.this, android.R.layout.simple_list_item_1, values);
						
						listRest.setAdapter(adapter);
						break;
					}
					else{
						noRestaurante.setText("Nada encontrado no banco de dados");
					}
				}
				
				this.progressDialog.dismiss();
			} catch (Exception e) {
				Log.e("log_tag", "Error parsing data "+e.toString());
			}
		}
		
	}
	
	
	@Override
	public boolean onCreateOptionsMenu(Menu menu) {
		// Inflate the menu; this adds items to the action bar if it is present.
		getMenuInflater().inflate(R.menu.list_restaurantes, menu);
		return true;
	}
	
	@Override
	public boolean onOptionsItemSelected(MenuItem item) {
		// Handle action bar item clicks here. The action bar will
		// automatically handle clicks on the Home/Up button, so long
		// as you specify a parent activity in AndroidManifest.xml.
		int id = item.getItemId();
		if (id == R.id.action_settings) {
			return true;
		}
		return super.onOptionsItemSelected(item);
	}
}

estado é input da primeira activity.

cidade é input da segunda.

Os dois tem combinar com o resultado encontrado no bando de dados para listar os restaurantes. Caso contrário um TextView mostra a mensagem " Nada encontrado no banco de dados".

Compartilhar este post


Link para o post
Compartilhar em outros sites

×

Informação importante

Ao usar o fórum, você concorda com nossos Termos e condições.