implement recyclerview with tablayout inside fragm

2019-08-12 03:51发布

问题:

how do I implement Recyclerview with TabLayout inside fragment? previously I've successfully used the activity with Recyclerview and TabLayout. but when I try to use TabLayout beside fragment, the Recyclerview is not showing.

I've tried looking at the tutorial references as follows:

link

but I have not succeeded. here I attach my code snippet, the tabbed fragment:

TabAddFragment1.java

package com.mimdudin.carekkerje.Activities;


import android.content.Context;
import android.content.SharedPreferences;
import android.os.Bundle;
import android.support.annotation.NonNull;
import android.support.v4.app.Fragment;
import android.support.v7.widget.LinearLayoutManager;
import android.support.v7.widget.RecyclerView;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.Toast;

import com.android.volley.AuthFailureError;
import com.android.volley.NetworkError;
import com.android.volley.NoConnectionError;
import com.android.volley.Request;
import com.android.volley.Response;
import com.android.volley.TimeoutError;
import com.android.volley.VolleyError;
import com.android.volley.VolleyLog;
import com.android.volley.toolbox.JsonObjectRequest;
import com.android.volley.toolbox.StringRequest;
import com.mimdudin.carekkerje.Adapter.AddRecyclerViewadapter;
import com.mimdudin.carekkerje.Helper.AppController;
import com.mimdudin.carekkerje.Model.Add;
import com.mimdudin.carekkerje.R;
import com.mimdudin.carekkerje.Util.Constant;

import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import static com.android.volley.VolleyLog.TAG;

/**
 * A simple {@link Fragment} subclass.
 */
public class TabAddFragment1 extends Fragment {
    private RecyclerView recyclerView;
    private AddRecyclerViewadapter addRecyclerViewadapter;
    private List<Add> addList;
    private SharedPreferences sharedPreferences;
    private String apiKey;
    public TabAddFragment1() {
        // Required empty public constructor
    }


    @Override
    public View onCreateView(@NonNull LayoutInflater inflater, ViewGroup container,
                             Bundle savedInstanceState) {
        // Inflate the layout for this
        View view = inflater.inflate(R.layout.tabadd1, container, false);

        recyclerView = view.findViewById(R.id.recyclerViewAdd);
        recyclerView.setHasFixedSize(true);
        recyclerView.setLayoutManager(new LinearLayoutManager(getActivity()));

        addList = new ArrayList<>();
        addList = getAdd();

        addRecyclerViewadapter = new AddRecyclerViewadapter(getContext(), addList);
        recyclerView.setAdapter(addRecyclerViewadapter);
        addRecyclerViewadapter.notifyDataSetChanged();

        sharedPreferences = getActivity().getSharedPreferences("data", Context.MODE_PRIVATE);

        return view;
    }

