二级联动

本文详细介绍了一种在Android应用中使用双Fragment布局的设计方法,包括如何在一个Activity中嵌入两个Fragment,以及如何通过接口实现Fragment之间的数据传递与响应。通过实例展示了从布局创建、Fragment添加到点击事件处理及数据解析的全过程。

效果图
在这里插入图片描述

我的想法:
1.创建布局里放进两个fragment
左边的fragment是一级展示,右边的fragment展示是解析第二个之后再解析第三个
在这里插入图片描述
在布局这个activity中

//       创建管理者
        FragmentManager fragmentManager = getActivity().getSupportFragmentManager();
        FragmentTransaction transaction = fragmentManager.beginTransaction();
        Fragoo fragoo = new Fragoo();
        Fragtt fragtt = new Fragtt();
//        添加两个fragment
        transaction.add(R.id.recyyj, fragoo);
        transaction.add(R.id.recyrj, fragtt);

        transaction.commit();

.第一个fragment 解析展示略过同平常的一致
.在第一个recyclerview适配器中设置点击事件

view.setOnClickListener(new View.OnClickListener() {
    @Override
    public void onClick(View v) {
        int position = viewHolder.getLayoutPosition();
        if (onFenYiListener!=null){
            onFenYiListener.onfen(position);
        }
    }
});

下面写接口方法

 //    创建接口
    public interface OnFenYiListener {
        void onfen(int position);
    }
    //声明接口
    public OnFenYiListener onFenYiListener;
//    创建方法

    public void setOnFenYiListener(OnFenYiListener onFenYiListener) {
        this.onFenYiListener = onFenYiListener;
    }

返回写一级页面中在写点击事件

//        点击事件
        myFenYiAdapter.setOnFenYiListener(new MyFenYiAdapter.OnFenYiListener() {
            @Override
            public void onfen(int position) {
                Toast.makeText(getActivity(),"123",Toast.LENGTH_SHORT).show();
//                解析
                try {
                    JSONObject jsonObject = result.getJSONObject(position);
                    String id = jsonObject.getString("id");
                    onFragoo.onOo(id);

                } catch (JSONException e) {
                    e.printStackTrace();
                }
            }
        });	

在下面写接口

//    接口回调
public interface OnFragoo {
    void onOo(String id);
}

//声明
public OnFragoo onFragoo;

//    方法

public void getOnFragoo(OnFragoo onFragoo) {
    this.onFragoo = onFragoo;
}

第二个fragment–她是从第一个oo(getOnFragoo)连接

//        找控件
        recyrj = view.findViewById(R.id.recyrj);
//       布局管理器
        LinearLayoutManager manager = new LinearLayoutManager(getActivity());
        recyrj.setLayoutManager(manager);
//   创建管理者
        FragmentManager manager1 = getActivity().getSupportFragmentManager();
        Fragoo oo = (Fragoo) manager1.findFragmentById(R.id.recyyj);

        oo.getOnFragoo(this);
//
        return view;
    }

    @Override
    public void onOo(String id) {
        fenRjPresenter = new FenRjPresenter(this);
        fenRjPresenter.fenrj(id);
    }
    //url + "?firstCategoryId=" + id  拼接接口
    
之后一致

