2012-04-09 37 views
9

我想創建一個列分隔符的表。我想用垂直條形圖像分割我的列。爲了達到這個目的,我使用了"android:divider="@drawable/abc"但它不起作用。下面是我的XML文件相同:如何在tablelayout中的列之間設置分隔符?

<TableLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" 
    android:orientation="horizontal" 
    android:stretchColumns="*" 
    android:padding="5dip" 
android:divider="@drawable/tracking_green" 
> 
<TableRow > 

<TextView 
    android:id="@+id/retaileritem1" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" 
    android:layout_weight="1" 
    android:text="xxxxxxx" /> 

<TextView 
    android:id="@+id/retaileritem2" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" 
    android:layout_weight="1" 
    android:text="xxxxxxx" /> 

<ImageView 
    android:id="@+id/retailerimage1" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" 
    android:layout_weight="1" 
    android:src="@drawable/tracking_green" /> 

</TableRow> 

回答

0

因爲tablelayout不提供這種直接,一個posibble方式可能是一個FrameLayout裏。將所需表格放在另一個只有一行的background_table上面,對於高度/寬度放置「match_parent」。添加3列與所需的layout_weights。將垂直divider-imageview添加到第二列。 主表應該在其行中使用相同的layout_weihts + margin來保持良好。

水平分隔符可能可以通過在「待分離」表格之間添加imageview來實現。

尚未測試,只是一個方法

ornay

10

添加機器人:showDividers = 「中間」

<TableLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" 
    android:orientation="horizontal" 
    android:stretchColumns="*" 
    android:padding="5dip" 
    android:divider="@drawable/tracking_green" 
    android:showDividers="middle" 
> 
+0

有什麼辦法改變分配器的顏色。 – 2014-02-17 11:23:51

+0

例如: 如果您使用--- android:divider =「@ color/orangeBackground」 然後您可以在colors.xml中定義值,如--- #FF8000 2014-02-18 01:20:06

0

在列表中有垂直分隔使用的ImageView如下:

<ImageView 
    android:id="@+id/divider" 
    android:contentDescription="@string/divider" 
    android:layout_width="1dp" 
    android:layout_height="65dp" 
    android:layout_marginTop="8sp" 
    android:background="#3B3B3B" 
    /> 

爲了避免在列表中沒有元素時顯示分隔符,您可以刪除e本android:background="#3B3B3B"線和編程設置:

1

我想要的東西是這樣的

table image with vertical dividers

我在styles.xml加入這個

<style name="Divider"> 
     <item name="android:layout_width">1dip</item> 
     <item name="android:layout_height">match_parent</item> 
     <item name="android:background">@color/divider_color</item> 
    </style> 

    <style name="Divider_invisible"> 
     <item name="android:layout_width">1dip</item> 
     <item name="android:layout_height">match_parent</item> 
    </style> 

Then in my table layout 

<TableLayout 
      android:id="@+id/table" 
      android:layout_width="match_parent" 
      android:layout_height="wrap_content" 
      android:orientation="horizontal" 
      android:stretchColumns="*" > 

      <TableRow 
       android:id="@+id/tableRow1" 
       android:layout_width="fill_parent" 
       android:layout_height="match_parent" 
       android:background="#92C94A" > 

       <TextView 
        android:id="@+id/textView11" 
        android:paddingBottom="10dp" 
        android:paddingLeft="5dp" 
        android:paddingRight="5dp" 
        android:paddingTop="10dp" /> 

       <LinearLayout 
        android:layout_width="1dp" 
        android:layout_height="match_parent" > 

        <View style="@style/Divider_invisible" /> 
       </LinearLayout> 

       <TextView 
        android:id="@+id/textView12" 
        android:paddingBottom="10dp" 
        android:paddingLeft="5dp" 
        android:paddingRight="5dp" 
        android:paddingTop="10dp" 
        android:text="@string/main_wo_colon" 
        android:textColor="@color/white" 
        android:textSize="16sp" /> 

       <LinearLayout 
        android:layout_width="1dp" 
        android:layout_height="match_parent" > 

        <View style="@style/Divider" /> 
       </LinearLayout> 

       <TextView 
        android:id="@+id/textView13" 
        android:paddingBottom="10dp" 
        android:paddingLeft="5dp" 
        android:paddingRight="5dp" 
        android:paddingTop="10dp" 
        android:text="@string/side_wo_colon" 
        android:textColor="@color/white" 
        android:textSize="16sp" /> 

       <LinearLayout 
        android:layout_width="1dp" 
        android:layout_height="match_parent" > 

        <View style="@style/Divider" /> 
       </LinearLayout> 

       <TextView 
        android:id="@+id/textView14" 
        android:paddingBottom="10dp" 
        android:paddingLeft="5dp" 
        android:paddingRight="5dp" 
        android:paddingTop="10dp" 
        android:text="@string/total" 
        android:textColor="@color/white" 
        android:textSize="16sp" /> 
      </TableRow> 

      <!-- display this button in 3rd column via layout_column(zero based) --> 

      <TableRow 
       android:id="@+id/tableRow2" 
       android:layout_width="match_parent" 
       android:layout_height="match_parent" 
       android:background="#6F9C33" > 

       <TextView 
        android:id="@+id/textView21" 
        android:padding="5dp" 
        android:text="@string/servings" 
        android:textColor="@color/white" 
        android:textSize="16sp" /> 

       <LinearLayout 
        android:layout_width="1dp" 
        android:layout_height="match_parent" > 

        <View style="@style/Divider" /> 
       </LinearLayout> 

