Попробуйте этот код .....

я есть макет, который содержит некоторые текстовые поля и фоновое изображение, которое отображается в верхней части моей деятельности. Мне бы хотелось, чтобы фоновое изображение масштабировалось, чтобы обернуть содержимое (не заботясь о соотношении сторон). Однако изображение больше содержимого, поэтому макет вместо этого оборачивает фоновое изображение. Вот мой оригинальный код:

<RelativeLayout 
    android:layout_width="fill_parent"
    android:id="@+id/HeaderList" 
    android:layout_gravity="top"
    android:layout_height="wrap_content" 
    android:background="@drawable/header">
    <TextView 
        android:layout_height="wrap_content"
        android:layout_width="wrap_content" 
        android:id="@+id/NameText"
        android:text="Jhn Doe" 
        android:textColor="#FFFFFF"
        android:textSize="30sp" 
        android:layout_alignParentLeft="true"
        android:layout_alignParentTop="true" 
        android:paddingLeft="4dp"
        android:paddingTop="4dp" 
    />
    <TextView 
        android:layout_height="wrap_content"
        android:layout_width="wrap_content" 
        android:textColor="#FFFFFF"
        android:layout_alignParentLeft="true"
        android:id="@+id/HoursText"
        android:text="170 hours" 
        android:textSize="23sp"
        android:layout_below="@+id/NameText" 
        android:paddingLeft="4dp" 
    />
</RelativeLayout>

После поиска некоторых других вопросов, я нашел эти два:

Как обернуть представления контента, а не рисовать фон?

Масштабировать Drawable или фоновое изображение?

Основываясь на этом, я создал FrameLayout с ImageView, показывающим фон. К сожалению, я до сих пор не могу заставить его работать. Я хочу, чтобы высота фонового изображения уменьшалась / расширялась с размерами текстовых представлений, но с FrameLayout ImageView соответствует размеру своего родителя, и я не могу найти способ сделать родительский размер подходящим для размер макета текстового представления. Вот мой обновленный код:

<FrameLayout 
    android:layout_width="fill_parent"
    android:layout_height="wrap_content" >

    <ImageView android:src="@drawable/header"
        android:layout_width="fill_parent" 
        android:scaleType="fitXY"
        android:layout_height="fill_parent" 
        />
    <RelativeLayout 
        android:layout_width="fill_parent"
        android:id="@+id/HeaderList" 
        android:layout_gravity="top"
        android:layout_height="wrap_content"
        >
        <TextView 
            android:layout_height="wrap_content"
            android:layout_width="wrap_content" 
            android:id="@+id/NameText"
            android:text="John Doe" 
            android:textColor="#FFFFFF"
            android:textSize="30sp" 
            android:layout_alignParentLeft="true"
            android:layout_alignParentTop="true" 
            android:paddingLeft="4dp"
            android:paddingTop="4dp" 
            />
        <TextView 
            android:layout_height="wrap_content"
            android:layout_width="wrap_content" 
            android:textColor="#FFFFFF"
            android:layout_alignParentLeft="true" 
            android:id="@+id/HoursText"
            android:text="170 hours" 
            android:textSize="23sp"
            android:layout_below="@+id/NameText" 
            android:paddingLeft="4dp" 
            />
    </RelativeLayout>
</FrameLayout>

Кто-нибудь есть какие-либо предложения о том, как лучше сделать масштаб изображения до размера содержимого некоторого макета? Меня не интересует соотношение сторон изображения, так как это не имеет значения, я просто хочу, чтобы оно заполняло фон.

Спасибо!

Ответы на вопрос(8)

FrameLayout (wrapcontent, wrapcontent)ImageView (соответствует родителю, соответствует родителю) // ваш фонLinearLayout (wrapcontent, wrapcontent)Все ваше содержимое идет внутри этого линейного макета или любого другого типа, что вы хотите
 Umair07 апр. 2015 г., 05:37
Вы можете определить размер ImageView ... и использовать scaleType, чтобы соответствовать изображению соответственно
 Richard01 апр. 2015 г., 16:30