rj适配器

 String url = "http://172.17.8.100/small/commodity/v1/findCommodityByCategory";
    Context context;
    JSONArray result;
    private Handler handler = new Handler();

    public MyFenRjAdapter(Context context, JSONArray result) {
        this.context = context;
        this.result = result;
    }

    @NonNull
    @Override
    public ViewHolder onCreateViewHolder(@NonNull ViewGroup viewGroup, int i) {
        View view = LayoutInflater.from(context).inflate(R.layout.fenrj, null, false);
        ViewHolder viewHolder = new ViewHolder(view);
        return viewHolder;
    }

    @Override
    public void onBindViewHolder(@NonNull final ViewHolder viewHolder, int i) {
        if (viewHolder instanceof ViewHolder) {
//            解析
            try {
                final JSONObject jsonObject = result.getJSONObject(i);
                String name = jsonObject.getString("name");
                String id = jsonObject.getString("id");
//                Log.i("ername", name);
//                赋值
                viewHolder.rjtext.setText(name);
                viewHolder.rjrecy.setLayoutManager(new GridLayoutManager(context, 4));
                OkHttpUntil.getInstance().doGet(url + "?categoryId=" + id + "&page=1&count=8", new Callback() {
                    @Override
                    public void onFailure(Call call, IOException e) {

                    }

                    @Override
                    public void onResponse(Call call, final Response response) throws IOException {
                        handler.post(new Runnable() {
                            @Override
                            public void run() {
                                String string = null;
                                try {
                                    string = response.body().string();
                                    JSONObject jsonObject1 = new JSONObject(string);
                                    JSONArray result = jsonObject1.getJSONArray("result");
//                                    Log.i("sanhandler", result.toString());
                                    SanAdapter sanAdapter = new SanAdapter(context, result);
                                    viewHolder.rjrecy.setAdapter(sanAdapter);
                                } catch (Exception e) {
                                    e.printStackTrace();
                                }
                            }
                        });
                    }
                });
            } catch (JSONException e) {
                e.printStackTrace();
            }
        }
    }

    @Override
    public int getItemCount() {
        return result.length();
    }

    class ViewHolder extends RecyclerView.ViewHolder {
        private final TextView rjtext;
        private final RecyclerView rjrecy;

        public ViewHolder(@NonNull View itemView) {
            super(itemView);
            rjtext = itemView.findViewById(R.id.rjtext);
            rjrecy = itemView.findViewById(R.id.rjrecy);
        }
    }
联动 RecyclerView:即使不用饿了么订餐,也请务必收藏好该库!由来Linkage-RecyclerView 是一款基于 MVP 架构开发的二级联动列表控件。它是因 “RxJava 魔法师” 这个项目的需求而存在。在最初寻遍了 GitHub 也没有找到合适的开源库(高度解耦、可远程依赖)之后,我决心研究参考现有开源项目关于二级联动的逻辑,并自己动手编写一个 高度解耦、轻松配置、可通过 maven 仓库远程依赖 的真正的第三方库。Linkage-RecyclerView 的个性化配置十分简单,依托于 MVP 的 “配置解耦” 特性,使用者无需知道内部的实现细节,仅通过实现 Config 类即可完成功能的定制和扩展。此外,在不设置自定义配置的情况下,LinkageRecyclerView 最少只需 一行代码即可运行起来。RxMagicEleme LinearEleme Grid目标Linkage-RecyclerView 的目标是:一行代码即可接入二级联动列表。除了一键接入而省去 99% 不必要的、复杂的、重复的工作外,你还可以从这个开源项目获得的内容包括:整洁的代码风格和标准的资源命名规范。MVP 架构在第三库中的最佳实践:使用者无需了解内部逻辑,通过实现接口即可轻松完成个性化配置。优秀的代码分层和封装思想,在不做任何个性化配置的情况下,一行代码即可接入。主体工程基于前沿的、遵循关注点分离的 JetPack MVVM 架构。AndroidX 和 Material Design 2 的全面使用。ConstraintLayout 约束布局的最佳实践。绝不使用 Dagger,绝不使用奇技淫巧、编写艰深晦涩的代码。如果你正在思考 如何为项目挑选合适的架构 的话,这个项目值得你参考!简单使用:1.在 build.gradle 中添加对该库的依赖。implementation 'com.kunminx.linkage:linkage-recyclerview:1.2.0'2.依据默认的联动实体类(DefaultLinkageItem)的结构准备一串 JSON。// DefaultLinkageItem.ItemInfo 包含三个字段: String title //二级选项的标题(必填) String group //二级选项所在分组的名称,要和对应的一级选项的标题相同(必填) String content //二级选项的内容(选填)[   {     "header": "优惠",     "isHeader": true   },   {     "isHeader": false,     "t": {       "content": "好吃的食物,增肥神器,有求必应",       "group": "优惠",       "title": "全家桶"     }   },   {     "header": "热卖",     "isHeader": true   } ]3.在布局中引入 LinkageRecyclerView 。<?xml version="1.0" encoding="utf-8"?>      4.在代码中解析 JSON,最少只需一行代码即可完成初始化。List items = gson.fromJson(...); //一行代码完成初始化 linkage.init(items);个性化配置:该库为一级和二级 Adapter 分别准备了 Config 接口(ILevelPrimaryAdapterConfig 和 ILevelSecondaryAdapterConfig),自定义配置时,即是去实现这两个接口,来取代默认的配置。之所以设置成接口的形式,而非 Builder 的形式,是因为二级联动列表内部的联动
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值