2010-11-16 16 views
14

Mam ImageView, który zawsze chcę mieć ten sam rozmiar. Jeśli obraz jest mniejszy niż widok, chciałbym go wyśrodkować w widoku. Jeśli obraz jest większy niż widok, chciałbym go przeskalować - z zachowaniem proporcji.ImageView o stałym rozmiarze, niezależnie od rozmiaru obrazu

miałem kilka prób na ten sam - ostatni z nich jest:

<LinearLayout 
    xmlns:android="http://schemas.android.com/apk/res/android" 
    android:layout_width="fill_parent" 
    android:layout_height="fill_parent"> 
    <ImageView android:id="@+id/itemImage" android:layout_width="100dp" 
      android:layout_height="100dp" android:scaleType="fitCenter" 
      android:adjustViewBounds="true" android:gravity="center" android:padding="10px" /> 
    <TextView android:id="@+id/currentLentItem" android:layout_width="wrap_content" 
       android:layout_height="wrap_content" android:padding="10px"/> 
</LinearLayout> 

Co ja tu brakuje?

+0

Czy masz do tego satysfakcjonujące rozwiązanie? – nwaltham

Odpowiedz

11

Spróbuj użyć typ skalę centerInside, jak poniżej:

<?xml version="1.0" encoding="utf-8"?> 
    <RelativeLayout 
     xmlns:android="http://schemas.android.com/apk/res/android" 
     android:layout_width="fill_parent" 
     android:layout_height="wrap_content" 
     > 
    <ImageView 
     android:id="@+id/itemImage" 
     android:layout_width="100dp" 
     android:layout_height="100dp" 
     android:layout_alignParentRight="true" 
     android:scaleType="centerInside" 
     android:gravity="right|center_vertical" 
     android:padding="10px" 
     /> 
    <TextView 
     android:id="@+id/currentLentItem" 
     android:layout_width="fill_parent" 
     android:layout_height="wrap_content" 
     android:layout_alignParentLeft="true" 
     android:layout_toLeftOf="@id/list_image" 
     android:padding="10px" 
     /> 
</RelativeLayout> 

To powoduje, że obraz do skalowania w dół tylko wtedy większy niż układ i będzie skalować proporcjonalnie jak dobrze (podczas fitXY wagi bez względu na aspekt stosunek). Wyśrodkuje także obraz, jeśli jest mniejszy.

EDYCJA: Zaktualizowałem przykład czegoś, czego oczekujesz. Oto istota tego, co się zmieniło:

• ImageView grawitacja zmieniona na right|center_vertical. Ponieważ chcesz, aby były wyrównane po prawej stronie, użycie tej grawitacji pozwoli na to, nawet jeśli są to obrazy orientacji pionowej.

• ImageView wyrównany do prawej strony RelativeLayout

• RelativeLayout ustawiony wrap_content ponieważ jest do stosowania dla ListView.

• Dodano widok tekstu, wyrównany do lewej strony rodzica, z prawą krawędzią zdefiniowaną przez lewą krawędź elementuImage.

+0

Dzięki za to - wygląda lepiej. Widok nadal nie wydaje się być jednak stałym rozmiarem. Jak widać z powyższego przykładu, ImageView znajduje się obok TextView - i jest wyświetlany w ListView. Chcę, aby prawa krawędź ImageViews była ustawiona tak, aby wszystko wyglądało schludnie i jednolicie ... –

+0

Paul, dodałem zaktualizowany przykład, który możesz wypróbować; to powinno przybliżyć cię do tego, czego szukasz. – kcoppock

+0

Dzięki. Widoki ImageView nie są jednak tego samego rozmiaru. Potrzebuję ich wszystkich, by mieli dokładnie taką samą szerokość. Wydaje mi się, że byłoby to możliwe dzięki ustawieniu layout_width - ale oczywiście nie ... –

10

Jeśli obraz jest większy niż widok, a następnie można go skalować przy użyciu:

android:scaleType="fitXY" 

Że nie da Ci to, co chcesz, jeśli obraz jest mniejszy. Być może można to wykryć w czasie wykonywania i zmienić program scaleType programowo.

+0

Czy istnieje sposób na "uderzenie" w te wątki ...? –

+0

jak to zmienić w czasie wykonywania? –

+0

imageView.setScaleType (ScaleType.FIT_XY); –

Powiązane problemy