- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在尝试使用 swipeRefreshLayout 更新数据,但每次我向下滑动刷新时它都会重复旧数据而不是显示新数据。
你能帮我解决这个问题并告诉我我在哪里犯了错误以及如何解决它吗?
我在 fragment 中的代码:
public class StoriesFragment extends Fragment {
private static final String TAG = MainActivity.class.getSimpleName();
private static final String url = "http://sho3a3.net/storiesfeed.json";
private ProgressDialog pDialog;
private List<StoriesItem> storiesListItem = new ArrayList<StoriesItem>();
private ListView storiesListView;
private CustomListAdapter adapter;
private SwipeRefreshLayout swipeRefreshLayout;
public StoriesFragment() {
// Required empty public constructor
}
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
// Inflate the layout for this fragment
View view = inflater.inflate(R.layout.stories_fragment, container, false);
/*Swipe Refresh Layout*/
swipeRefreshLayout = (SwipeRefreshLayout) view.findViewById(R.id.swipe_container);
swipeRefreshLayout.setOnRefreshListener(new SwipeRefreshLayout.OnRefreshListener() {
@Override
public void onRefresh() {
adapter.notifyDataSetChanged();
getDataFromUrl();
}
});
swipeRefreshLayout.setColorScheme(
android.R.color.holo_blue_bright,
android.R.color.holo_green_light,
android.R.color.holo_orange_light,
android.R.color.holo_red_light);
swipeRefreshLayout.post(new Runnable() {
@Override
public void run() {
swipeRefreshLayout.setRefreshing(true);
getDataFromUrl();
}
});
storiesListView = (ListView) view.findViewById(R.id.list);
adapter = new CustomListAdapter(getActivity(), storiesListItem);
storiesListView.setAdapter(adapter);
/*Click Feed Item */
storiesListView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> adapterView, View view, int i, long l) {
Toast.makeText(getActivity(), " " + i, Toast.LENGTH_SHORT).show();
Object o = storiesListView.getItemAtPosition(i);
StoriesItem storiesItem = (StoriesItem) o;
Intent intent = new Intent(getActivity(), DetailsActivity.class);
intent.putExtra("storiesItem", storiesItem);
startActivity(intent);
}
});
return view;
}
private void getDataFromUrl() {
// RequestQueue requestQueue = Volley.newRequestQueue(getActivity());
// Creating volley request obj
JsonArrayRequest movieReq = new JsonArrayRequest(url,
new Response.Listener<JSONArray>() {
@Override
public void onResponse(JSONArray response) {
Log.d(TAG, response.toString());
//hidePDialog();
String title;
String date;
String profession;
// Parsing json
for (int i = 0; i < response.length(); i++) {
try {
JSONObject obj = response.getJSONObject(i);
StoriesItem storiesItem = new StoriesItem();
//Title
title = obj.getString("title");
byte[] bytesTitle = title.getBytes("ISO-8859-1");
String stringTitle = new String(bytesTitle, "UTF-8");
storiesItem.setTitle(stringTitle);
//Date
date = obj.getString("date");
byte[] bytesDate = date.getBytes("ISO-8859-1");
String stringDate = new String(bytesDate, "UTF-8");
storiesItem.setDate(stringDate);
//Profession
profession = obj.getString("profession");
byte[] bytesProfession = profession.getBytes("ISO-8859-1");
String stringProfession = new String(bytesProfession, "UTF-8");
storiesItem.setProfession(stringProfession);
storiesItem.setThumbnailUrl(obj.getString("image"));
storiesItem.setContent(obj.getString("content"));
// adding movie to movies array
storiesListItem.add(storiesItem);
} catch (JSONException e) {
e.printStackTrace();
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
}
// swipeRefreshLayout.setRefreshing(false);
onItemsLoadComplete();
// notifying list adapter about data changes
// so that it renders the list view with updated data
adapter.notifyDataSetChanged();
}
}, new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError error) {
Toast.makeText(getActivity(), "Error Connection", Toast.LENGTH_SHORT).show();
VolleyLog.d(TAG, "Error: " + error.getMessage());
swipeRefreshLayout.setRefreshing(false);
//hidePDialog();
}
});
//requestQueue.add(movieReq);
// Adding request to request queue
AppController.getInstance().addToRequestQueue(movieReq);
}
void onItemsLoadComplete() {
// Update the adapter and notify data set changed
// ...
adapter.notifyDataSetChanged();
// Stop refresh animation
swipeRefreshLayout.setRefreshing(false);
}
public void onUpdate() {
adapter = new CustomListAdapter(getActivity(), storiesListItem);
storiesListView.setAdapter(adapter);
if (swipeRefreshLayout.isRefreshing()) {
swipeRefreshLayout.setRefreshing(false);
}
}
}
最佳答案
您的 getDataFromUrl 所做的只是从服务器获取一些数据并将它们添加到 storiesListItem 中。这样做,storiesListItem 中的先前项目将不会神奇地消失 :-)。
你应该做的是在每次刷新之前明确列表:
swipeRefreshLayout.setOnRefreshListener(new SwipeRefreshLayout.OnRefreshListener() {
@Override
public void onRefresh() {
adapter.notifyDataSetChanged();
storiesListItem.clear();
getDataFromUrl();
}
代替:
swipeRefreshLayout.setOnRefreshListener(new SwipeRefreshLayout.OnRefreshListener() {
@Override
public void onRefresh() {
adapter.notifyDataSetChanged();
getDataFromUrl();
}
关于android - 使用 swipeRefreshLayout 更新自定义适配器中的数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30382406/
我正在尝试 react-native run-android 有这个问题吗?? Could not resolve all files for configuration ':react-native
关于我的环境的信息 Mac OS 大苏尔:11.4 VS for Mac:8.10.6(内部版本 10) Xamarin.Android:11.3.0.4 SDK 工具版本:26.1.1 SDK平台工
我正在开发一个 Android 应用程序。我将 listview 与 SwipefreshLayout 一起使用。但是当我使用 SwipefreshLayout 刷新 ListView 时,加载圈永远
我的应用程序包含一个 SwipeRefreshLayout ,其中包含一个 listView 。该列表从服务器接收数据。因此,当获取数据并且正确填充列表时,滑动刷新可以工作,但是当数据未传递到列表并且
我在使用 SwipeRefreshLayout 时遇到了内存泄漏问题,想知道是否有任何方法可以通过解决方法来解决此问题? 在一个空项目中,以滑动布局作为主要 Activity 的根,如果你向下滑动,并
我尝试为现有的 ListView 实现 SwipeRefreshLayout,但每当我运行该程序时,即使我通过拉动刷新它,它也只显示一项。但是,刷新动画有效。相关代码如下: items = (
这个问题在这里已经有了答案: When I am scrolling up SwipeRefreshLayout refreshing my app (4 个答案) 关闭 3 年前。 我有一个带有
我正在我的应用程序中实现 SwipeRefreshLayout。我已成功实现 OnRefreshListener,并且能够正确刷新 ListView 项目。 我的问题是,如果我向下滑动,当 Swipe
fragment 的onCreateView方法内部: swipeRefreshLayout.setOnRefreshListener(new SwipeRefreshLayout.OnRefresh
我有以下问题:我有很长的 ListView,但是当我向上滚动时会触发 onRefresh,而不是先滚动回顶部。我该如何解决这个问题? 我将以下 fragment 插入到 FrameLay
我有一个 SwipeRefreshLayout,其中包含用于聊天 Activity 的 RecyclerView。我将其底部限制在屏幕底部线性布局的顶部:
我在我的布局中使用了 SwipeRefreshLayout,我需要显示一个动画来调整已被下拉的距离。 到目前为止,我还没有找到任何方法来检测已拉动的实际距离。 SwipeRefreshListener
我喜欢新的 SwipeRefreshLayout!它看起来很棒,而且非常容易使用。但我想在两个方向上使用它。我有一个消息屏幕,我想通过从上到下滑动来加载旧消息,我想通过从下到上滑动来加载新消息。 这个
我正在使用支持库中的 SwipeRefreshListener。我正在从 AsyncTask 的 onPreExecute 和 onPostExecute 调用 setRefresh。然而,什么都没有
是否可以在不显示进度微调器的情况下执行 SwipeRefreshLayout 功能。现在,它的默认拉动刷新行为完美无缺地显示了 Progress 微调器和 onRefresh() 我隐藏了它。但我想将
我正在为 Google 支持库的 SwipeRefreshLayout 中的文档而苦苦挣扎。 当我使用 setOnRefreshListener 设置的回调接收到刷新调用时,我执行了我的操作,之后我发
有没有办法使用主题修改 SwipeRefreshLayout 中箭头的颜色? 我知道您可以通过编程方式使用此代码 public void setColorSchemeResources (int...
我已经实现了一个将 SwipeRefreshLayout 作为内容 View 的 fragment 。刷新动画在 onRefresh 时触发,但即使在从服务器检索数据后将 setRefreshing
我有一个向用户显示项目列表的 Activity ,它使用了分页库。我的问题是当用户向下滑动屏幕时我无法重新加载列表,以便它再次从服务器获取数据。 这是我的数据源工厂: public class Cou
我在我的 listView 中添加了一个“拉动刷新”,我还想在列表为空时添加一个空 View - 现在我收到了这个错误。我怎样才能使这项工作?如果我将 View 定位在 swipeRefresh 之外
我是一名优秀的程序员,十分优秀!