Как я могу получить данные JSON и сохранить в базе данных, а затем отображать в пользовательском списке адаптеров?Android

Форум для тех, кто программирует под Android
Ответить
Anonymous
 Как я могу получить данные JSON и сохранить в базе данных, а затем отображать в пользовательском списке адаптеров?

Сообщение Anonymous »

import java.io.IOException;
import java.util.ArrayList;
import java.util.List;

import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.client.ClientProtocolException;
import org.apache.http.client.HttpClient;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.DefaultHttpClient;
import org.apache.http.util.EntityUtils;
import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;

import sereen.sql.Info;
import sereen.sql.InfoServicesNew;
import android.os.AsyncTask;
import android.os.Bundle;
import android.app.Activity;
import android.app.ProgressDialog;
import android.content.Intent;
import android.util.Log;
import android.view.Menu;
import android.view.View;
import android.view.Window;
import android.widget.AdapterView;
import android.widget.ArrayAdapter;
import android.widget.ListView;
import android.widget.Toast;
import android.widget.AdapterView.OnItemClickListener;

public class PenddingOrders extends Activity {
ArrayList info = new ArrayList();

int imgPendding = R.drawable.ex2;
ListView list;
ProgressDialog pd;
ArrayAdapter adapter;
private String defValue = "N/A";

InfoServicesNew databaseHelper;
String name = InfoServicesNew.DB_TABLE_NAME;
static int img[]={R.drawable.ex2,R.drawable.ex2,R.drawable.ex2,R.drawable.ex2,
R.drawable.ex2,R.drawable.ex2,R.drawable.ex2,R.drawable.ex2, R.drawable.ex2,
R.drawable.ex2};
String data;
Intent o;
int position;
Object object;

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_pendding_orders);

databaseHelper = new InfoServicesNew(this);

list = (ListView)findViewById(R.id.listView1);
pd = new ProgressDialog(this);

new asy().execute("http://jsonblob.com/api/jsonBlob/53021f ... ce1677329a");
}

@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.pendding_orders, menu);
return true;
}

public class asy extends AsyncTask
{
@Override
protected ArrayList doInBackground(String... params) {
// TODO Auto-generated method stub

//activity is defined as a global variable in your AsyncTask

try {
HttpClient hc = new DefaultHttpClient();
HttpGet hg = new HttpGet(params[0]);
HttpResponse hr = hc.execute(hg);
HttpEntity he = hr.getEntity();
data = EntityUtils.toString(he);
Log.i("data", data);
}
catch (ClientProtocolException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
catch (IOException e)
{
// TODO Auto-generated catch block
e.printStackTrace();
}

ArrayList sereenlist = new ArrayList();
sereenlist = getJSONData(data);

return sereenlist;
}

private ArrayList getJSONData(String data) {
// TODO Auto-generated method stub

ArrayList rs = null;

try {
JSONObject obj = new JSONObject(data);
JSONArray finalObj = obj.optJSONArray("orders");

for (int i = 0; i < finalObj.length(); i++)
{
final String orderNumber = finalObj.optJSONObject(i).optString(
"order-number");
final String orderAmount = finalObj.optJSONObject(i).optString(
"order-amount");
final String date = finalObj.optJSONObject(i).optString(
"date");
final String client = finalObj.optJSONObject(i).optString(
"client");
final String upperLimit = finalObj.optJSONObject(i).optString(
"upper-limit");
final String debt = finalObj.optJSONObject(i).optString(
"debt");

long id1=databaseHelper.insert(new Info(client,orderAmount,date ,orderNumber,upperLimit,debt));

if(id1 < 0)
{
Toast.makeText(getApplicationContext(), "unsuccessfull add", Toast.LENGTH_LONG).show();
}
else
{
Toast.makeText(getApplicationContext(), "done", Toast.LENGTH_LONG).show();
}
}

rs = databaseHelper.selectAll();

databaseHelper.close();
Log.i("size", finalObj.length()+"");
}//try end
catch (JSONException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}

return rs;
}

@Override
protected void onPreExecute() {
// TODO Auto-generated method stub
super.onPreExecute();
pd.setTitle("fetching");
pd.setMessage("waiting...");
pd.show();
}

@Override
protected void onPostExecute(ArrayList result) {
// TODO Auto-generated method stub

SetAdapterList(result);

pd.dismiss();
}

private void SetAdapterList(ArrayList result)
{
// TODO Auto-generated method stu

CustomAdapter adapter=new CustomAdapter(getApplicationContext(),result);
list.setAdapter(adapter);
}
}
}
< /code>
Что я хочу сделать, это получить все данные JSON по ссылке и показать в logCat. Я получаю это успешно, а затем пытаюсь вставить его в базу данных, используя Dbhelper и Info Class, которые содержат Getters и Setters для всех значений. Тем не менее, каждый раз, когда я запускаю код, я получаю: < /p>
02-19 01:09:34.490: E/AndroidRuntime(1210): Caused by: java.lang.RuntimeException: Can't create handler inside thread that has not called Looper.prepare()


Подробнее здесь: https://stackoverflow.com/questions/218 ... om-adapter
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Android»