2015-07-06 14 views
5

voglio creare lo schema di come l'immagine seguente con Material CardView e Button Azione galleggiante personalizzato: enter image description hereCreare il layout con CardView e Floating Pulsante Azione Android

E mi è stato sviluppato fino a questo file XML di layout come segue:

<?xml version="1.0" encoding="utf-8"?> 
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    xmlns:app="http://schemas.android.com/apk/res-auto" 
    xmlns:fab="http://schemas.android.com/apk/res-auto" 
    android:layout_width="match_parent" 
    android:layout_height="wrap_content"> 

    <RelativeLayout 
     android:id="@+id/mainview" 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content" 
     android:orientation="vertical"> 

     <android.support.v7.widget.CardView 
      android:id="@+id/cv" 
      android:layout_width="match_parent" 
      android:layout_height="wrap_content" 
      app:cardCornerRadius="2dp" 
      app:cardElevation="2dp" 
      android:layout_marginBottom="@dimen/cardMarginVertical" 
      android:layout_marginLeft="@dimen/cardMarginHorizontal" 
      android:layout_marginRight="@dimen/cardMarginHorizontal" 
      android:layout_marginTop="@dimen/cardMarginVertical" 
      app:cardPreventCornerOverlap="false" 
      app:contentPadding="0dp"> 

      <com.github.florent37.materialviewpager.sample.ExpandableTextView 
       android:id="@+id/expandingTextView" 
       android:layout_width="match_parent" 
       android:layout_height="wrap_content" 
       android:textSize="15dp" 
       android:layout_marginLeft="10dp" 
       android:layout_marginTop="10dp" 
       android:layout_marginRight="10dp" 
       android:layout_marginBottom="10dp" 
       android:text="@string/longText" /> 

      <RelativeLayout 
       android:id="@+id/buttonlayout" 
       android:layout_width="match_parent" 
       android:layout_height="wrap_content" 
       android:layout_below="@+id/expandingTextView" 
       android:layout_gravity="bottom" 
       android:background="@android:color/transparent"> 

       <com.getbase.floatingactionbutton.FloatingActionButton 
        android:id="@+id/action_c" 
        android:layout_width="wrap_content" 
        android:layout_height="wrap_content" 
        fab:fab_colorNormal="#fff" 
        android:layout_alignParentRight="true" 
        fab:fab_colorPressed="#fff" 
        android:visibility="visible" /> 
      </RelativeLayout> 
     </android.support.v7.widget.CardView> 
    </RelativeLayout> 
</FrameLayout> 
+0

Please help me in questo layout ero confuso come lavorare su questo layout con 2 giorni, ma non in grado di completare il layout fino a questa immagine. –

risposta

10

Per implementare l'interfaccia utente come la tua immagine, alcuni codici come di seguito possono aiutare.

I parametri layout_anchor e layout_anchorGravity in FloatingActionButton sono il punto.

<?xml version="1.0" encoding="utf-8"?> 
<android.support.design.widget.CoordinatorLayout xmlns:android="http://schemas.android.com/apk/res/android" 
     xmlns:app="http://schemas.android.com/apk/res-auto" 
     android:orientation="vertical" 
     android:layout_width="match_parent" 
     android:layout_height="match_parent"> 

    <android.support.v4.widget.NestedScrollView 
     android:layout_width="match_parent" 
     android:layout_height="match_parent" 
     app:layout_behavior="@string/appbar_scrolling_view_behavior"> 

     <android.support.v7.widget.CardView 
      android:id="@+id/cv" 
      android:layout_width="match_parent" 
      android:layout_height="wrap_content" 
      android:layout_margin="16dp"> 

       <TextView 
        android:layout_width="match_parent" 
        android:layout_height="wrap_content" 
        android:text="The Android Support Library package is a set of code libraries that provide backward-compatible versions of Android framework APIs as well as features that are only available through the library APIs. Each Support Library is backward-compatible to a specific Android API level. This design means that your applications can use the libraries' features and still be compatible with devices running Android 1.6 (API level 4) and up." /> 

     </android.support.v7.widget.CardView> 

    </android.support.v4.widget.NestedScrollView> 

    <android.support.design.widget.FloatingActionButton 
     android:layout_height="wrap_content" 
     android:layout_width="wrap_content" 
     app:layout_anchor="@id/cv" 
     app:layout_anchorGravity="right|end|bottom" 
     android:layout_margin="16dp" 
     android:clickable="true"/> 

</android.support.design.widget.CoordinatorLayout> 

Edit:

risposta precoce aveva qualche bug in Android 5.0.1 e 5.0.2, FAB avrebbe mostrato di seguito a schede.

Aggiungere NestedScrollView con layout_behavior fuori CardView a lavorare in Android 5.0.1 e 5.0.2

+0

Ciao Ellie ci proverò e ti informerò presto ... –

+0

Sei in grado di fare modifiche un codice nel mio codice postato come sopra così sono in grado di farlo facilmente. Grazie per l'aiuto. –

+1

Ho rimosso un codice inutile dal mio layout. Puoi dare un'occhiata –

Problemi correlati