简体   繁体   English

如何根据条件在recyclerview中隐藏json对象?

[英]How to hide json object in recyclerview based on condition?

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.我在数组列表中有一个 json 数组,我需要将一个对象显示为计数,将一个对象显示为文本视图,在过滤对象时,我无法找到计数视图和显示视图,我搜索哈希图,但它不起作用,我的问题我可以在一个 recyclerview 适配器中添加两个数组列表,一个用于视图,另一个用于在同一视图中计数。 Edit: 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?编辑:经过研究,我知道我需要隐藏对象,如果它与 id 匹配,但我找不到在 recyclerview 中根据条件显示和隐藏内容有什么解决方案?

@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 object generated is as below生成的 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"
    }
   ]
   }
    }

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?在上面的 Json 响应中,如果对象是评论,我想显示内容,但如果是回复,我需要根据 id 显示计数匹配任何解决方案?

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();
}

Now for onBindViewHolder for example you want to display mList first then现在对于onBindViewHolder例如你想先显示mList然后

  @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

}
}

I am not sure I understand you fully.我不确定我是否完全理解你。 However, In my opinion, you can create a model class and keep two variables there.但是,在我看来,您可以创建一个模型类并在其中保留两个变量。

public class Demo {
    private int count;
    private int value;

    public Demo(int count, int value) {
        this.count = count;
        this.value = value;
    }
}

Then, you can create an ArrayList of that model class and pass it to RecyclerView adapter.然后,您可以创建该模型类的ArrayList并将其传递给RecyclerView适配器。

ArrayList<Demo> demos = new ArrayList<>();
Demo firstObject = new Demo(1, 10);
demos.add(firstObject);
Demo secondObject = new Demo(2, 11);
demos.add(secondObject);
Demo thirdObject = new Demo(3, 12);
demos.add(thirdObject);

Feel free to ask if I'm not clear or anything else.如果我不清楚或其他任何问题,请随时询问。

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

相关问题 如何根据特定条件在我的 RecyclerView 上为某些项目隐藏 ImageView? - How can I hide an ImageView on my RecyclerView for certain items based on a particular condition? 当没有条件显示的项目时隐藏 recyclerview - Hide recyclerview when there is no item to show with condition 如何根据 controller 条件隐藏/显示 thymeleaf 字段? - How to hide/show thymeleaf fields based on controller condition? 根据条件作为请求传递给API时,排除JSON对象中的值 - Exclude a value in JSON object when passing as request to API based on condition 使用Java根据条件从json数组中删除对象 - remove object from json array based on condition using java 如何根据布尔条件创建对象? - How to create object based on boolean condition? 我如何使用 retrofit 和 recyclerView 解析 json object - How i can parsing json object with retrofit and recyclerView 如何在recyclerview中隐藏字符串的一部分? - How to hide part of a string in a recyclerview? 解析json对象并追加到recyclerview - Parsing json Object and appending to recyclerview 如何根据对象的条件从java中的数组列表返回(和删除)对象 - How to return (and remove) an object from an arraylist in java based on a condition of that object
 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM