【发布时间】:2017-07-14 02:37:51
【问题描述】:
我已经在这个问题上停留了一段时间,所以我终于在寻找一些提示。我的应用程序的 Main Activity 执行 Volley GET 请求 onCreate 并且我的 ListView 项目显示正常。单击列表中的项目后,我将一些数据传递给另一个活动,然后我执行 Volley POST 请求来更新我的数据库。然后我被带回我的主活动,之前选择的 ListView 项目应立即更新(从列表中消失或更改 TextViews 等),但如果我选择另一个项目并重复该过程,它似乎落后了一个周期。
我一直在用 onResume 测试各种东西,但我似乎无法让它工作。我什至将整个 volley 请求放在一个方法中,并尝试调用它 onResume 但这会导致我的进度对话框挂起并复制列表中的所有内容。但是,由工具栏上的方法调用的列表的手动刷新工作正常,以及来自定时运行的请求。
用户列表活动
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_user_list);
//Setting adapter to the listView
listView =(ListView) findViewById(R.id.list);
adapter =new CustomListAdapter(this,userList);
listView.setAdapter(adapter);
// Showing progress dialog before making http request
pDialog =new ProgressDialog(this);
pDialog.setMessage("Loading...");
pDialog.show();
if(userList!=null) {
userList.clear();
}
// Creating volley request obj
JsonArrayRequest userReq = new JsonArrayRequest(url,
new Response.Listener<JSONArray>() {
@Override
public void onResponse(JSONArray response) {
Log.d(TAG, response.toString());
hidePDialog();
// Parsing json
for (int i = 0; i < response.length(); i++) {
try {
JSONObject obj = response.getJSONObject(i);
User user = new User();
user.setUserId(obj.getString("user_id"));
user.setFirstName(obj.getString("firstname"));
user.setLastName(obj.getString("lastname"));
// adding user to users array
userList.add(user);
} catch (JSONException e) {
e.printStackTrace();
}
}
adapter.notifyDataSetChanged();
}
}, new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError error) {
VolleyLog.d(TAG, "Error: " + error.getMessage());
hidePDialog();
}
});
//Passing Data to UserDetailActivity
listView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> adapterView, View view, int position, long id) {
int UserDetailActivity = 1;
Intent i = new Intent(UserListActivity.this, UserDetailActivity.class);
i.putExtra("user_id", userList.get(position));
i.putExtra("firstname", userList.get(position));
i.putExtra("lastname", userList.get(position));
startActivityForResult(i, UserDetailActivity);
}
});
}
// Adding request to request queue
AppController.getInstance().addToRequestQueue(userReq);
@Override
public void onActivityResult(int requestCode, int resultCode, Intent data) {
if(requestCode == 1 && resultCode == RESULT_OK) {
//Calling the volley method below
volleyRequest();
}
}
//Collapsed volley method, same as onCreate
public void volleyRequest() {...}
UserDetailActivity
//Update Status
private void updateStatus() {
SharedPreferences sharedPreferences = getSharedPreferences(Config.SHARED_PREF_NAME, Context.MODE_PRIVATE);
final String user_id = sharedPreferences.getString(Config.user_id,"Not Available");
final String user_status = "ONLINE";
StringRequest stringRequest = new StringRequest(Request.Method.POST, Config.USERSTATUS_URL,
new Response.Listener<String>() {
@Override
public void onResponse(String response) {
Toast.makeText(UserDetailActivity.this, response, Toast.LENGTH_LONG).show();
}
},
new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError error) {
Toast.makeText(UserDetailActivity.this, error.getMessage(), Toast.LENGTH_LONG).show();
}
}) {
@Override
protected Map<String, String> getParams() throws AuthFailureError {
Map<String, String> params = new HashMap<>();
params.put("user_status", user_status);
params.put("user_id", user_id);
return params;
}
};
RequestQueue requestQueue = Volley.newRequestQueue(this);
requestQueue.add(stringRequest);
//Calling method below
finishAndSetResult();
//Intent intent = new Intent(this, UserListActivity.class);
//startActivity(intent);
}
private void finishAndSetResult() {
if (getParent() == null) {
setResult(RESULT_OK, null);
} else {
getParent().setResult(RESULT_OK, null);
}
finish();
}
更新 - 解决方案
所以我意识到我正在使用两个不同的请求。一个与我的 AppController 类一起执行立即更新,另一个似乎等到 UI 线程上的另一个事件 (?) 发生:
// Correct one to use
AppController.getInstance().addToRequestQueue(userReq);
//Delayed
RequestQueue requestQueue = Volley.newRequestQueue(this);
requestQueue.add(stringRequest);
【问题讨论】:
-
因此,您使用 GET 请求加载 ListView,然后打开一个新 Activity,在其中使用 POST 请求更改信息 (DB) 的来源,但随后您希望 ListView 更新一次你回到持有它的 Activity 吗?如果我知道您的问题是什么,请告诉我。
-
没错!!我需要它立即更新以反映数据库中的更改。我会用 onResume 做点什么吗?
-
不,如果您打开一个新的 Activity,您希望更改或将结果返回给调用它的 Activity,您应该对 onActivityResult 执行一些操作。我会在回答中解释。
标签: listview post get android-volley onresume