web-dev-qa-db-ja.com

LinearLayoutManagerでExpandableアイテムを実装する方法(Android Lで導入)

RecyclerViewは、Android Lで導入されており、AppCompat v7ライブラリの一部です。次に、この新しいRecyclerViewでアプリを更新して、 ListViews。そうするために、LayoutManagerRecyclerViewを設定する場合は、正常に機能するLinearLayoutManagerを使用しています。

ここに難しいものがあります:ExpandableListViewRecyclerViewに変更したい場合。 Googleが「ExpandableLayoutManager」を作成していないため、これは非常にトリッキーであり、私はこれを達成できません。

documentation は子について言及していますが、それはRecyclerViewのルートビューの子ではなく、子自身のようです。

誰かが回避策やそれについての手がかりを持っていますか?または、少なくとも自分のLayoutManagerを実装できるようにするための開始点などの情報。

20
Lucas S.

これは library でアイテムを「セクション」にグループ化するのに役立ち、この example に続く展開/折りたたみ機能を実装できます。

まず、セクションクラスを作成します。

class MySection extends StatelessSection {

    String header;
    List<String> list;
    boolean expanded = true;

    public MySection(String header, List<String> list) {
        // call constructor with layout resources for this Section header and items 
        super(R.layout.section_header, R.layout.section_item);
        this.myHeader = header;
        this.myList = list;
    }

    @Override
    public int getContentItemsTotal() {
        return expanded? list.size() : 0;
    }

    @Override
    public RecyclerView.ViewHolder getHeaderViewHolder(View view) {
        return new HeaderViewHolder(view);
    }

    @Override
    public void onBindHeaderViewHolder(RecyclerView.ViewHolder holder) {
        final HeaderViewHolder headerHolder = (HeaderViewHolder) holder;

        headerHolder.tvTitle.setText(title);

        headerHolder.rootView.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                expanded = !expanded;
                headerHolder.imgArrow.setImageResource(
                        expanded ? R.drawable.ic_keyboard_arrow_up_black_18dp : R.drawable.ic_keyboard_arrow_down_black_18dp
                );
                sectionAdapter.notifyDataSetChanged();
            }
        });
    }

    @Override
    public RecyclerView.ViewHolder getItemViewHolder(View view) {
        // return a custom instance of ViewHolder for the items of this section
        return new MyItemViewHolder(view);
    }

    @Override
    public void onBindItemViewHolder(RecyclerView.ViewHolder holder, int position) {
        MyItemViewHolder itemHolder = (MyItemViewHolder) holder;

        // bind your view here
        itemHolder.tvItem.setText(list.get(position));
    }
}

次に、セクションのインスタンスを作成し、アダプターを設定します。

// Create an instance of SectionedRecyclerViewAdapter 
SectionedRecyclerViewAdapter sectionAdapter = new SectionedRecyclerViewAdapter();

// Add your Sections
sectionAdapter.addSection(new MySection("Section 1", Arrays.asList(new String[] {"Item 1", "Item 2", "Item 3", "Item 4" })));
sectionAdapter.addSection(new MySection("Section 2", Arrays.asList(new String[] {"Item 1", "Item 2" })));

// Set up your RecyclerView with the SectionedRecyclerViewAdapter
RecyclerView recyclerView = (RecyclerView) findViewById(R.id.recyclerview);
recyclerView.setLayoutManager(new LinearLayoutManager(getContext()));
recyclerView.setAdapter(sectionAdapter);
1
Gustavo