2013-05-11 189 views
0

我想創建一個ListView立即在它下面的TextView。爲了做到這一點,我添加了一個頁腳到ListView。我想要一個ListView和TextView之間的一條線,但我希望它具有特定的邊距。我創建了一個樣式,然後將其添加到頁腳。當我用樣式添加視圖時,它會將我的文本完全從屏幕中移出。這裏是ListView控件:我的TextView沒有顯示....爲什麼?

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    android:layout_width="fill_parent" 
    android:layout_height="fill_parent" 
    android:orientation="vertical" > 

    <ListView 
     android:id="@+id/list_view_order_filter" 
     android:layout_width="match_parent" 
     android:layout_height="0dp" 
     android:layout_marginTop="15dp" 
     android:layout_weight="1" > 
    </ListView> 

    <LinearLayout 
     android:layout_width="fill_parent" 
     android:layout_height="wrap_content" 
     android:layout_gravity="bottom" 
     android:orientation="horizontal" > 

     <Button 
      android:id="@+id/orderFilters" 
      android:layout_width="fill_parent" 
      android:layout_height="wrap_content" 
      android:layout_weight="1" 
      android:text="@string/order_filter" > 
     </Button> 

     <Button 
      android:id="@+id/orderFiltersCancel" 
      android:layout_width="fill_parent" 
      android:layout_height="wrap_content" 
      android:layout_weight="1" 
      android:text="@string/cancel" > 
     </Button> 
    </LinearLayout> 

</LinearyLayout> 

這是我的風格:

<style name="divider"> 
    <item name="android:layout_width">match_parent</item> 
    <item name="android:layout_height">1dp</item> 
    <item name="android:layout_marginRight">15dp</item> 
    <item name="android:layout_marginLeft">15dp</item> 
    <item name="android:layout_marginTop">10dp</item> 
    <item name="android:background">?android:attr/listDivider</item> 
</style> 

這裏是我的頁腳:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    android:layout_width="fill_parent" 
    android:layout_height="wrap_content" 
    android:orientation="horizontal" > 

    <View style="@style/divider" /> 

    <LinearLayout 
     android:layout_width="fill_parent" 
     android:layout_height="wrap_content" 
     android:orientation="horizontal" 
     android:layout_weight="1"> 

     <TextView 
      android:layout_width="match_parent" 
      android:layout_height="wrap_content" 
      android:layout_marginLeft="15dp" 
      android:layout_marginRight="15dp" 
      android:gravity="left" 
      android:text="@string/total" 
      android:textStyle="bold" /> 

     <TextView 
      android:id="@+id/orderTotal" 
      android:layout_width="wrap_content" 
      android:layout_height="wrap_content" 
      android:layout_marginRight="15dp" 
      android:gravity="right" 
      android:textIsSelectable="true" /> 
    </LinearLayout> 

</LinearLayout> 

以下是對我的看法是看起來像一個屏幕截圖。
enter image description here

回答

1

頁腳中的LinearLayout是水平的,但style =「@ style/divider」的View有layout_width:match_parent。它推動了隨後離開屏幕的所有內容。

0

這與@風格的 「match_parent」/除法問題

{

<item name="android:layout_width">20dp</item> 

<item name="android:layout_height">1dp</item> 

<item name="android:layout_marginRight">15dp</item> 

<item name="android:layout_marginLeft">15dp</item> 

<item name="android:layout_marginTop">10dp</item> 

<item name="android:background">?android:attr/listDivider</item> 

}

試試這個,你就可以看到你的觀點,此後根據需要調整寬度

所有你可以讓你的線性佈局垂直

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
android:layout_width="fill_parent" 
android:layout_height="wrap_content" 
android:orientation="horizontal" 
android:layout_marginTop="40dp" > 

<View style="@style/divider" /> 

<LinearLayout 
    android:layout_width="fill_parent" 
    android:layout_height="wrap_content" 
    android:layout_weight="1" 
    android:orientation="horizontal" > 

    <TextView 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content" 
     android:layout_marginLeft="15dp" 
     android:layout_marginRight="15dp" 
     android:gravity="left" 
     android:text="12000000" 
     android:textStyle="bold" /> 

    <TextView 
     android:id="@+id/orderTotal" 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content" 
     android:layout_marginRight="15dp" 
     android:gravity="right" 
     android:textIsSelectable="true" /> 
</LinearLayout> 

0

試試這個代碼。這裏我將你的主要xml和頁腳合併到單個文件中。根據你的編輯

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
android:layout_width="fill_parent" 
android:layout_height="fill_parent" 
android:orientation="vertical" > 

<ListView 
    android:id="@+id/list_view_order_filter" 
    android:layout_width="match_parent" 
    android:layout_height="0dp" 
    android:layout_marginTop="15dp" 
    android:layout_weight="1" > 
</ListView> 

<LinearLayout 
    android:layout_width="fill_parent" 
    android:layout_height="wrap_content" 
    android:layout_gravity="bottom" 
    android:orientation="horizontal" > 

    <Button 
     android:id="@+id/orderFilters" 
     android:layout_width="fill_parent" 
     android:layout_height="wrap_content" 
     android:layout_weight="1" 
     android:text="order_filter" > 
    </Button> 

    <Button 
     android:id="@+id/orderFiltersCancel" 
     android:layout_width="fill_parent" 
     android:layout_height="wrap_content" 
     android:layout_weight="1" 
     android:text="cancel" > 
    </Button> 
</LinearLayout> 



    <View 
     android:layout_width="fill_parent" 
     android:layout_height="1dp" 
     android:background="@drawable/icon" /> 

    <LinearLayout 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content" 
     android:orientation="horizontal" > 

     <TextView 
      android:layout_width="match_parent" 
      android:layout_height="wrap_content" 
      android:layout_marginLeft="15dp" 
      android:layout_marginRight="15dp" 
      android:gravity="left" 
      android:text="total" 
      android:textColor="#3a6e9a" 
      android:textStyle="bold" /> 

     <TextView 
      android:id="@+id/orderTotal" 
      android:layout_width="wrap_content" 
      android:layout_height="wrap_content" 
      android:layout_marginRight="15dp" 
      android:gravity="right" 
      android:text="left" 
      android:textColor="#3a6e9a" /> 
    </LinearLayout> 

    </LinearLayout>