2013-02-13 14 views
5

Co chcę osiągnąć jest jak ten układ: enter image description hereJak uzyskać interfejs użytkownika Android podobny do tego układu graficznego? O android: clipChildren

Próbowałem użyć tego kodu, aby osiągnąć jak tego obrazu, ale niestety nie udało mi się. To jest urywek mojego kodu:

<RelativeLayout 
     android:layout_width="fill_parent" 
     android:layout_height="wrap_content" 
     android:layout_marginBottom="10dp" 
     android:clipChildren="false" 
     > 



     <RelativeLayout 
      android:id="@+id/text_area_third" 
      android:layout_width="fill_parent" 
      android:layout_height="wrap_content" 
      android:background="@drawable/round_corner_background" 
      android:focusable="false" 
      android:paddingBottom="5dp" 
      android:paddingLeft="5dp" 
      android:paddingRight="5dp" 
      android:paddingTop="5dp" > 

      <TextView 
       android:id="@+id/text_download_purch_third" 
       android:layout_width="wrap_content" 
       android:layout_height="wrap_content" 
       android:layout_alignParentLeft="true" 
       android:layout_alignRight="@+id/acron_icon" 
       android:layout_marginLeft="5dp" 
       android:layout_marginRight="30dp" 
       android:layout_marginTop="10dp" 
       android:gravity="left" 
       android:maxLines="2" 
       android:text="1asdasdasdasdadsasdasdadasdasdasdasdasdasdasdasd" 
       android:textColor="@color/black" 
       android:textSize="10sp" 
       android:textStyle="normal" /> 

      <ImageView 
       android:id="@+id/acron_icon" 
       android:layout_width="20dp" 
       android:layout_height="20dp" 
       android:layout_alignParentRight="true" 
       android:layout_centerVertical="true" 
       android:layout_margin="5dp" 
       android:layout_marginTop="10dp" 
       android:background="@drawable/acron" 
       android:scaleType="fitCenter" /> 
     </RelativeLayout> 

     <LinearLayout 
      android:layout_alignTop="@+id/text_area_third" 
      android:layout_alignLeft="@+id/text_area_third" 
      android:layout_width="wrap_content" 
      android:layout_height="wrap_content" 
      android:background="@color/orange" 
      android:layout_marginLeft="-10dp" 
      android:layout_marginTop="-10dp" 
      android:padding="3dp" > 

      <TextView 
       android:layout_width="wrap_content" 
       android:layout_height="wrap_content" 
       android:text="GET" 
       android:textColor="@color/white" 
       android:textSize="13sp" 
       android:textStyle="bold" /> 
     </LinearLayout> 

    </RelativeLayout> 

enter image description here

Można zobaczyć, że „get” label (z pomarańczowym tle) jest obcięty przez rodzica związana. Ustawiłem android:clipChildren="false", ale wciąż jest przycięte. Czy ktoś może mi pomóc?

+0

Co się dzieje, jeśli dostosowanie go do układu nadrzędnego (z użyciem 'layout_alignParentTop/Left') zamiast' text_area_third' (i dostosować 'layout_marginLeft/Top' odpowiednio)? – Geobits

+0

@Geobits: Próbowałem również, ale ten sam błąd się zdarzył –

Odpowiedz

3

Pojedyncza RelativeLayout jest droga . Pamiętaj, aby zachować rzeczy tak proste, jak to tylko możliwe. W RelativeLayout ostatnie zadeklarowane elementy są renderowane na pozostałych. Poniższy kod XML powinien (w pewnym sensie) odpowiadać Twoim potrzebom, wystarczy dostosować obrazy, marginesy i rozmiary, zgodnie z wymaganiami.

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    android:layout_width="180dp" 
    android:layout_height="60dp" 
    android:background="#DDD" > 

    <TextView 
     android:id="@+id/text_download_purch_third" 
     android:layout_width="match_parent" 
     android:layout_height="match_parent" 
     android:layout_marginBottom="3dp" 
     android:layout_marginLeft="12dp" 
     android:layout_marginRight="8dp" 
     android:layout_marginTop="10dp" 
     android:background="@drawable/round_corner_background" 
     android:maxLines="2" 
     android:paddingLeft="4dp" 
     android:paddingRight="25dp" 
     android:paddingTop="16dp" 
     android:text="1asdasdasdasdadsasdasdadasdasdasdasdasdasdasdasd" 
     android:textColor="@color/black" 
     android:textSize="10sp" 
     android:textStyle="normal" /> 

    <ImageView 
     android:id="@+id/acron_icon" 
     android:layout_width="20dp" 
     android:layout_height="20dp" 
     android:layout_alignParentRight="true" 
     android:layout_centerVertical="true" 
     android:layout_margin="5dp" 
     android:layout_marginTop="10dp" 
     android:background="@drawable/acron" 
     android:scaleType="fitCenter" /> 

    <TextView 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content" 
     android:layout_marginLeft="8dp" 
     android:layout_marginTop="4dp" 
     android:background="#FFA0A0" 
     android:padding="2dp" 
     android:text="GET!" 
     android:textColor="@color/white" 
     android:textSize="13sp" 
     android:textStyle="bold" /> 

</RelativeLayout> 
0

Czy myślałeś o użyciu FrameLayout? To sprawia, pokrywającego obrazu łatwiejszego ... (co jeden układ/view pojawiają się na szczycie drugiego) ... Tutaj jest dobry poradnik ...

http://mobile.tutsplus.com/tutorials/android/android-sdk_frame-layout/

+0

['FrameLayout'] (http://developer.android.com/reference/android/widget/FrameLayout.html) nigdy nie powinien być używany do przechowywania więcej niż jedno dziecko. – Eric

+1

Dokument mówi, że można go używać, jeśli nie zależy Ci na innej rozdzielczości ekranu. – chuthan20

+0

@Eric: czy możesz dokładniej wyjaśnić, dlaczego 'FrameLayout' nie powinien być używany do przechowywania więcej niż 1 dziecka? –