应用程序联系Web服务超过必要的

时间:2013-11-16 03:10:23

标签: android listview

我有一个listview,无论何时调用它都会联系Web服务,这就是它的样子

public class ListView extends ListActivity {    


    ArrayList<HashMap<String, String>> questionList;        

     final String TAG_DATA_WEB = "data";
     private String stringxxx;
     ProgressDialog pDialog;
     LoadAllData mTask; 

            JSONArray question = null;          
            android.widget.ListView lv;

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

        stringxxx = getIntent().getStringExtra("TAG_SEARCH");


        questionList = new ArrayList<HashMap<String, String>>(); 

    mTask = new LoadAllData();

         mTask.execute();

        }


    @Override   
    protected void onListItemClick(android.widget.ListView l, View v, int pos, long id) {
         super.onListItemClick(l, v, pos, id);  

          HashMap<String, String> item = questionList.get(pos);

          Intent i = new Intent(ListView.this, SingleListItem.class);
          i.putExtra(TAG_DATA_WEB, item.get(TAG_DATA_WEB));
          startActivity(i);

            }     

    @Override
    public void onBackPressed() 
    {              
        /** If user Pressed BackButton While Running Asynctask
            this will close the ASynctask.
         */
        if (mTask != null && mTask.getStatus() != AsyncTask.Status.FINISHED)
        {
            mTask.cancel(true);
        }          
        super.onBackPressed();
        Intent i = new Intent(ListView.this, PREV.class);
        startActivity(i);
        finish();
    }


    @Override
    protected void onDestroy() {

     if (mTask != null && mTask.getStatus() != AsyncTask.Status.FINISHED)
     {
        mTask.cancel(true);
      }  

        super.onDestroy();

    }

    @Override
    protected void onPause() {

     if (pDialog != null)
     {
         if(pDialog.isShowing())
         {
             pDialog.dismiss();
         }
            super.onPause();

      }  
}

    class LoadAllData extends AsyncTask<String, Void, JSONObject> {

        @Override
        protected void onPreExecute() {
            super.onPreExecute();             
            pDialog = new ProgressDialog(ListView.this);
            pDialog.setMessage("Loading Data. Please wait...");
            pDialog.setIndeterminate(false);
            pDialog.setCancelable(true);
            pDialog.show();           
}
        @Override
        protected JSONObject doInBackground(String... args) {  
            pDialog.setOnCancelListener(new DialogInterface.OnCancelListener(){ 
                public void onCancel(DialogInterface dialog) { 
                    mTask.cancel(true); 
                    Intent i = new Intent(ListView.this, PREV.class);
                    startActivity(i);
                    finish();
            } 
        });

            JSONObject json = new JSONObject();
            try {

                String query = URLEncoder.encode(searchTerm, "utf-8");
                String URL = "http://example.com";
                JSONParsser jParser = new JSONParsser();

                    json = jParser.readJSONFeed(URL);
                } catch (UnsupportedEncodingException e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                }

                return json;           

            }

        @Override
        protected void onPostExecute(JSONObject json) { 

                try {

                    JSONArray questions = json.getJSONObject("all").getJSONArray("questions");

                    for(int i = 0; i < DT.length(); i++) {
                        JSONObject question = DT.getJSONObject(i);


                    String data = question.getString(TAG_DATA_WEB);

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

                    map.put(TAG_DATA_WEB, data);

                    questionList.add(map);

                    pDialog.dismiss();
                    ListAdapter adapter = new SimpleAdapter(getBaseContext(), questionList,
                                R.layout.listelements,
                                new String[] { TAG_DATA_WEB }, new int[] {
                                R.id.Subject,});

                        setListAdapter(adapter);
                    }

                } catch (JSONException e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                }

        }


    }

}

我遇到的问题是,当我点击listview上的某个项目进入下一个活动时,它就像它的假设一样,没有问题就在我按下后退按钮返回列表视图时,列表视图活动重新启动,它还会再次联系Web服务以检索信息,就好像我将finish();放在startArtivity(I);代码的onItemClick部分之后。现在通常,如果您的Web服务没有搜索限制但我正在使用的搜索限制,这不会是一个问题。基本上我说的是,当用户点击listview项目进入下一个活动时,当他们按下onBack按钮时,我希望信息仍然存在,而不是应用程序再次联系Web服务以检索信息和最终结果将是达到的搜索限制。有人可以帮我吗?

2 个答案:

答案 0 :(得分:0)

我使用过XML解析,所以我可以在逻辑上给你帮助。

  • 您可以将bean类与get和set方法一起使用并存储结果 你来自网络服务。

  • 使用Set方法存储您编写的值 解析代码。

  • 在活动的适配器代码中使用get方法来检索这些方法 值。

  • 这样,当您达到该服务时,将不会再次调用Web服务 使用后退按钮的活动。

  • 但请记住,如果您再次从其父级启动该服务,则会再次调用Web服务。

答案 1 :(得分:0)

你会有几个选择:

使用AsyncTaskLoader数据加载替换AsyncTask数据加载。首先检查Loader开发人员文章。我很久以前就使用AsyncTasks进行数据加载......

第二个选项是存储您收到的数据,下次不要调用Web服务。为此,将数据以某种方式存储在onSaveInstanceStateonCreate中,检查Bundle参数是否为空,以及是否为onSaveInstanceState中使用的相同密钥设置了数据。如果为true,则表示您已拥有数据。如果为false,则查询。

根据数据的重要性和易变性,您可以在下载某种应用持久性(共享首选项或sqlite)后将其保存一次,并在每次活动重新创建或创建自己时使用它。