Giter Site home page Giter Site logo

beerus11 / sectioned-recyclerview Goto Github PK

View Code? Open in Web Editor NEW

This project forked from pflammertsma/sectioned-recyclerview

0.0 1.0 0.0 1 MB

Implement a multi-sectioned RecyclerView using a custom adapter interface.

Home Page: https://aidanfollestad.com

License: Apache License 2.0

Java 100.00%

sectioned-recyclerview's Introduction

Sectioned RecyclerView

Sectioned RecyclerView allows you to easily split a RecyclerView into sections with headers.


Gradle Dependency

jCenter Build Status License

The Gradle dependency is available via jCenter. jCenter is the default Maven repository used by Android Studio.

Dependency

Add this to your module's build.gradle file:

dependencies {
    // ... other dependencies
    compile 'com.afollestad:sectioned-recyclerview:0.4.0'
}

Adapter

Here's a basic example:

public class MainAdapter extends SectionedRecyclerViewAdapter<MainAdapter.MainVH> {

  @Override
  public int getSectionCount() {
    return 20; // number of sections.
  }

  @Override
  public int getItemCount(int section) {
    return 8; // number of items in section (section index is parameter).
  }

  @Override
  public void onBindHeaderViewHolder(MainVH holder, int section, boolean expanded) {
    // Setup header view.
  }

  @Override
  public void onBindViewHolder(MainVH holder, int section, int relativePosition, int absolutePosition) {
    // Setup non-header view.
    // 'section' is section index.
    // 'relativePosition' is index in this section.
    // 'absolutePosition' is index out of all non-header items.
    // See sample project for a visual of how these indices work.
  }

  @Override
  public MainVH onCreateViewHolder(ViewGroup parent, int viewType) {
    // Change inflated layout based on 'header'.
    int layoutRes = viewType == VIEW_TYPE_HEADER ? R.layout.header : R.layout.normal;
    View v = LayoutInflater.from(parent.getContext())
      .inflate(layoutRes, parent, false);
    return new MainVH(v);
  }

  public static class MainVH 
    extends SectionedViewHolder
    implements View.OnClickListener {

    public MainVH(View itemView) {
      super(itemView);
      // Setup view holder.
      // You'd want some views to be optional, e.g. for header vs. normal.
      itemView.setOnClickListener(this);
    }
    
    @Override
    public void onClick(View view) {
      // SectionedViewHolder exposes methods such as:
      boolean isHeader = isHeader();
      ItemCoord position = getRelativePosition();
      int section = position.section();
      int relativePos = position.relativePos();
    }
  }
}

Expanding and Collapsing Sections

Expanding and collapsing sections is easy:

MainAdapter adapter = // ...
adapter.expandSection(int);
adapter.collapseSection(int);
adapter.toggleSectionExpanded(int);
boolean isExpanded = adapter.isSectionExpanded(int);

Hiding Empty Sections

You can tell the adapter to hide sections which have no items.

MainAdapter adapter = // ...
adapter.shouldShowHeadersForEmptySections(false);

Notifying Adapter of Section Changes

Like notifyDataSetChanged(), notifyItemInserted(int), notifyItemRemoved(int) (etc.), the sectioned adapter provides a method called notifySectionChanged(int). It notifies the adapter that every item in that section has changed, rather than every item in the whole adapter. onBindViewHolder will be called again for each item in the section.

You should not use this method when a section has been added or removed. You should always use notifyDataSetChanged() for that to avoid data corruption in the adapter.


Layout Manager

If you're using a LinearLayoutManager, you're all set. If you're using a GridLayoutManager, you need to tell the adapter:

GridLayoutManager manager = // ...
adapter.setLayoutManager(manager);

This is vital to getting headers to span all columns.

sectioned-recyclerview's People

Contributors

afollestad avatar cachapa avatar agatti avatar pflammertsma avatar d-fournier avatar

Watchers

Anurag Goel avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.