Shadow Separator Between Android Fragments

前端 未结 2 1251
春和景丽
春和景丽 2021-01-29 19:20

I have a layout similar to the ICS Gmail app for tablets (ListFragment on the left and content on the right) and I was wondering how I could go about constructing t

相关标签:
2条回答
  • 2021-01-29 19:40

    Just to let everyone know (because there seems to be a lack of information out there on this topic), this is achieved within the background selector XML of the individual list rows' view. For example, this is the main screen's layout,

    <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:id="@+id/list_row"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="vertical"
        android:background="@drawable/list_item_selector">
    
        ...<!-- Rest of layout goes here -->
    
    </RelativeLayout>
    

    But the magic comes in the list_item_selector:

    <selector xmlns:android="http://schemas.android.com/apk/res/android">
        <item android:state_pressed="true" android:drawable="@drawable/list_pressed" />
        <item android:state_activated="true" android:drawable="@drawable/list_arrow_activated"  />
        <item android:drawable="@drawable/list_default" />
    </selector>
    

    By defining these as 9-patch drawables like this, you can have each list item contribute it's width worth of shadow to that line in the middle, and when it is activated, that segment of shadow will be replaced by an arrow. I hope this helps someone, as it's sure helped me!

    0 讨论(0)
  • 2021-01-29 19:59

    I'm looking to do the same thing that you're trying to do; create an effect that one fragment is "closer" than another.

    Roboguy's answer handles how to have the white arrow "selector" on the list item; I'll try to be more specific about shadows. Another good example of the use of background selectors can be seen in the source code of the Google IO 2011 App. Once you have the source, look at the fragment_dashboard.xml icon selectors.

    The shadow separator is a gradient, applied to the left side of a view. There are two parts;

    First, the "shadow" itself:

    res/shadow_left.xml

    <?xml version="1.0" encoding="utf-8"?>
    <shape xmlns:android="http://schemas.android.com/apk/res/android">
    <gradient
        android:angle="0"
        android:startColor="#55000000" 
        android:endColor="#00000000"
        />
    </shape>
    

    Then, to actually apply it to a layout:

    layout/my_lower_layer

    <?xml version="1.0" encoding="utf-8"?>
    <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="match_parent"
        android:layout_height="match_parent" >
    <View
        android:layout_width="20dp"
        android:layout_height="fill_parent"
        android:background="@drawable/fragment_shadow_left" />
    <ImageView
        android:id="@+id/imageview"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_centerInParent="true" />
    </RelativeLayout>
    

    This has to be done with a relative layout (to my knowledge). If you're using a linear layout, you can wrap the whole linearLayout inside of a relative layout, and then add the with the gradient.

    Note that, if you do this, the gradient <View> has to go below the <LinearLayout>; otherwise, the gradient will be drawn under the linear layout, so you won't see it.

    0 讨论(0)
提交回复
热议问题