如何保持ImageView的常量宽度和高度

时间:2017-07-06 13:26:12

标签: c# android xamarin.android

我有一个recyclerView,显示了imageView(缩略图大小)和textView的列表。每当我用大量文本填充textViews时,imageView会缩小并且高度会增加。 textView也被包裹在左边,在右边留下了很多空白区域。下面是我正在谈论的图像。即使我的textView有很多文本,如何使缩略图宽度和高度固定,以保持图像质量。

enter image description here

* axml **

<?xml version="1.0" encoding="utf-8"?>
<android.support.v7.widget.CardView xmlns:tools="http://schemas.android.com/tools"
    xmlns:card_view="http://schemas.android.com/apk/res-auto"
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/card_view"
    android:background="#E2E2E2"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_marginBottom="4dp"
    card_view:cardCornerRadius="7dp"
    android:layout_marginRight="4dp"
    android:layout_marginLeft="4dp">
    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="vertical"
        android:padding="12dp">
        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:orientation="horizontal"
            android:weightSum="100">
            <ImageView
                android:layout_width="0dp"
                android:layout_height="match_parent"
                android:layout_weight="25"
                android:adjustViewBounds="true"
                android:scaleType="centerCrop"
                android:id="@+id/imageView" />
            <LinearLayout
                android:layout_width="0dp"
                android:layout_height="match_parent"
                android:layout_weight="63"
                android:orientation="vertical"
                android:paddingRight="10dp"
                android:paddingLeft="10dp"
                android:paddingTop="7dp"
                android:paddingBottom="7dp">
                <TextView
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:textAppearance="?android:attr/textAppearanceMedium"
                    android:textSize="18sp"
                    android:textColor="#333333"
                    android:text="Caption"
                    android:layout_weight="1"
                    android:ellipsize="none"
                    android:maxLines="100"
                    android:scrollHorizontally="false"
                    android:id="@+id/txt_title"
                    android:textStyle="bold"
                    android:fontFamily="Times New Roman"
                    android:layout_marginLeft="4dp"
                    android:layout_marginTop="10dp"
                    android:layout_gravity="center_vertical|left" />
                <TextView
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:textAppearance="?android:attr/textAppearanceMedium"
                    android:textSize="14sp"
                    android:textColor="#333333"
                    android:text="Caption"
                    android:layout_weight="1"
                    android:ellipsize="none"
                    android:maxLines="100"
                    android:scrollHorizontally="false"
                    android:id="@+id/textView"
                    android:fontFamily="Times New Roman"
                    android:layout_marginLeft="4dp"
                    android:layout_marginTop="10dp"
                    android:layout_gravity="center_vertical|left" />
                <TextView
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:textAppearance="?android:attr/textAppearanceMedium"
                    android:textSize="13sp"
                    android:textColor="#808080"
                    android:text="Caption"
                    android:layout_weight="1"
                    android:ellipsize="none"
                    android:maxLines="100"
                    android:scrollHorizontally="false"
                    android:id="@+id/pub_date"
                    android:fontFamily="Times New Roman"
                    android:layout_marginLeft="4dp"
                    android:layout_marginTop="10dp"
                    android:layout_gravity="center_vertical|left" />
            </LinearLayout>
        </LinearLayout>
    </LinearLayout>
    <android.support.v7.widget.RecyclerView
        android:id="@+id/recyclerView"
        android:scrollbars="vertical"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent" />
</android.support.v7.widget.CardView>

3 个答案:

答案 0 :(得分:1)

请参阅此javadoc以获取ImageView的setMaxWidth方法:

  

为此视图提供最大宽度的可选参数。只要   如果setAdjustViewBounds(boolean)已设置为true,则有效。设置一个   图像最大为100 x 100,同时保留原始图像   纵横比,请执行以下操作:

     

1)将adjustViewBounds设置为true

     

2)设定   maxWidth和maxHeight为100

     

3)设置高度和宽度布局   params to WRAP_CONTENT。

     

请注意,此视图使用此视图仍可能小于100 x 100   如果原始图像很小,则接近。将图像设置为固定   size,在布局参数中指定该大小然后使用   setScaleType(android.widget.ImageView.ScaleType)确定如何   使图像适合边界。

答案 1 :(得分:0)

第1步:删除此行:

android:weightSum="100"

步骤2:在此行中将63更改为1:

android:layout_weight="63"

步骤3:更改以下行:

android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_weight="25"

这个:

android:layout_width="wrap_content"
android:layout_height="match_parent"

或者如果你想要固定宽度:

android:layout_width="150dp"
android:layout_height="match_parent"

答案 2 :(得分:0)

使用此

<?xml version="1.0" encoding="utf-8"?>
<android.support.v7.widget.CardView xmlns:tools="http://schemas.android.com/tools"
    xmlns:card_view="http://schemas.android.com/apk/res-auto"
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/card_view"
    android:background="#E2E2E2"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_marginBottom="4dp"
    card_view:cardCornerRadius="7dp"
    android:layout_marginRight="4dp"
    android:layout_marginLeft="4dp">
    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="vertical"
        android:padding="12dp">
        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:orientation="horizontal"
            android:weightSum="100">
            <ImageView
                android:layout_width="0dp"
                **android:layout_height="wrap_content"**
                android:layout_weight="25"
                android:adjustViewBounds="true"
                android:scaleType="centerCrop"
                android:src="@mipmap/ic_launcher"
                android:id="@+id/imageView" />
            <LinearLayout
                android:layout_width="0dp"
                **android:layout_height="wrap_content"**
                android:layout_weight="63"
                android:orientation="vertical"
                android:paddingRight="10dp"
                android:paddingLeft="10dp"
                android:paddingTop="7dp"
                android:paddingBottom="7dp">
                <TextView
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:textAppearance="?android:attr/textAppearanceMedium"
                    android:textSize="18sp"
                    android:textColor="#333333"
                    android:text="Captionjkdhka asdgasidga sgdia g Caption vCaptionCaptionCaptionvCaptionCaption"
                    android:layout_weight="1"
                    android:ellipsize="none"
                    android:maxLines="100"
                    android:scrollHorizontally="false"
                    android:id="@+id/txt_title"
                    android:textStyle="bold"
                    android:fontFamily="Times New Roman"
                    android:layout_marginLeft="4dp"
                    android:layout_marginTop="10dp"
                    android:layout_gravity="center_vertical|left" />
                <TextView
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:textAppearance="?android:attr/textAppearanceMedium"
                    android:textSize="14sp"
                    android:textColor="#333333"
                    android:text="Caption"
                    android:layout_weight="1"
                    android:ellipsize="none"
                    android:maxLines="100"
                    android:scrollHorizontally="false"
                    android:id="@+id/textView"
                    android:fontFamily="Times New Roman"
                    android:layout_marginLeft="4dp"
                    android:layout_marginTop="10dp"
                    android:layout_gravity="center_vertical|left" />
                <TextView
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:textAppearance="?android:attr/textAppearanceMedium"
                    android:textSize="13sp"
                    android:textColor="#808080"
                    android:text="Caption"
                    android:layout_weight="1"
                    android:ellipsize="none"
                    android:maxLines="100"
                    android:scrollHorizontally="false"
                    android:id="@+id/pub_date"
                    android:fontFamily="Times New Roman"
                    android:layout_marginLeft="4dp"
                    android:layout_marginTop="10dp"
                    android:layout_gravity="center_vertical|left" />
            </LinearLayout>
        </LinearLayout>
    </LinearLayout>
</android.support.v7.widget.CardView>

问题在于图像视图和布局的高度