首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >CardView包装

CardView包装
EN

Stack Overflow用户
提问于 2014-10-23 18:10:02
回答 2查看 3K关注 0票数 0

我在我的应用程序中有一个卡片视图(使用支持库),如果它们不是都放在一排的话,我希望卡片被包装起来。目前,它们只是垂直堆叠。如果他们是列表中唯一的元素,那么是否有一种方法可以让他们不仅包装起来,而且还可以填充整个家长呢?

理想情况下,我希望每行两张卡片,然后让它们在这一点上换一条新的行。

包含回收视图的视图:

代码语言:javascript
复制
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/my_rootlayout"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">

<LinearLayout
    android:id="@+id/my_window"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:layout_centerInParent="true"
    android:orientation="vertical">

    <TextView
        android:id="@+id/my_headertext"
        style="@style/roboto_header_text_black"
        android:layout_width="wrap_content"
        android:layout_height="0dp"
        android:layout_centerHorizontal="true"
        android:layout_gravity="center_horizontal"
        android:layout_weight=".15"
        android:gravity="center"
        android:padding="@dimen/device_padding"
        android:text="@string/en_us_my_header"
        android:textIsSelectable="false" />

    <android.support.v7.widget.RecyclerView
        android:id="@+id/my_list"
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:layout_weight=".85"

        />
</LinearLayout>

CardView:

代码语言:javascript
复制
<android.support.v7.widget.CardView xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:card_view="http://schemas.android.com/apk/res-auto"
android:layout_width="250dp"
android:layout_height="wrap_content"
android:orientation="vertical"
card_view:cardCornerRadius="2dp">

<LinearLayout
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:layout_weight="1"
    android:orientation="vertical">
<RelativeLayout
    android:layout_width="match_parent"
    android:layout_height="200dp"
    android:orientation="horizontal">

    <ImageView
        android:id="@+id/image_thumbnail"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:layout_centerHorizontal="true"
        android:gravity="center"
        android:src="@drawable/default_image"
        android:scaleType="centerCrop"
        android:adjustViewBounds="true" />

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="40dp"
        android:orientation="horizontal"
        android:layout_alignParentBottom="true"
        android:layout_alignParentStart="true"
        android:background="#99000000"
        android:gravity="center_vertical"
        android:paddingLeft="8dp">

        <TextView
            android:id="@+id/my_listitem_title_text"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:singleLine="true"
            android:text="This is my title"
            android:textColor="@color/white"
            android:textSize="20sp"
            android:fontFamily="sans-serif-light"
            android:paddingLeft="8dp"
            android:paddingRight="8dp"
            android:paddingTop="4dp"
            android:paddingBottom="4dp" />

    </LinearLayout>
</RelativeLayout>

    <ProgressBar
        android:layout_width="match_parent"
        android:layout_height="8dp"
        android:indeterminate="false"
        style="?android:progressBarStyleHorizontal"
        android:progress="45" />

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="horizontal"
        android:paddingLeft="8dp"
        android:paddingRight="8dp"
        android:paddingTop="2dp"
        android:paddingBottom="2dp">
    <TextView
        android:id="@+id/code_text_block"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:textColor="@color/black"
        android:textSize="14sp"
        android:text="ABC" />

    <TextView
    android:id="@+id/my_listitem_id_text"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="#123456"
        android:textColor="@color/black"
    android:layout_marginLeft="8dp" />
    </LinearLayout>

    <TextView
        android:id="@+id/my_listitem_date_text"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:textSize="14sp"
        android:paddingLeft="8dp"
        android:paddingRight="8dp"
        android:paddingTop="2dp"
        android:paddingBottom="2dp"
        android:text="Nov 5 - Nov 12, 2016"
        android:textColor="#7D7D7D" />

    <LinearLayout
        android:orientation="horizontal"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:paddingLeft="8dp"
        android:paddingRight="8dp"
        android:paddingTop="4dp"
        android:paddingBottom="4dp">

        <Button
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="Download"
            android:textAllCaps="true"
            android:fontFamily="sans-serif"
            android:textStyle="bold"
            android:id="@+id/download_button"
            android:background="@color/white"
            android:textColor="@color/black"
            android:paddingLeft="4dp"
            android:paddingRight="4dp"
            android:paddingTop="8dp"
            android:paddingBottom="8dp" />
    </LinearLayout>

</LinearLayout>

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2015-02-22 16:28:58

是的,您必须使用GridLayout作为@随机性6174 ,使用这个代码为指南,它可以做您想做的事情。

请注意这一部分,其中它声明了RecyclerView LayoutManager (MainActivity.java)

代码语言:javascript
复制
mRecyclerView = (RecyclerView) findViewById(R.id.recyclerView);
mLayoutManager = new StaggeredGridLayoutManager(2, StaggeredGridLayoutManager.VERTICAL);
mRecyclerView.setLayoutManager(mLayoutManager);

希望这能帮到你。

票数 1
EN

Stack Overflow用户

发布于 2014-10-23 20:21:29

我想你可能想在这里使用一个流布局。据我所知,Android没有内置的流布局类,但是在其他地方有很多东西可以找到,比如这一个

但是,由于您希望显示可能都具有相同大小的卡片,也许您也可以使用GridLayout并以编程方式调整列数以满足您的需要。

祝好运!

/edit:没关系,我刚学到CardView是什么。我以为你想展示扑克牌。也许流程布局仍然适合你,但我肯定误解了这个问题。是我的错。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/26534533

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档