    private List<Add> getAdd() {
        String tag_headers_req = "req_apikey";
        JsonObjectRequest jsonObjRequest = new JsonObjectRequest(Request.Method.GET, Constant.URL_GETADD, null,
                new Response.Listener<JSONObject>() {
                    @Override
                    public void onResponse(JSONObject response) {
                        Log.d("onResponse: ", response.toString());

                        try {
                            boolean error = response.getBoolean("error");

                            if (!error){
                                JSONArray jsonArr = response.getJSONArray("transaksi");
                                for (int i = 0; i < jsonArr.length(); i++){
                                    JSONObject allObj = jsonArr.getJSONObject(i);

                                    Add add = new Add();
                                    add.setTitleAdd(allObj.getString("title"));
                                    add.setPreviewAdd(allObj.getString("deskripsi"));
                                    add.setTanggalAdd(allObj.getString("tanggal"));
                                    add.setImg_logoAdd(allObj.getString("img_logo"));

                                    SharedPreferences.Editor editor = sharedPreferences.edit();
                                    editor.putString("title", add.getTitleAdd());
                                    editor.putString("deskripsi", add.getPreviewAdd());
                                    editor.putString("tanggal", add.getTanggalAdd());
                                    editor.putString("img_logo", add.getImg_logoAdd());
                                    editor.commit();

                                    addList.add(add);
                                }
                            } else {
                                Toast.makeText(getContext(), response.getString("message"), Toast.LENGTH_SHORT).show();
                            }
                        } catch (JSONException e) {
                            e.printStackTrace();
                            Log.d(TAG, "onResponse: " + e.getMessage());
                        }
                    }
                }, new Response.ErrorListener() {
            @Override
            public void onErrorResponse(VolleyError error) {
                VolleyLog.d("Error: " + error.getMessage());
                if (error instanceof TimeoutError || error instanceof NoConnectionError || error instanceof NetworkError){
                    Toast.makeText(getContext(), "Please check your connection!", Toast.LENGTH_SHORT).show();
                }
            }
        })
        {
            @Override
            public String getBodyContentType() {
                return "application/x-www-form-urlencoded";
            }

            @Override
            public Map<String, String> getHeaders() throws AuthFailureError {
                Map<String, String> headers = new HashMap<>();
                sharedPreferences = getActivity().getSharedPreferences("data", Context.MODE_PRIVATE);
                apiKey = sharedPreferences.getString("apiKey", "User Tidak Ditemukan");
                Log.d("getHeaders: ", apiKey);

//                headers.put("Content-Type", "application/json; charset=utf-8");
//                headers.put("Content-Type", "application/x-www-form-urlencoded");

                headers.put("Authorization", apiKey);
                return headers;
            }
        };
        AppController.getInstance().addToRequestQueue(jsonObjRequest, tag_headers_req);
        return  addList;
    }
}

AND, my recyclerview adapter

AddRecyclerviewAdapter.java

package com.mimdudin.carekkerje.Adapter;

import android.content.Context;
import android.os.Bundle;
import android.support.v4.app.FragmentTransaction;
import android.support.v7.app.AppCompatActivity;
import android.support.v7.widget.RecyclerView;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ImageView;
import android.widget.TextView;

import com.bumptech.glide.Glide;
import com.bumptech.glide.request.RequestOptions;
import com.mimdudin.carekkerje.Activities.TabAddFragment1Detail;
import com.mimdudin.carekkerje.Model.Add;
import com.mimdudin.carekkerje.R;

import java.util.List;

public class AddRecyclerViewadapter extends RecyclerView.Adapter<AddRecyclerViewadapter.ViewHolder> {
    private Context context;
    private List<Add> addList;

    public AddRecyclerViewadapter(Context context, List<Add> addList){
        this.context = context;
        this.addList = addList;
    }

