【问题标题】:How to maintain a constant ImageView width and and height如何保持恒定的 ImageView 宽度和高度
【发布时间】:2017-07-06 21:47:57
【问题描述】:

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

*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>

【问题讨论】:

  • 只是一个注释。如果一个 ViewGroup 只有一个孩子,那么您很可能不需要使用它。在这种情况下,如果您相应地更改第二个 LinearLayout 的属性,则可以消除第一个 LinearLayout。

标签: c# android xamarin.android


【解决方案1】:

ImageView的setMaxWidth方法参考这个javadoc:

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

1) 将 adjustViewBounds 设置为 true

2) 设置 maxWidth 和 maxHeight 为 100

3) 设置高宽布局 参数为 WRAP_CONTENT。

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

【讨论】:

    【解决方案2】:

    第 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"
    

    【讨论】:

      【解决方案3】:

      使用这个

      <?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>
      

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

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 1970-01-01
        • 2014-05-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 2014-06-12
        • 1970-01-01
        • 2011-06-19
        相关资源
        最近更新 更多