2013-03-11 81 views
3

我想使聊天室Android应用程序,我使用JSON作为webservices使用PHP,MYSQL &解析它在我的Android应用程序。最初我能够看到数据,但即使在更新数据库后,我也无法更新应用程序中的数据,但我必须重新运行应用程序以获取更新的数据。我如何解决这个问题。在Android中向数据库添加新数据后更新列表视图

代码:

package com.example.androidhive; 

import java.util.ArrayList; 
import java.util.HashMap; 
import java.util.List; 
import java.util.Timer; 

import org.apache.http.NameValuePair; 
import org.json.JSONArray; 
import org.json.JSONException; 
import org.json.JSONObject; 

//import com.mekya.R; 

import android.app.ListActivity; 
import android.app.ProgressDialog; 
import android.content.Intent; 
import android.os.AsyncTask; 
import android.os.Bundle; 
import android.util.Log; 
import android.view.View; 
import android.widget.AdapterView; 
import android.widget.AdapterView.OnItemClickListener; 
import android.widget.EditText; 
import android.widget.ListAdapter; 
import android.widget.ListView; 
import android.widget.SimpleAdapter; 
import android.widget.TextView; 

public class AllProductsActivity extends ListActivity { 

    // Progress Dialog 
    private ProgressDialog pDialog; 

    // Creating JSON Parser object 
    JSONParser jParser = new JSONParser(); 

    ArrayList<HashMap<String, String>> all_chat; 

    // url to get all products list 
    private static String url_all_products = "http://url.com/chat-app/"; 

    // JSON Node names 
    private static final String TAG_CHAT = "chat"; 
    private static final String TAG_FROM = "from_u"; 
    private static final String TAG_MESSAGE = "message"; 
    private static final String TAG_DATE = "date"; 


    // products JSONArray 
    JSONArray chat = null; 

    @Override 
    public void onCreate(Bundle savedInstanceState) { 
     super.onCreate(savedInstanceState); 
     setContentView(R.layout.all_products); 

     // Hashmap for ListView 
     all_chat = new ArrayList<HashMap<String, String>>(); 

     // Loading products in Background Thread 
     new LoadAllProducts().execute(); 


    } 

    /** 
    * Background Async Task to Load all product by making HTTP Request 
    * */ 
    class LoadAllProducts extends AsyncTask<String, String, String> { 

     /** 
     * Before starting background thread Show Progress Dialog 
     * */ 
     @Override 
     protected void onPreExecute() { 
      super.onPreExecute(); 
      pDialog = new ProgressDialog(AllProductsActivity.this); 
      pDialog.setMessage("Loading products. Please wait..."); 
      pDialog.setIndeterminate(false); 
      pDialog.setCancelable(false); 
      pDialog.show(); 
     } 

     /** 
     * getting All products from url 
     * */ 
     protected String doInBackground(String... args) { 
      // Building Parameters 
      List<NameValuePair> params = new ArrayList<NameValuePair>(); 
      // getting JSON string from URL 
      JSONObject json = jParser.makeHttpRequest(url_all_products, "GET", params); 

      // Check your log cat for JSON reponse 
      Log.d("All Products: ", json.toString()); 

      try { 
        // products found 
        // Getting Array of Products 
        chat = json.getJSONArray(TAG_CHAT); 

        // looping through All Products 
        for (int i = 0; i < chat.length(); i++) { 
         JSONObject c = chat.getJSONObject(i); 

         // Storing each json item in variable 
         String date = c.getString(TAG_DATE); 
         String from = c.getString(TAG_FROM); 
         String message = c.getString(TAG_MESSAGE); 

         // creating new HashMap 
         HashMap<String, String> map = new HashMap<String, String>(); 

         // adding each child node to HashMap key => value 
         map.put(TAG_DATE, date); 
         map.put(TAG_FROM, from); 
         map.put(TAG_MESSAGE, message); 

         // adding HashList to ArrayList 
         all_chat.add(map); 
        } 

      } catch (JSONException e) { 
       e.printStackTrace(); 
      } 

      return null; 
     } 

     /** 
     * After completing background task Dismiss the progress dialog 
     * **/ 
     protected void onPostExecute(String file_url) { 
      // dismiss the dialog after getting all products 
      pDialog.dismiss(); 
      // updating UI from Background Thread 

      runOnUiThread(new Runnable() { 

       public void run() { 
        /** 
        * Updating parsed JSON data into ListView 
        * */ 
        ListAdapter adapter = new SimpleAdapter(
          AllProductsActivity.this, all_chat, R.layout.list_item, new String[] { TAG_FROM,TAG_DATE, TAG_MESSAGE }, 
          new int[] { R.id.from,R.id.date, R.id.message }); 
        // updating listview 
        setListAdapter(adapter); 
       } 
      }); 

     } 

    } 
} 
+0

在这里添加您的适配器 – Sajmon 2013-03-11 21:06:24

+0

先生sajmon_d,我不undrestand什么是乌拉圭回合的平均... java代码:(我有没有java代码适配器,何坤ID呢? – 2013-03-12 05:04:24

+0

先生,我使用defult listadapter。我使用“import android.widget.ListAdapter;” – 2013-03-12 20:09:30

回答

0

的过程应该是这样的,

假设这是你的网址:http://www.xxx.com/get_chat.php?id="" 服务器应该发送基于id参数响应。如果它没有发送整个列表,否则发送比该标识更新的新数据。

所以,第一次你会得到整个列表,然后服务器发送新的数据,基于什么是最后一个项目的ID。根据你所提到的,我假设你可以更新你的数据库。

现在假设你有一个计时器,你的应用程序每隔一秒向服务器发送请求(如果你想让它成为真实的,这是一个可怕的假设,假设10000台设备每隔一秒就向服务器发送请求! 。 如果没有数据:不做任何事情(它应该在onPostExecute方法进行检查) 如果有数据:从数据库中获得整个列表(因为新的数据之前,因此添加后,您将更新项目)并将其传递给您的适配器。

希望它可以帮助你:)

相关问题