# greedo-layout-for-android **Repository Path**: lengyueming/greedo-layout-for-android ## Basic Information - **Project Name**: greedo-layout-for-android - **Description**: Full aspect ratio grid LayoutManager for Android's RecyclerView - **Primary Language**: Unknown - **License**: MIT - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 0 - **Created**: 2020-11-21 - **Last Updated**: 2020-12-19 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README # Greedo Layout for Android A drop-in custom layout manager for Android RecyclerViews to layout a grid of photos while respecting their aspect ratios. ![image](screenshot.png) ## Setup Download the latest release via Gradle: ``` groovy repositories { maven { url 'https://github.com/500px/greedo-layout-for-android/raw/master/releases/' } } dependencies { compile 'com.fivehundredpx:greedo-layout:1.5.1' } ``` ## Usage See the sample project for a complete solution on how to use GreedoLayout. Below are the specific steps. ```java // Create an instance of the GreedoLayoutManager and pass it to the RecyclerView MyRecyclerAdapter recyclerAdapter = new MyRecyclerAdapter(this); GreedoLayoutManager layoutManager = new GreedoLayoutManager(recyclerAdapter); RecyclerView recyclerView = (RecyclerView)findViewById(R.id.recycler_view); recyclerView.setLayoutManager(layoutManager); recyclerView.setAdapter(recyclerAdapter); // Set the max row height in pixels layoutManager.setMaxRowHeight(300); // If you would like to add spacing between items (Note, MeasUtils is in the sample project) int spacing = MeasUtils.dpToPx(4, this); recyclerView.addItemDecoration(new GreedoSpacingItemDecoration(spacing)); ``` And then, in your RecyclerView adapter, or some other class of your choosing, implement `SizeCalculatorDelegate`. This implementation got passed to the layout manager above. ```java public class MyRecyclerAdapter extends RecyclerView.Adapter implements SizeCalculatorDelegate { @Override public double aspectRatioForIndex(int index) { // Return the aspect ratio of your image at the given index } } ``` ## License GreedoLayout is released under the MIT license. See LICENSE for details.