2012-09-04 14 views
24

Chcę powtórzyć obraz z ImageView z RelativeLayout. Czy możliwe jest użycie Bitmapy xml i użycie tilemode "repeat" z RelativeLayout, ponieważ to, co widziałem w Internecie, wszystkie mają do czynienia z LinearLayout.Powtórz obraz z ImageView w RelativeLayout

Każda pomoc lub napiwek będą mile widziane.

Odpowiedz

62

Utwórz plik XML o nazwie tło w rozciągliwej folderze

background.xml

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

W swojej względnej Układ dodać powyższy XML jako tło

<RelativeLayout 
xmlns:android="http://schemas.android.com/apk/res/android" 
android:layout_width="fill_parent" 
android:layout_height="fill_parent" 
android:background="@drawable/background" /> 
+6

Ustawienie androida: scaleType = "fitXY" jest konieczne, jeśli umieścisz to w ImageView. –

3

Tak, jest to możliwe. Zdefiniuj swój powtarzający się obraz jako Drawable (bitmap) w formacie XML i użyj go jako tła swojego RelativeLayout.

10

Tak, oczywiście, można go używać z układem względnym. Użyj go jako tła Twojego RelativeLayout. Używałem go również w moim projekcie.

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 
     android:layout_width="fill_parent" 
     android:layout_height="wrap_content" 
     android:orientation="horizontal" 
     android:background="@drawable/top_header_bg_repeat" 
     android:gravity="center"> 

top_header_bg_repeat.xml (in drawable folder) 
---------------------------------------------- 

<bitmap 
    xmlns:android="http://schemas.android.com/apk/res/android" 
    android:src="@drawable/top_header" 
    android:tileMode="repeat" 
    android:dither="true"/> 

Set Bitmap in ImageView 
---------------------- 

<ImageView 
     android:layout_width="fill_parent" 
     android:layout_height="wrap_content" 
     android:src="@drawable/top_header_bg_repeat" 
     android:scaleType="fitXY"/> 

<ImageView 
      android:layout_width="fill_parent" 
      android:layout_height="wrap_content" 
      android:background="@drawable/top_header_bg_repeat"/> 
+0

Chcę powtórzyć obraz przy użyciu imageView umieszczonego w układzie względnym Zrobiłem to, ale nie zadziałało –

+0

Znaczy, że chcesz tę bitmapę w widoku obrazu? –

+0

yes want the bitmap as source of Image view –

2

We wszystkich żądaniach istnieje jeden mały problem, jeśli obraz będzie świetny i mniejszy, jaki rozmiar będzie miał układ, obraz nie zmieni rozmiaru, tylko powtórzenie przez X. Powtórzenie przez Y możesz zrobić to tylko programowo.

mi rozwiązać mój problem tak (ustawiony syta ciężkości)

odkształcalne bg dla obrazu

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

i na układ

<?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="@dimen/table_cell_height"> 

    <ImageView 
     android:id="@+id/imageView1" 
     android:layout_width="fill_parent" 
     android:layout_height="@dimen/table_cell_height" 
     android:scaleType="fitXY" 
     android:src="@drawable/table_cells_bg"/> 
<TextView 
     android:id="@+id/txtActivityTime" 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content" 
     android:layout_alignParentTop="true" 
     android:layout_toRightOf="@+id/avatarImage" 
     android:text="TextView" 
     android:textColor="@color/white" 
     android:textSize="@dimen/font_size_middle" /> 
</RelativeLayout> 

I table_cells_bg_img to obraz width = 1px i wysokość = 1px

itp. Układu, więc teraz twój obraz to jak backg okrągłe i zostanie przeskalowane na dowolny rozmiar układu rodzica

Spróbuj, może pomóż. Aby zostać wyczyszczonym w moim przypadku, potrzebuję kaflowy obraz tła do pełnego rozmiaru tablecell powtarzanego przez współrzędną X (jak mogę to zrobić na iOS). Więc rozwiązuję to tak, jak opisuję.

Powiązane problemy