RecyclerView
を使用する垂直GridLayoutManager
があります。各列を中央に配置しますが、列は左端から始まります。次の写真では、私が話していることを見ることができます。 columnsい配色を使用して、列と背景を説明しました。緑はRecyclerView
の各アイテムの背景であり、赤はRecyclerView
自体の背景です。
私はそれを設定しています:
mRecyclerView.setLayoutManager(new GridLayoutManager(this, 2));
Column_item.xmlは次のとおりです。
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:Android="http://schemas.Android.com/apk/res/Android"
Android:layout_width="120dp"
Android:layout_height="180dp"
Android:orientation="vertical"
Android:padding="4dp">
<ImageView
Android:id="@+id/movie_column_photo"
Android:layout_width="80dp"
Android:layout_height="120dp"/>
<TextView
Android:id="@+id/movie_column_title"
Android:layout_width="wrap_content"
Android:layout_height="wrap_content"/>
</LinearLayout>
Recyclerview xmlは次のとおりです。
<LinearLayout
Android:layout_width="match_parent"
Android:layout_height="wrap_content">
<Android.support.v7.widget.RecyclerView
Android:id="@+id/company_details_recyclerview"
Android:layout_width="match_parent"
Android:layout_height="match_parent"
Android:scrollbars="vertical">
</Android.support.v7.widget.RecyclerView>
</LinearLayout>
列アイテムを列の幅に合わせながら、すべてを中央に配置してみてください。
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:Android="http://schemas.Android.com/apk/res/Android"
Android:layout_width="match_parent"
Android:layout_height="180dp"
Android:orientation="vertical"
Android:padding="4dp">
<ImageView
Android:id="@+id/movie_column_photo"
Android:layout_width="80dp"
Android:layout_height="120dp"
Android:layout_gravity="center_horizontal"/>
<TextView
Android:id="@+id/movie_column_title"
Android:layout_width="match_parent"
Android:layout_height="wrap_content"
Android:gravity="center"/>
</LinearLayout>