- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在试用 Volley,所以它对我的项目非常有用。我可以添加东西和移动信息,但我需要应用程序在列表中添加新项目时自行刷新或更新,我个人希望像 Whatsapp 一样流畅。
我怎样才能做到这一点?我在另一个项目中使用了 AsyncTask
,但我不知道这是否应该是这里采用的方法。我对 Android 开发有点陌生,这让我对 Volley 有了一些了解。
你能帮我指出正确的方向吗?
下面是我的适配器的代码、我的主要 Activity 以及我发布帖子的位置。我相信这种刷新应该在这 3 个类中的一个中完成。
如果你能帮助我,那将是我知识的重要学习步骤。我感谢那些愿意提供帮助的人!
谢谢! :)
主要 Activity
public class MainActivity extends AppCompatActivity implements NewsAdapter.OnItemClickListener{
//variable to hold the information that we want to pass to another activity
public static final String EXTRA_NEWS = "newspost";
private TextView textviewUsername, textviewUserEmail;
ArrayList<News> newsArrayList;
private LinearLayoutManager mLayoutManager;
RecyclerView recyclerView;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
if (!SharedPrefManager.getInstance(this).isLoggedIn()){
startActivity(new Intent(this, LoginActivity.class));
finish();
}
textviewUsername = findViewById(R.id.txtViewusername);
textviewUserEmail = findViewById(R.id.txtViewUserEmail);
textviewUsername.setText(SharedPrefManager.getInstance(this).getUser().getUsername());
textviewUserEmail.setText(SharedPrefManager.getInstance(this).getUser().getEmail());
recyclerView = findViewById(R.id.recylerView);
mLayoutManager = new LinearLayoutManager(getApplicationContext());
//Invert the view of the list
mLayoutManager.setReverseLayout(true);
mLayoutManager.setStackFromEnd(true);
recyclerView.setLayoutManager(mLayoutManager);
recyclerView.setHasFixedSize(true);
recyclerView.setItemAnimator(new DefaultItemAnimator());
newsArrayList = new ArrayList<>();
loadProducts();
}
private void loadProducts() {
/*
* Creating a String Request
* The request type is GET defined by first parameter
* The URL is defined in the second parameter
* Then we have a Response Listener and a Error Listener
* In response listener we will get the JSON response as a String
* */
JsonObjectRequest request = new JsonObjectRequest(Request.Method.GET, Constants.URL_SHOW_NEWS, null,
new Response.Listener<JSONObject>() {
@Override
public void onResponse(JSONObject response) {
try {
//converting the string to json array object
JSONArray jsonArray = response.getJSONArray("news");
//traversing through all the object
for (int i = 0; i < jsonArray.length(); i++) {
//getting product object from json array
JSONObject jsnews = jsonArray.getJSONObject(i);
//adding the product to product list
String post = jsnews.getString("noticia");
newsArrayList.add(new News(post));
}
//creating adapter object and setting it to recyclerview
NewsAdapter adapter = new NewsAdapter(MainActivity.this, newsArrayList);
recyclerView.setAdapter(adapter);
/* ------ SETTING OUR ADAPTER TO OUR ONCLICKLISTERNER ---------*/
adapter.setOnClickListener(MainActivity.this);
} catch (JSONException e) {
Toast.makeText(getApplicationContext(), "Parou aqui", Toast.LENGTH_LONG).show();
}
}
},
new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError error) {
Toast.makeText(getApplicationContext(), "Algo de errad nao esta certo", Toast.LENGTH_LONG).show();
}
});
//adding our stringrequest to queue
Volley.newRequestQueue(this).add(request);
}
public void post(View view){
startActivity(new Intent(this, PostNews.class));
}
@Override
public void onItemClick(int position) {
/* -------------- DO WHATEVER YOU WANT WITH THE CLICK EVENT HERE------------------ */
Intent newsDetail = new Intent(this, NewsDetailActivity.class);
News clickedNews = newsArrayList.get(position);
newsDetail.putExtra(EXTRA_NEWS, clickedNews.getNews_post());
startActivity(newsDetail);
}
}
我的适配器
public class NewsAdapter extends RecyclerView.Adapter<NewsAdapter.NewsAdapterViewHolder> {
private Context context;
private ArrayList<News> newsArrayList;
//creating a listener for the interface with the same name as our interface
private OnItemClickListener xListener;
//making our own custom onClickListener
public interface OnItemClickListener {
void onItemClick(int position);
}
public void setOnClickListener(OnItemClickListener listener){
//used to simulate the onItemClick of a listview
xListener = listener;
}
public NewsAdapter(Context context, ArrayList<News> newsArrayList) {
this.context = context;
this.newsArrayList = newsArrayList;
}
@Override
public NewsAdapterViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
View v = LayoutInflater.from(context).inflate(R.layout.news_list, parent, false);
return new NewsAdapterViewHolder(v);
}
@Override
public void onBindViewHolder(NewsAdapterViewHolder holder, int position) {
News currentNews = newsArrayList.get(position);
String post = currentNews.getNews_post();
holder.txtNoticia.setText(post);
}
@Override
public int getItemCount() {
return newsArrayList.size();
}
public class NewsAdapterViewHolder extends RecyclerView.ViewHolder{
public TextView txtNoticia;
public NewsAdapterViewHolder(View itemView) {
super(itemView);
txtNoticia = itemView.findViewById(R.id.txtnewsPost);
//creating the option for when we click on something to work
//-------------------------WARNING--------------------------//
/*THIS IS A TRICK TO USE onItemClick AS YOU WOULD USE IN A LIST VIEW
* IT'S BETTER TO USE HERE (ACCORDING TO THE TUTORIAL THAN USING ON THE *-onBindViewHolder-*)*/
itemView.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
if (xListener != null) {
int position = getAdapterPosition();
//noposition to make sure the position is still valid
if (position != RecyclerView.NO_POSITION){
//onItemclick is the method that we created on the interface
xListener.onItemClick(position);
}
}
}
});
}
}
}
创建帖子的 Activity
public class PostNews extends AppCompatActivity {
private Button btnpostar;
private EditText editTextNewsPost;
private ProgressBar progressBar;
SharedPrefManager sharedPrefManager;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_post_news);
editTextNewsPost = findViewById(R.id.EditTextNewsPost);
btnpostar = findViewById(R.id.btnPostar);
progressBar = findViewById(R.id.progressBar3);
progressBar.setVisibility(View.GONE);
}
public void salvarNoticia(View view) {
final User user = sharedPrefManager.getInstance(this).getUser();
final String post = editTextNewsPost.getText().toString();
if (!post.equals("")) {
progressBar.setVisibility(View.VISIBLE);
StringRequest stringRequest = new StringRequest(Request.Method.POST,
Constants.URL_REGISTER_NEWS,
new Response.Listener<String>() {
@Override
public void onResponse(String response) {
progressBar.setVisibility(View.GONE);
try {
JSONObject jsonObject = new JSONObject(response);
Toast.makeText(getApplicationContext(), jsonObject.getString("message"),
Toast.LENGTH_LONG).show();
} catch (JSONException e) {
Toast.makeText(getApplicationContext(), e.getMessage(), Toast.LENGTH_LONG).show();
}
}
}, new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError error) {
progressBar.setVisibility(View.GONE);
Toast.makeText(getApplicationContext(), "Erro: " + error.getMessage(), Toast.LENGTH_LONG).show();
}
}) {
@Override
protected Map<String, String> getParams() throws AuthFailureError {
Map<String, String> params = null;
params = new HashMap<>();
params.put("news_post", post);
params.put("user_FK", String.valueOf(user.getId()));
return params;
}
};
RequestHandler.getInstance(getApplicationContext()).addToRequestQueue(stringRequest);
} else {
Toast.makeText(getApplicationContext(), "Por favor, não poste nada em branco", Toast.LENGTH_LONG).show();
}
}
}
最佳答案
该问题不受特定编程问题的影响,而是指向应用程序架构。但是,我写这个答案是为了分享我在使用此类应用程序方面的一些经验。
据我从您的问题中了解到,您想使用 RecyclerView
在您的应用程序中显示帖子。当用户从应用程序创建帖子/产品或其他人创建帖子/产品时,RecyclerView
需要更新。如果我理解正确,那么你需要牢记以下几点。
MainActivity
的 onCreate
函数中调用 loadProducts();
函数,这是正确的。应用程序应在启动时加载需要在 RecyclerView
中显示的所有项目。所以初始化部分是完全没问题的。 RecyclerView
中。当用户想要查看那里是否有任何更新时,他/她可能会下拉 RecyclerView
来刷新数据。我想您已经想到了这一点,我只是涵盖了所有可用的选项。 loadProducts
函数。当您的每个拉取请求都有新数据可用时,使用 notifyDataSetChanged
方法相应地更新 RecyclerView
。 loadProducts
函数并相应地更新 RecyclerView
。推送既不实时也不可靠。但是,它可能会为您节省大量 API 调用。 我刚刚给了你一些想法。希望这些可以帮助你。
更新
根据您的评论,我认为您没有清楚地理解我的意思。您无法在服务器端每 x 分钟后收到推送通知,因为在这种情况下,您需要跟踪安装在用户设备中的每个应用程序中的帖子更新 - 这是一个糟糕的设计.
您需要选择一个。如果您想每 x 分钟刷新一次数据,那么我建议在您的应用程序中保留一个 Handler
或一个后台 Service
,它将调用 loadProducts
每 x 分钟后运行一次,并将更新您的数据。
如果您计划实现基于推送通知的更新,那么您可以向服务器端插入的每个新数据上连接的设备发送推送。当应用端收到推送时,你需要用更新后的数据相应地更新列表。希望现在更清楚了。
关于java - 让 RecyclerView 像 Whatsapp 一样更新,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49436199/
我在另一个 RecyclerView(parentRecyclerView) 中实现了 RecyclerView(childRecyclerView),图片说明了所有的实现: 我想编写一个 espre
我正在构建一个应用程序,它使用ViewPager2在页面之间水平滚动,每个页面都有一个垂直滚动的内容RecyclerView,其中每个列表的第一个位置都有一行水平滚动小部件,例如附加到寻呼机指示器类型
我正在尝试实现一个水平的 recyclerview 并且 recyclerview 的每个项目都将是一个具有网格布局的垂直 recyclerview。我面临的问题是,当我尝试垂直滚动子 recycle
我使用显示条目列表的 RecyclerView。每个条目都托管另一个 RecyclerView,它是一个图像列表。 我现在想让这个嵌套的 RecyclerView 可点击,而不是它的项目,而是整个 V
我正在尝试将手机中的图像加载到我的回收 View 中。 到目前为止,我已经创建了一个 recyclerview.adapter 和一个 gridlayoutmanager,并将它们附加到我的 recy
我需要一个可扩展 View ,其中父/可扩展标题将具有文本和下拉箭头。每个此类标题的子项应该是在网格结构中具有多个项目的 View 。 (有点像带有 GridLayoutManager 的回收器 Vi
我正在使用显示不同类别列表的 RecyclerView。每行项目还包含 RecyclerView 以显示类别项目列表。父级 RecyclerView 由垂直 LinearLayoutManager 填
我正在更新一个旧的 Android 项目,现在我从 RecyclerView 中反复收到这条日志语句: W/RecyclerView:RecyclerView 不支持滚动到绝对位置。改为使用 scro
在我的 Adapter 中,我调用 LayoutManager.ChildAt(position) 来获取 itemview,但是我得到的 View 不是匹配的 itemview,当我调用 notif
我正在从 ListView 迁移到 RecyclerView,但是在 SQLite 中输入一些数据后,我的列表没有使用 notifyDataSetChanged() 更新;所以我总是要调用setAda
我正在用 Google Now Cards 的风格创建一组 5 张卡片。我首先关注的是总体布局。 我正在使用 CardView 和 RecyclerView ,我想要实现的是这样的: 这是我的 Car
在我的应用程序中,我有一个 RecyclerView,其中包含一个简单的项目 View ,每行包含一个 TextView 和一个 Spinner。 用户从操作栏中单击“保存”后,我需要遍历所有项目并获
我正在尝试检查 RecyclerView 中是否可以看到某些特定项目;但我无法实现。请帮助我确定我的项目是否在 RecyclerView 中完全可见。 mrecylerView.addOnScroll
我有一个提要片段,它的主要元素是帖子的 RecyclerView。 我正在使用 Lisa Wray 的 Groupie 库管理回收站 https://github.com/lisawray/group
我有这两个类似的行为回收器 View 适配器,它们之间的唯一区别是 onclick 方法和传递给它们的对象。所以,我正在考虑将类 B 设计为从回收器 View 适配器继承,这样我就可以更改构造函数来执
这很奇怪。我对这个问题感到沮丧。我将数据保存在 ArrayList 中。当我将数据放在 RecyclerView 上时。数据未显示在列表中。这是我的代码 listOrder.forEach { ord
编辑我通过使用 CoordinatorLayout 和 AppBarLayout 作为 header 和 TabLayout 的包装解决了这个问题。本来应该很明显,但是哦,好吧。 原始问题:我有一个设
我有一个回收 View 。我想从其适配器类更新回收器 View 。我尝试了 notiftDataSetChanged( ) 但它只适用于主类。下面是 recyclerview 适配器类的代码。 pac
我正在使用具有不同 viewholders 的 recyclerview(具有垂直 LinearLayout),其中一个有另一个 RecyclerView(带有水平 LL)。在第二个 recycler
我想创建一个与 Google Play Store 或 Netflix App 类似的布局,其中在单个 RecyclerView 中基本上有多个水平 RecyclerView。如果这不是他们做事的方式
我是一名优秀的程序员,十分优秀!