如何根据条件在recyclerview中隐藏json对象? [英] How to hide json object in recyclerview based on condition?

查看:61
本文介绍了如何根据条件在recyclerview中隐藏json对象?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我在数组列表中有一个json数组,我需要将一个对象显示为count,将一个对象显示为文本视图,而要过滤该对象时,我无法找到count视图和显示视图,我在搜索哈希图,但它不起作用,我的问题是我可以在一个recyclerview适配器中添加两个数组列表,一个用于视图,一个用于在同一视图中计数. 经过研究后,我知道如果对象与ID匹配,我需要隐藏对象,但是在recyclerview中,我找不到根据条件显示和隐藏内容的解决方案?

I have one json array in array list I need show one object as count and one as text view, while going to filter the object I'm not able to find count view and display view, I search for hash map but it does not work, my question i can i add two array list in one recyclerview adapter one for view and one for count in same view. after researching about that I come to know I need to hide object if it is a match with id but I could not found to display and hide content base on condition in recyclerview any solution?

@Override
public void onBindViewHolder(@NonNull DiscussingAdapter.DiscussionView holder, int position) {
    HashMap<String, List<Result>> hashMap = new HashMap<String, List<Result>>();
    Result result = discussionsList.get(position);
    //discussionsList.get(position);

    List<Result> filterList = discussionsList.stream()
            .filter(p -> p.getParentCommentID()==null).collect(Collectors.toList());
    Log.d("filterList",filterList.toString());
    for (int counter = 0; counter < filterList.size(); counter++) {
        holder.tvHeader.setText(filterList.get(counter).getTitle());
        holder.tvDetail.setText(Utils.html2text(filterList.get(counter).getComment()));
        holder.tvViewReply.setText("Reply");
        holder.tvUser.setText("By " + filterList.get(counter).getAuthor().getTitle());
        String DateofReceipt = filterList.get(counter).getCreated();
        String date = DateofReceipt.split("T", 0)[0];
        String date_before = date;
        String date_after = Utils.date(date_before);
        holder.tvDate.setText(date_after);
    }

    Map<String, Integer> commentsCountMap = new HashMap<>();
    for(Result res : discussionsList) {
        String parentCommentId = res.getParentCommentID();
        // If the Result has a parent comment
        if(parentCommentId != null) {
            // get the count for this parent comment (default to 0)
            int nbCommentsForParent = commentsCountMap.getOrDefault(parentCommentId, 0);
            // increment the count
            nbCommentsForParent++;
            // Update the Map with the new count
            commentsCountMap.put(parentCommentId, nbCommentsForParent);


        }
    }

    for(Map.Entry<String,Integer> cCount : commentsCountMap.entrySet()){

        holder.tvViewReply.setText(String .valueOf(cCount.getValue())+" Reply");



    }}

生成的Json对象如下

      {
      "d": {
"results": [
  {
    "__metadata": {
      "id": "e7433825-6771-4f5e-96c7-c4d2674d7764",
      "uri": "",
      "etag": "\"2\"",
      "type": "SP.Data.InquiryDiscussionsListListItem"
    },
    "Author": {
      "__metadata": {
        "id": "f064775c-6161-4bdb-9f4d-8bc6a898d218",
        "type": "SP.Data.UserInfoItem"
      },
      "Title": "Submitter1"
    },
    "Id": 1501,
    "ID": 1501,
    "Title": null,
    "Created": "2019-06-06T04:15:17Z",
    "ParentCommentID": "1439",
    "Comment": "<div class=\"ExternalClass8C333A77B6564A53BED74CA1BA2D2A10\">
    reply add for 009</div>",
    "CommentType": null,
    "CommentDocumentName": null,
    "AppID": "1083",
    "Role": "Customer"
  },
  {
    "__metadata": {
      "id": "e92f708f-93dc-4587-8c4f-5518ed24f360",
      "uri": "",
      "etag": "\"2\"",
      "type": "SP.Data.InquiryDiscussionsListListItem"
    },
    "Author": {
      "__metadata": {
        "id": "209d2d9a-bb07-4064-aaa0-231ad881a80f",
        "type": "SP.Data.UserInfoItem"
      },
      "Title": "Submitter1"
    },
    "Id": 1500,
    "ID": 1500,
    "Title": null,
    "Created": "2019-06-06T04:14:55Z",
    "ParentCommentID": "1439",
    "Comment": "<div class=\"ExternalClass44B1A0BB4D314C57BEE20141BFF10491\">comment add for       009</div>",
    "CommentType": null,
    "CommentDocumentName": null,
    "AppID": "1083",
    "Role": "Customer"
  },
  {
    "__metadata": {
      "id": "ec112002-3132-4bc1-8f85-03fbd9fda11d",
      "uri": "",
      "etag": "\"2\"",
      "type": "SP.Data.InquiryDiscussionsListListItem"
    },
    "Author": {
      "__metadata": {
        "id": "6e8ecb1d-4deb-4168-a8b4-a725abf8002a",
        "type": "SP.Data.UserInfoItem"
      },
      "Title": "Sarada Devi Potti"
    },
    "Id": 1439,
    "ID": 1439,
    "Title": "Canceled",
    "Created": "2019-06-03T09:32:34Z",
    "ParentCommentID": null,
    "Comment": "<div  class=\"ExternalClass5E1BFEDC348C43719AD940E644E0E0B6\">sdaeadfasdf</div>",
    "CommentType": "Public",
    "CommentDocumentName": null,
    "AppID": "1083",
    "Role": "Budget Analyst"
    }
   ]
   }
    }

在以上Json响应"中,如果object是Comment,我想显示内容,但是如果是回复,我需要根据id匹配任何解决方案来显示计数?

In Above Json response if object is Comment I want to display content but if it is a reply I need to display count base on id match any solution?

推荐答案

您可以通过一种简单的方式来实现此目的,首先将两个列表都传递给适配器 然后返回总大小

You can achieve this in a simple way first pass both the list to your adapter then return the total size

  @Override
public int getItemCount() {
    return mList.size() + mList1.size();
}

例如,现在要显示onBindViewHolder,然后先显示mList

Now for onBindViewHolder for example you want to display mList first then

  @Override
public void onBindViewHolder(@NonNull DiscussingAdapter.DiscussionView holder, int position) {
if(position < mList.size()){
// Load the data from mList 
holder.tvName.setText(mList.get(position).getName())
}else{
//For getting Data from secondList
holder.tvName.setText(mList1.get(position-mList.getSize()).getName())
// Now you will get data from second List

}
}

这篇关于如何根据条件在recyclerview中隐藏json对象?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