.......... 
....... 
...... 
2

這是一個表我是怎麼做到的!

CODE

<LinearLayout 
      android:layout_width="match_parent" 
      android:layout_height="wrap_content" 
      android:layout_gravity="center" 
      android:orientation="vertical" > 

      <LinearLayout 
       android:layout_width="match_parent" 
       android:layout_height="wrap_content" 
       android:orientation="vertical" 
       android:padding="5dp" > 

       <TextView 
        android:id="@+id/textView4" 
        android:layout_width="wrap_content" 
        android:layout_height="wrap_content" 
        android:layout_gravity="center" 
        android:layout_weight="1" 
        android:paddingBottom="50dp" 
        android:text="Salary Details" 
        android:textAppearance="?android:attr/textAppearanceLarge" 
        android:textStyle="bold" /> 

       <TableLayout 
        android:layout_width="wrap_content" 
        android:layout_height="match_parent" 
        android:layout_weight="1" 
        android:shrinkColumns="0" 
        android:stretchColumns="1" > 

        <TableRow 
         android:layout_width="match_parent" 
         android:layout_height="match_parent" 
         android:layout_gravity="center_vertical" > 

         <TextView 
          android:layout_gravity="center_vertical" 
          android:gravity="left" 
          android:text="Financial Year" 
          android:textColor="@android:color/white" 
          android:textSize="14sp" 
          android:textStyle="bold" /> 

         <Spinner 
          android:id="@+id/spnSearchByCity" 
          android:layout_width="fill_parent" 
          android:layout_height="40dp" 
          android:layout_gravity="center_vertical" 
          android:entries="@array/year" 
          tools:listitem="@android:layout/simple_spinner_dropdown_item" /> 
        </TableRow> 
       </TableLayout> 

       <LinearLayout 
        android:layout_width="match_parent" 
        android:layout_height="match_parent" 
        android:background="#d30059" 
        android:orientation="vertical" 
        android:paddingTop="50dp" > 

        <TableLayout 
         android:layout_width="match_parent" 
         android:layout_height="wrap_content" > 

         <TableRow 
          android:id="@+id/tableRow1" 
          android:layout_width="wrap_content" 
          android:layout_height="wrap_content" 
          android:background="@android:color/white" > 

          <TextView 
           android:id="@+id/textView1" 
           android:layout_width="wrap_content" 
           android:layout_height="wrap_content" 
           android:layout_marginBottom="1dp" 
           android:layout_marginLeft="1dp" 
           android:layout_marginTop="1dp" 
           android:layout_weight="1" 
           android:background="#d30059" 
           android:gravity="center" 
           android:text="Month" 
           android:textAppearance="?android:attr/textAppearanceMedium" /> 

          <TextView 
           android:id="@+id/textView2" 
           android:layout_width="wrap_content" 
           android:layout_height="wrap_content" 
           android:layout_marginBottom="1dp" 
           android:layout_marginLeft="1dp" 
           android:layout_marginTop="1dp" 
           android:layout_weight="1" 
           android:background="#d30059" 
           android:gravity="center" 
           android:text="Net Salary" 
           android:textAppearance="?android:attr/textAppearanceMedium" /> 

          <TextView 
           android:id="@+id/textView3" 
           android:layout_width="wrap_content" 
           android:layout_height="wrap_content" 
           android:layout_marginBottom="1dp" 
           android:layout_marginLeft="1dp" 
           android:layout_marginRight="1dp" 
           android:layout_marginTop="1dp" 
           android:layout_weight="1" 
           android:background="#d30059" 
           android:gravity="center" 
           android:text="Click" 
           android:textAppearance="?android:attr/textAppearanceMedium" /> 
         </TableRow> 

         <TableRow 
          android:id="@+id/tableRow2" 
          android:layout_width="wrap_content" 
          android:layout_height="wrap_content" 
          android:background="@android:color/white" > 

          <TextView 
           android:layout_width="wrap_content" 
           android:layout_height="wrap_content" 
           android:layout_marginBottom="1dp" 
           android:layout_marginLeft="1dp" 
           android:layout_weight="1" 
           android:background="#d30059" 
           android:gravity="center" 
           android:text="Jan" 
           android:textAppearance="?android:attr/textAppearanceMedium" /> 

          <TextView 
           android:layout_width="wrap_content" 
           android:layout_height="wrap_content" 
           android:layout_marginBottom="1dp" 
           android:layout_marginLeft="1dp" 
           android:layout_weight="1" 
           android:background="#d30059" 
           android:gravity="center" 
           android:text="11305" 
           android:textAppearance="?android:attr/textAppearanceMedium" /> 

          <LinearLayout 
           android:layout_width="match_parent" 
           android:layout_height="wrap_content" 
           android:layout_marginBottom="1dp" 
           android:layout_marginLeft="1dp" 
           android:layout_marginRight="1dp" 
           android:layout_weight="1" 
           android:background="#d30059" 
           android:gravity="center" 
           android:orientation="vertical" > 

           <TextView 
            android:id="@+id/txtDetailsOneId" 
            android:layout_width="wrap_content" 
            android:layout_height="wrap_content" 
            android:layout_weight="1" 
            android:background="#000000" 
            android:text="DETAILS" 
            android:textAppearance="?android:attr/textAppearanceMedium" /> 
          </LinearLayout> 
         </TableRow> 

         <TableRow 
          android:id="@+id/tableRow3" 
          android:layout_width="wrap_content" 
          android:layout_height="wrap_content" 
          android:background="@android:color/white" > 

          <TextView 
           android:layout_width="wrap_content" 
           android:layout_height="wrap_content" 
           android:layout_marginBottom="1dp" 
           android:layout_marginLeft="1dp" 
           android:layout_weight="1" 
           android:background="#d30059" 
           android:gravity="center" 
           android:text="Feb" 
           android:textAppearance="?android:attr/textAppearanceMedium" /> 

          <TextView 
           android:layout_width="wrap_content" 
           android:layout_height="wrap_content" 
           android:layout_marginBottom="1dp" 
           android:layout_marginLeft="1dp" 
           android:layout_weight="1" 
           android:background="#d30059" 
           android:gravity="center" 
           android:text="11405" 
           android:textAppearance="?android:attr/textAppearanceMedium" /> 

          <LinearLayout 
           android:layout_width="match_parent" 
           android:layout_height="wrap_content" 
           android:layout_marginBottom="1dp" 
           android:layout_marginLeft="1dp" 
           android:layout_marginRight="1dp" 
           android:layout_weight="1" 
           android:background="#d30059" 
           android:gravity="center" 
           android:orientation="vertical" > 

           <TextView 
            android:id="@+id/txtDetailsTwoId" 
            android:layout_width="wrap_content" 
            android:layout_height="wrap_content" 
            android:layout_weight="1" 
            android:background="#000000" 
            android:text="DETAILS" 
            android:textAppearance="?android:attr/textAppearanceMedium" /> 
          </LinearLayout> 
         </TableRow> 

         <TableRow 
          android:id="@+id/tableRow4" 
          android:layout_width="wrap_content" 
          android:layout_height="wrap_content" > 
         </TableRow> 
        </TableLayout> 
       </LinearLayout> 
      </LinearLayout> 

      <LinearLayout 
       android:layout_width="match_parent" 
       android:layout_height="wrap_content" 
       android:orientation="vertical" 
       android:padding="50dp" > 

       <Button 
        android:id="@+id/btnMainMenuId" 
        android:layout_width="wrap_content" 
        android:layout_height="wrap_content" 
        android:layout_gravity="center" 
        android:layout_marginTop="5dp" 
        android:text="MAIN MENU" 
        android:textColor="@android:color/white" 
        android:textSize="12sp" /> 
      </LinearLayout> 
     </LinearLayout> 

快照

enter image description here

0

嘗試設定第二TextView的marginleft = 1DP。如果你不想分配器設置marginleft = 0dp

相關問題