Для меня это просто не работает, потому что ImageView больше, чем его контейнер :(

но вместо FrameLayout и используйте android: scaleType = "fitXY". Переместите imageView в RealtiveLayout, который содержит текстовые представления android: id = "@ + id / HeaderList" и удалите фоновый android: background = "@ drawable / header "на этом уровне.

<?xml version="1.0" encoding="utf-8"?> 
<RelativeLayout 
         android:id="@+id/principal"
         android:layout_width="fill_parent"
         android:layout_height="fill_parent"
         android:background="@drawable/header" >

     <RelativeLayout 
         android:layout_width="fill_parent"
         android:id="@+id/HeaderList" 
         android:layout_gravity="top"
         android:layout_height="wrap_content" >  


         <ImageView
             android:id="@+id/backImg"
             android:layout_width="fill_parent"
             android:layout_height="fill_parent"
             android:layout_centerInParent="true"
             android:adjustViewBounds="true"
             android:background="@color/blancotransless"
             android:src="@drawable/header"
             android:scaleType="fitXY" >
         </ImageView>

             <TextView 
                 android:layout_height="wrap_content"
                 android:layout_width="wrap_content" 
                 android:id="@+id/NameText"
                 android:text="John Doe" 
                 android:textColor="#FFFFFF"
                 android:textSize="30sp" 
                 android:layout_alignParentLeft="true"
                 android:layout_alignParentTop="true" 
                 android:paddingLeft="4dp"
                 android:paddingTop="4dp" 
                 />
             <TextView 
                 android:layout_height="wrap_content"
                 android:layout_width="wrap_content" 
                 android:textColor="#FFFFFF"
                 android:layout_alignParentLeft="true" 
                 android:id="@+id/HoursText"
                 android:text="170 hours" 
                 android:textSize="23sp"
                 android:layout_below="@+id/NameText" 
                 android:paddingLeft="4dp" 
                 />
         </RelativeLayout> 
      </RelativeLayout>

Более или менее это должно работать!

но если вы динамически устанавливаете фоновое изображение на onCreate, это может сработать. Размер макета уже должен быть установлен.

 greg7gkb06 февр. 2012 г., 19:58
Я попробовал это, и для моей ситуации это не сработало. Размер группы представления по-прежнему был изменен и теперь содержит фоновое изображение.

Попробуйте этот код .....

<LinearLayout 
   android:layout_width="fill_parent"
   android:id="@+id/HeaderList" 
   android:orientation="vertical"
   android:layout_gravity="top"
   android:layout_height="wrap_content" 
   android:background="@drawable/header">
<TextView 
    android:layout_height="wrap_content"
    android:layout_width="wrap_content" 
    android:id="@+id/NameText"
    android:text="Jhn Doe" 
    android:textColor="#FFFFFF"
    android:textSize="30sp" 
    android:paddingLeft="4dp"
    android:paddingTop="4dp" 
/>
<TextView 
    android:layout_height="wrap_content"
    android:layout_width="wrap_content" 
    android:textColor="#FFFFFF"
    android:id="@+id/HoursText"
    android:text="170 hours" 
    android:textSize="23sp" 
    android:paddingLeft="4dp" 
/>
</LinearLayout>

что я делал нечто подобное в прошлом, попробуйте поиграть с настройкой гравитации в вашем изображении, я думаю, что один из них должен делать то, что вам нужно.

 bjg22222 янв. 2011 г., 04:13
Спасибо за предложение. Я пытался поиграть с параметром layout_gravity как в ImageView, так и в RelativeLayout, но мне не повезло. Я пробовал оба варианта «клип» и «заливка», а также различные их комбинации и другие значения позиционирования, и ни один из них, похоже, не имел никакого эффекта. Вы помните, какие значения удельного веса вы использовали?

Вы можете использовать это:

<ImageView
...
android:scaleType="fitXY"
>

Надеюсь, это помогло)))

Создайте отрисовываемый XML, скажем, mybackground.xml

<?xml version="1.0" encoding="utf-8"?>
<bitmap xmlns:android="http://schemas.android.com/apk/res/android"
    android:src="@drawable/header"
    android:gravity="fill" />

Затем в вашем RelativeLayout в первом фрагменте кода использовать

android:background="@drawable/mybackground"
 jfcartier13 дек. 2013 г., 09:08
+1 это не работает, android: gravity = "fill" только повышают
 jontro14 мая 2012 г., 18:18
Только что попробовал, это не работает.

и единственное решение, которое я мог найти, было этим:

<RelativeLayout
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    >

    <View
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:background="@drawable/some_image"
        android:layout_alignTop="@+id/actual_content"
        android:layout_alignBottom="@id/actual_content"
        android:layout_alignLeft="@id/actual_content"
        android:layout_alignRight="@id/actual_content"
        />

    <LinearLayout
        android:id="@id/actual_content"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_alignParentTop="true"
        >

       <!-- more stuff ... -->

    </LinearLayout>

</RelativeLayout>
 Kevin Robatel26 июл. 2016 г., 12:02
Для людей, которые не хотят терять 10 минут, для ссылки на представление, объявленное после, необходимо добавить@+id/ экземпляр@id/ для создания идентификатора.
 kev04 февр. 2014 г., 15:55
это работало с несколькими модификациями для меня. - использовал ImageView вместо View - добавлен android: scaleType = "fitXY" в ImageView

Ваш ответ на вопрос