    @Override
    public AddRecyclerViewadapter.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
        View view = LayoutInflater.from(parent.getContext())
                .inflate(R.layout.add_row, parent, false);
        return new ViewHolder(view, context);
    }

    @Override
    public void onBindViewHolder(AddRecyclerViewadapter.ViewHolder holder, int position) {
        Add add = addList.get(position);

        holder.tvTitleAdd.setText(add.getTitleAdd());
        holder.tvPreviewAdd.setText(add.getPreviewAdd());
        holder.tvTanggalAdd.setText(add.getTanggalAdd());

        String img_logoAddurl = add.getImg_logoAdd();
        Glide.with(context)
                .load(img_logoAddurl)
                .apply(new RequestOptions().placeholder(android.R.drawable.ic_dialog_info)
                        .error(android.R.drawable.ic_dialog_alert).centerCrop().dontAnimate()
//                         .centerCrop(), .crossFade(), .thumbnail(), .dontAnimate(), .dontTransform() BitmapTransformation(.circleCrop())
        )
                .into(holder.img_logoAdd);

    }

    @Override
    public int getItemCount() {
        return addList.size();
    }

    public class ViewHolder extends RecyclerView.ViewHolder {
        private TextView tvTitleAdd;
        private TextView tvPreviewAdd;
        private ImageView img_logoAdd;
        private TextView tvTanggalAdd;

        public ViewHolder(final View itemView, final Context ctx) {
            super(itemView);
            context = ctx;

            tvTitleAdd = itemView.findViewById(R.id.tvTitleAdd);
            tvPreviewAdd = itemView.findViewById(R.id.tvPreviewAdd);
            img_logoAdd = itemView.findViewById(R.id.img_logoAdd);
            tvTanggalAdd = itemView.findViewById(R.id.tvTanggalAdd);

            itemView.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {

                    TabAddFragment1Detail tabAddFragment1Detail = new TabAddFragment1Detail();

                    Add add = addList.get(getAdapterPosition());
                    Bundle bundle = new Bundle();
                    bundle.putSerializable("add", add);
                    tabAddFragment1Detail.setArguments(bundle);

                    AppCompatActivity activity = (AppCompatActivity) itemView.getContext();

                    android.support.v4.app.FragmentManager fragmentManager = activity.getSupportFragmentManager();
                    FragmentTransaction fragmentTransaction = fragmentManager.beginTransaction().addToBackStack(null);
//                    fragmentTransaction.setTransition(FragmentTransaction.TRANSIT_FRAGMENT_FADE);
                    fragmentTransaction.replace(R.id.frame_fragmentaddDetail, tabAddFragment1Detail);
                    fragmentTransaction.commit();

                }
            });
        }
    }
}

and, here I attach to play tablayout who initialize both the tab fragment

AddFragment.java

package com.mimdudin.carekkerje.Activities;


import android.os.Bundle;
import android.support.annotation.NonNull;
import android.support.design.widget.TabLayout;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentManager;
import android.support.v4.app.FragmentStatePagerAdapter;
import android.support.v4.view.ViewPager;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;

import com.mimdudin.carekkerje.R;

/**
 * A simple {@link Fragment} subclass.
 */
public class AddFragment extends Fragment {
    public AddFragment() {
        // Required empty public constructor
    }

    //untuk bottom navigation
    public static AddFragment newInstance() {
        return new AddFragment();
    }

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
    }

    @Override
    public View onCreateView(@NonNull LayoutInflater inflater, ViewGroup container,
                             Bundle savedInstanceState) {
        // Inflate the layout for this fragment
         View view = inflater.inflate(R.layout.fragment_add, container, false);

//        Toolbar toolbar = view.findViewById(R.id.toolbar);
//        ((AppCompatActivity)getActivity()).setSupportActionBar(toolbar);

        TabLayout tabLayout = view.findViewById(R.id.tabLayout);
        tabLayout.addTab(tabLayout.newTab().setText("Pasang"));
        tabLayout.addTab(tabLayout.newTab().setText("History"));
        tabLayout.setTabGravity(TabLayout.GRAVITY_FILL);

        final ViewPager viewPager = view.findViewById(R.id.pagerAdd);
//        tabLayout.setupWithViewPager(viewPager);
        final AddPagerAdapter adapter = new AddPagerAdapter(getActivity().getSupportFragmentManager(), tabLayout.getTabCount());
        viewPager.setAdapter(adapter);

        viewPager.setOnPageChangeListener(new TabLayout.TabLayoutOnPageChangeListener(tabLayout));
        tabLayout.setOnTabSelectedListener(new TabLayout.OnTabSelectedListener() {
            @Override
            public void onTabSelected(TabLayout.Tab tab) {
                viewPager.setCurrentItem(tab.getPosition());
            }

            @Override
            public void onTabUnselected(TabLayout.Tab tab) {

            }

            @Override
            public void onTabReselected(TabLayout.Tab tab) {

            }
        });

        return view;

    }

    private class AddPagerAdapter extends FragmentStatePagerAdapter {

        private int tabCount;

        AddPagerAdapter(FragmentManager fm, int tabCount) {
            super(fm);
            this.tabCount = tabCount;
        }

        @Override
        public Fragment getItem(int position) {
            switch (position){
                case 0:
                    return new TabAddFragment2();
                case 1:
                    return new TabAddFragment1();
                default:
                    return null;
            }
        }

        @Override
        public int getCount() {
            return tabCount;
        }
    }

}

