2013-02-19 2 views
0

Я пытаюсь создать приложение для Android, которое имеет ScrollView, где изображение (удаленный URL) заполняет экран (с marginTop, marginLeft, marginRight и marginBottom, установленным около 5dp) и при прокрутке вниз вы найдете дополнительные компоненты пользовательского интерфейса.Масштабировать удаленное изображение на высоту и ширину устройства

Мне сложно масштабировать изображение до точных размеров. Размер изображения не контролируется. Некоторые могут быть маленькими, некоторые из них могут быть большими. Если он маленький, я бы хотел растянуть его, чтобы он соответствовал экрану. Мой XML выглядит следующим образом:

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

    <ProgressBar 
    android:layout_width="100dp" 
    android:layout_height="100dp" 
    android:indeterminate="true" 
    android:layout_centerInParent="true" 
    android:visibility="invisible" 
    android:id="@+id/movieImageLoading"/> 

    <ImageView android:id="@+id/headerImage" 
    android:layout_width="fill_parent" 
    android:layout_height="wrap_content" 
    android:layout_gravity="center" 
    android:scaleType="fitXY" 
    android:layout_marginTop="5dp" 
    android:layout_marginLeft="5dp" 
    android:layout_marginRight="5dp" 
    android:layout_marginBottom="5dp" 
    android:contentDescription="@string/movie_image"></ImageView> 

    <Button 
     android:id="@+id/save2" 
     android:layout_width="150dp" 
     android:layout_marginTop="10dp" 
     android:layout_height="wrap_content" 
     android:layout_centerHorizontal="true" 
     android:layout_below="@+id/headerImage" 
     android:text="save" /> 

</RelativeLayout> 

что неправильно, может кто-нибудь помочь мне, пожалуйста?

Спасибо ..

+0

Высказывания «это неправильно» не полезно. Что не так? Какое поведение вы видите? В идеале, разместите снимок экрана о том, что происходит, и макет того, как вы хотите, чтобы он выглядел. –

+0

Hi Matt. Определили поведение в ответе Пратика ниже. Скриншоты: http://postimage.org/image/wthseojsf/ http://postimage.org/image/is2rtogah/ – sharath

+0

Я не пробовал прямо сейчас, но не должен «centerInside» быть желаемым типом scaletype ? Из документации, похоже, делается именно то, что вы хотите. EDIT: см. Http://developer.android.com/reference/android/widget/ImageView.ScaleType.html – Thrakbad

ответ

0

попробовать этот макет

Сделайте свою кнопку в нижней части, чтобы установить и настроить вид изображения выше кнопок с заполняющим родителем и последним указать индикатор

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    android:layout_width="fill_parent" 
    android:layout_height="fill_parent" > <!-- here make wrap to fill --> 
    <Button 
     android:id="@+id/save2" 
     android:layout_width="150dp" 
     android:layout_height="wrap_content" 
     android:layout_centerHorizontal="true" 
     android:layout_marginTop="10dp" 
     android:text="save" 
     android:layout_alignParentBottom="true" /> 

    <ImageView 
     android:id="@+id/headerImage" 
     android:layout_width="fill_parent" 
     android:layout_height="fill_parent" 
     android:layout_above="@+id/save2" 
     android:layout_gravity="center" 
     android:layout_margin="5dp" 
     android:contentDescription="movie_image" 
     android:scaleType="fitXY" > 
    </ImageView> 

    <ProgressBar 
     android:id="@+id/movieImageLoading" 
     android:layout_width="100dp" 
     android:layout_height="100dp" 
     android:layout_centerInParent="true" 
     android:indeterminate="true" 
     android:visibility="invisible" /> 
</RelativeLayout> 
+0

Спасибо за ответ Pratik. Я все еще вижу то же поведение tho Маленькие изображения, похоже, масштабируют X и Y, но не растягиваются на дно. Большие изображения, похоже, растут за пределами нижней части экрана. – sharath

+0

Скриншоты: http://postimage.org/image/wthseojsf/ http://postimage.org/image/is2rtogah/ – sharath

+0

Привет, я обновил свой ответ с небольшими изменениями, пожалуйста, проверьте его. Вы должны относиться к высоте как fill_parent, а не wrap_content – Pratik

Смежные вопросы