1. 程式人生 > >控制元件懸浮在某個控制元件之上 Android五大布局方式——相對佈局(RelativeLayout)屬性詳解

控制元件懸浮在某個控制元件之上 Android五大布局方式——相對佈局(RelativeLayout)屬性詳解

如圖所示,想要實現搜尋框在輪播圖上面,不管滑動與否,這個組合控制元件都在上面

1.就要用到RelativeLayout,相對於父元素定位,而且這個搜尋框的組合控制元件必須要放在所有控制元件下面,在使用android:layout_alignParentTop="true"這個屬性,貼緊父元素的上邊緣.

程式碼實現

<?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">

    <com.youth.banner.Banner
        android:id="@+id/ban"
        android:layout_width="match_parent"
        android:layout_height="300px"/>

    <FrameLayout
        android:layout_alignParentTop="true"
        android:id="@+id/f1_frag"
        android:layout_width="wrap_content"
        android:layout_height="50px">

        <View
            android:id="@+id/home_title_bar_bg_view"
            android:layout_width="match_parent"
            android:layout_height="match_parent"/>

        <LinearLayout
            android:orientation="horizontal"
            android:gravity="center_vertical"
            android:layout_width="match_parent"
            android:layout_height="match_parent">

            <LinearLayout
                android:gravity="center_horizontal"
                android:orientation="vertical"
                android:id="@+id/f1_erweima"
                android:layout_width="50dp"
                android:layout_height="wrap_content">

                <ImageView
                    android:src="@drawable/sao1"
                    android:layout_width="18dp"
                    android:layout_height="18dp" />
                <TextView
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:textSize="10sp"
                    android:text="掃啊掃"/>
            </LinearLayout>

            <LinearLayout
                android:background="@drawable/home_title_bar_search_corner_bg"
                android:gravity="center_vertical"
                android:layout_weight="1"
                android:layout_width="0dp"
                android:layout_height="30dp">

                <ImageView
                    android:layout_marginLeft="5dp"
                    android:src="@drawable/order_find"
                    android:layout_width="15dp"
                    android:layout_height="15dp" />

                <TextView
                    android:layout_marginLeft="5dp"
                    android:gravity="center_vertical"
                    android:layout_weight="1"
                    android:layout_width="0dp"
                    android:layout_height="30dp"
                    android:textColor="@color/white"
                    android:textSize="15dp"
                    android:lines="1"
                    android:ellipsize="end"
                    android:text="運動戶外超級品牌類日 跨店鋪跨店鋪"
                    />
                <ImageView
                    android:layout_marginRight="5dp"
                    android:src="@drawable/root"
                    android:layout_width="15dp"
                    android:layout_height="15dp" />
            </LinearLayout>

            <LinearLayout
                android:gravity="center_horizontal"
                android:orientation="vertical"
                android:layout_width="50dp"
                android:layout_height="wrap_content">

                <ImageView
                    android:src="@drawable/order_msg"
                    android:layout_width="18dp"
                    android:layout_height="18dp" />
                <TextView
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:textSize="10sp"
                    android:text="訊息"/>
            </LinearLayout>
        </LinearLayout>
    </FrameLayout>
</RelativeLayout>

RelativeLayout用到的一些重要的屬性:

第一類:屬性值為true或false

android:layout_centerHrizontal 水平居中
android:layout_centerVertical 垂直居中
android:layout_centerInparent 相對於父元素完全居中
android:layout_alignParentBottom 貼緊父元素的下邊緣
android:layout_alignParentLeft 貼緊父元素的左邊緣
android:layout_alignParentRight 貼緊父元素的右邊緣
android:layout_alignParentTop 貼緊父元素的上邊緣
android:layout_alignWithParentIfMissing 如果對應的兄弟元素找不到的話就以父元素做參照物

第二類:屬性值必須為id的引用名“@id/id-name”

android:layout_below 在某元素的下方
android:layout_above 在某元素的的上方
android:layout_toLeftOf 在某元素的左邊
android:layout_toRightOf 在某元素的右邊
android:layout_alignTop 本元素的上邊緣和某元素的的上邊緣對齊
android:layout_alignLeft 本元素的左邊緣和某元素的的左邊緣對齊
android:layout_alignBottom 本元素的下邊緣和某元素的的下邊緣對齊
android:layout_alignRight 本元素的右邊緣和某元素的的右邊緣對齊

第三類:屬性值為具體的畫素值,如30dip,40px

android:layout_marginBottom 離某元素底邊緣的距離
android:layout_marginLeft 離某元素左邊緣的距離
android:layout_marginRight 離某元素右邊緣的距離
android:layout_marginTop 離某元素上邊緣的距離

EditText的android:hint
設定EditText為空時輸入框內的提示資訊。

android:gravity 
android:gravity屬性是對該view 內容的限定.比如一個button 上面的text. 你可以設定該text 在view的靠左,靠右等位置.以button為例,android:gravity=”right”則button上面的文字靠右

android:layout_gravity
android:layout_gravity是用來設定該view相對與起父view 的位置.比如一個button 在linearlayout裡,你想把該button放在靠左、靠右等位置就可以通過該屬性設定.以button為例,android:layout_gravity=”right”則button靠右

android:layout_alignParentRight
使當前控制元件的右端和父控制元件的右端對齊。這裡屬性值只能為true或false,預設false。