hope you can help me solve.

回答1:

If you want to use Nested fragment than

Use getChildFragmentManager() instead of getSupportFragmentManager()

Use this

 final AddPagerAdapter adapter = new AddPagerAdapter(getChildFragmentManager(), tabLayout.getTabCount());

Instead of this

 final AddPagerAdapter adapter = new AddPagerAdapter(getActivity().getSupportFragmentManager(), tabLayout.getTabCount());

EDIT notifyDataSetChanged() in your getAdd() after adding data in your list like below code

try this

 addRecyclerViewadapter.notifyDataSetChanged();

CODE

private List<Add> getAdd() {
        String tag_headers_req = "req_apikey";
        JsonObjectRequest jsonObjRequest = new JsonObjectRequest(Request.Method.GET, Constant.URL_GETADD, null,
                new Response.Listener<JSONObject>() {
                    @Override
                    public void onResponse(JSONObject response) {
                        Log.d("onResponse: ", response.toString());

                        try {
                            boolean error = response.getBoolean("error");

                            if (!error){
                                JSONArray jsonArr = response.getJSONArray("transaksi");
                                for (int i = 0; i < jsonArr.length(); i++){
                                    JSONObject allObj = jsonArr.getJSONObject(i);

                                    Add add = new Add();
                                    add.setTitleAdd(allObj.getString("title"));
                                    add.setPreviewAdd(allObj.getString("deskripsi"));
                                    add.setTanggalAdd(allObj.getString("tanggal"));
                                    add.setImg_logoAdd(allObj.getString("img_logo"));

                                    SharedPreferences.Editor editor = sharedPreferences.edit();
                                    editor.putString("title", add.getTitleAdd());
                                    editor.putString("deskripsi", add.getPreviewAdd());
                                    editor.putString("tanggal", add.getTanggalAdd());
                                    editor.putString("img_logo", add.getImg_logoAdd());
                                    editor.commit();

                                    addList.add(add);
                                }
                               // add here  notifyDataSetChanged(); 
                                addRecyclerViewadapter.notifyDataSetChanged();
                            } else {
                                Toast.makeText(getContext(), response.getString("message"), Toast.LENGTH_SHORT).show();
                            }
                        } catch (JSONException e) {
                            e.printStackTrace();
                            Log.d(TAG, "onResponse: " + e.getMessage());
                        }
                    }
                }, new Response.ErrorListener() {
            @Override
            public void onErrorResponse(VolleyError error) {
                VolleyLog.d("Error: " + error.getMessage());
                if (error instanceof TimeoutError || error instanceof NoConnectionError || error instanceof NetworkError){
                    Toast.makeText(getContext(), "Please check your connection!", Toast.LENGTH_SHORT).show();
                }
            }
        })
        {
            @Override
            public String getBodyContentType() {
                return "application/x-www-form-urlencoded";
            }

            @Override
            public Map<String, String> getHeaders() throws AuthFailureError {
                Map<String, String> headers = new HashMap<>();
                sharedPreferences = getActivity().getSharedPreferences("data", Context.MODE_PRIVATE);
                apiKey = sharedPreferences.getString("apiKey", "User Tidak Ditemukan");
                Log.d("getHeaders: ", apiKey);

//                headers.put("Content-Type", "application/json; charset=utf-8");
//                headers.put("Content-Type", "application/x-www-form-urlencoded");

                headers.put("Authorization", apiKey);
                return headers;
            }
        };
        AppController.getInstance().addToRequestQueue(jsonObjRequest, tag_headers_req);
        return  addList;
    }