XML中的垂直线,用于Android中的通知

时间:2014-06-20 05:10:35

标签: android android-layout

我创建了一个自定义通知XML文件。我想绘制一条垂直线,如下图中的水平线。我一直在尝试各种方法无法实现它。从水平到垂直的xml方向对我没有帮助。

检查下面的截图:我想获得垂直线而不是红线。

enter image description here

尝试以下代码:

    <LinearLayout
        android:id="@+id/horizontalLayout"
        android:layout_width="match_parent"
        android:layout_height="2dip"
        android:background="#000000"
        android:orientation="vertical" >
    </LinearLayout>

以下是我的XML:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="#151515"
android:baselineAligned="false"
android:orientation="horizontal" >

<LinearLayout
    android:id="@+id/iconimagelayout"
    android:layout_width="wrap_content"
    android:layout_height="match_parent"
    android:gravity="center"
    android:orientation="vertical"
    android:paddingLeft="5dp" >

    <ImageView
        android:id="@+id/iconimage"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:contentDescription="@string/icon"
        android:src="@drawable/cancel" />
</LinearLayout>

<LinearLayout
    android:id="@+id/NameLayout"
    android:layout_width="0dp"
    android:layout_height="match_parent"
    android:layout_weight=".70"
    android:orientation="vertical"
    android:paddingLeft="10sp" >

    <LinearLayout
        android:id="@+id/topTextlayout"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="#2E2E2E"
        android:gravity="center_horizontal"
        android:paddingBottom="5dp" >

        <TextView
            android:id="@+id/topText"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:paddingTop="5dp"
            android:text="TITLE"
            android:textColor="#FFFFFF"
            android:textSize="18sp" />
    </LinearLayout>

    <LinearLayout
        android:id="@+id/horizontalLayout"
        android:layout_width="match_parent"
        android:layout_height="2dip"
        android:background="#000000"
        android:orientation="horizontal" >
    </LinearLayout>

    <LinearLayout
        android:id="@+id/textLayout"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="#1C1C1C"
        android:paddingTop="5dp" >

        <TextView
            android:id="@+id/text"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:paddingBottom="10dp"
            android:paddingLeft="5dp"
            android:text="MESSAGE BODY"
            android:textColor="#FFFFFF"
            android:textSize="18sp" />
    </LinearLayout>

    <LinearLayout
        android:id="@+id/horizontalLayout2"
        android:layout_width="match_parent"
        android:layout_height="2dip"
        android:background="#000000"
        android:orientation="horizontal" >
    </LinearLayout>

    <LinearLayout
        android:id="@+id/alldismisslayout"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="#2E2E2E" >

        <ImageView
            android:id="@+id/dismissicon"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:contentDescription="@string/dismissicon"
            android:src="@drawable/cancel" />

        <LinearLayout
            android:id="@+id/dismissLayout"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:gravity="center|left" >

            <TextView
                android:id="@+id/dismissText"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:paddingLeft="5dp"
                android:text="@string/notificationdismiss"
                android:textColor="#FFFFFF"
                android:textSize="18sp" />
        </LinearLayout>
    </LinearLayout>
</LinearLayout>

</LinearLayout>

不确定我在哪里放置垂直线代码。

5 个答案:

答案 0 :(得分:4)

您可以使用以下内容创建垂直线。

<View
    android:layout_width="4dip"
    android:layout_height="match_parent"
    android:background="#FF000000"/>

在第一次取消imageview之后放置此代码。因此,您的最终代码将变为

<LinearLayout
    android:id="@+id/iconimagelayout"
    android:layout_width="wrap_content"
    android:layout_height="match_parent"
    android:gravity="center"
    android:orientation="vertical"
    android:paddingLeft="5dp" >

    <ImageView
        android:id="@+id/iconimage"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:contentDescription="@string/icon"
        android:src="@drawable/cancel" />
</LinearLayout>

<View
    android:layout_width="4dip"
    android:layout_height="match_parent"
    android:background="#FF000000"/>

<LinearLayout
    android:id="@+id/NameLayout"
    android:layout_width="0dp"
    android:layout_height="match_parent"
    android:layout_weight=".70"
    android:orientation="vertical"
    android:paddingLeft="10sp" >

    <LinearLayout
        android:id="@+id/topTextlayout"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="#2E2E2E"
        android:gravity="center_horizontal"
        android:paddingBottom="5dp" >

        <TextView
            android:id="@+id/topText"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:paddingTop="5dp"
            android:text="TITLE"
            android:textColor="#FFFFFF"
            android:textSize="18sp" />
    </LinearLayout>

    <LinearLayout
        android:id="@+id/horizontalLayout"
        android:layout_width="match_parent"
        android:layout_height="2dip"
        android:background="#000000"
        android:orientation="horizontal" >
    </LinearLayout>

    <LinearLayout
        android:id="@+id/textLayout"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="#1C1C1C"
        android:paddingTop="5dp" >

        <TextView
            android:id="@+id/text"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:paddingBottom="10dp"
            android:paddingLeft="5dp"
            android:text="MESSAGE BODY"
            android:textColor="#FFFFFF"
            android:textSize="18sp" />
    </LinearLayout>

    <LinearLayout
        android:id="@+id/horizontalLayout2"
        android:layout_width="match_parent"
        android:layout_height="2dip"
        android:background="#000000"
        android:orientation="horizontal" >
    </LinearLayout>

    <LinearLayout
        android:id="@+id/alldismisslayout"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="#2E2E2E" >

        <ImageView
            android:id="@+id/dismissicon"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:contentDescription="@string/dismissicon"
            android:src="@drawable/cancel" />

        <LinearLayout
            android:id="@+id/dismissLayout"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:gravity="center|left" >

            <TextView
                android:id="@+id/dismissText"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:paddingLeft="5dp"
                android:text="@string/notificationdismiss"
                android:textColor="#FFFFFF"
                android:textSize="18sp" />
        </LinearLayout>
    </LinearLayout>
</LinearLayout>

希望它有所帮助。

答案 1 :(得分:3)

如果需要,只需使用适当的背景和保证金

这是截图

image

<强> XML

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="#151515"
android:baselineAligned="false"
>



    <ImageView
        android:id="@+id/iconimage"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_below="@+id/topText"
        android:contentDescription="string/icon"
        android:src="@drawable/ic_launcher" />




        <TextView
            android:id="@+id/topText"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:background="#2E2E2E"
            android:layout_centerHorizontal="true"

            android:text="TITLE"
            android:textColor="#FFFFFF"
            android:textSize="18sp" />



        <TextView
            android:id="@+id/text"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:paddingBottom="10dp"
            android:layout_below="@+id/topText"
            android:layout_toRightOf="@+id/iconimage"
            android:layout_margin="10dp"
            android:background="#1C1C1C"
            android:text="MESSAGE BODY"
            android:textColor="#FFFFFF"
            android:textSize="18sp" />




        <ImageView
            android:id="@+id/dismissicon"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_below="@+id/text"
            android:layout_toRightOf="@+id/iconimage"
            android:contentDescription="string/dismissicon"
            android:src="@drawable/ic_launcher" />


            <TextView
                android:id="@+id/dismissText"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_margin="10dp"
                android:layout_toRightOf="@+id/dismissicon"
                android:layout_below="@+id/text"
                 android:background="#2E2E2E"
                android:text="notificationdismiss"
                android:textColor="#FFFFFF"
                android:textSize="18sp" />


            <TextView android:layout_width="2dp"
                android:layout_height="wrap_content"
                android:background="#ff0000"
                android:layout_alignRight="@+id/iconimage"
                android:layout_alignBottom="@+id/dismissicon"
                android:layout_alignTop="@+id/topText"
                />


</RelativeLayout>

答案 2 :(得分:2)

Try this way,hope this will help you to solve your problem.

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="#151515"
    android:baselineAligned="false"
    android:orientation="horizontal" >

    <LinearLayout
        android:id="@+id/iconimagelayout"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:gravity="center"
        android:paddingLeft="5dp" >

        <ImageView
            android:id="@+id/iconimage"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:contentDescription="@string/icon"
            android:src="@drawable/ic_launcher" />

        <View
            android:layout_width="1dp"
            android:layout_height="match_parent"
            android:background="#FF0000"/>

        <LinearLayout
            android:id="@+id/NameLayout"
            android:layout_width="0dp"
            android:layout_height="match_parent"
            android:layout_weight="1"
            android:orientation="vertical"
            android:paddingLeft="10dp">

            <LinearLayout
                android:id="@+id/topTextlayout"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:background="#2E2E2E"
                android:gravity="center_horizontal"
                android:padding="10dp">

                <TextView
                    android:id="@+id/topText"
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:text="TITLE"
                    android:textColor="#FFFFFF"
                    android:textSize="18sp" />
            </LinearLayout>

            <LinearLayout
                android:id="@+id/horizontalLayout"
                android:layout_width="match_parent"
                android:layout_height="2dp"
                android:background="#000000"
                android:orientation="horizontal" >
            </LinearLayout>

            <LinearLayout
                android:id="@+id/textLayout"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:background="#1C1C1C"
                android:padding="10dp">

                <TextView
                    android:id="@+id/text"
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:text="MESSAGE BODY"
                    android:textColor="#FFFFFF"
                    android:textSize="18sp" />
            </LinearLayout>

            <LinearLayout
                android:id="@+id/horizontalLayout2"
                android:layout_width="match_parent"
                android:layout_height="2dp"
                android:background="#000000"
                android:orientation="horizontal" >
            </LinearLayout>

            <LinearLayout
                android:id="@+id/alldismisslayout"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:background="#2E2E2E"
                android:gravity="center">

                <ImageView
                    android:id="@+id/dismissicon"
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:contentDescription="@string/dismissicon"
                    android:src="@drawable/ic_launcher" />

                <LinearLayout
                    android:id="@+id/dismissLayout"
                    android:layout_width="0dp"
                    android:layout_weight="1"
                    android:layout_height="match_parent"
                    android:gravity="center"
                    android:paddingLeft="5dp">

                    <TextView
                        android:id="@+id/dismissText"
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:text="@string/notificationdismiss"
                        android:textColor="#FFFFFF"
                        android:textSize="18sp" />
                </LinearLayout>
            </LinearLayout>
        </LinearLayout>
    </LinearLayout>
</LinearLayout>

答案 3 :(得分:2)

嘿,用 layout hierarchy

尝试此操作
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="#1C1C1C"
android:baselineAligned="false"
android:orientation="horizontal" >

<ImageView
    android:id="@+id/iconimage"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_gravity="center"
    android:src="@drawable/cancel" />

<View
    android:layout_width="3dp"
    android:layout_height="fill_parent"
    android:layout_marginLeft="3dp"
    android:background="@color/GREEN" />

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

    <LinearLayout
        android:id="@+id/topTextlayout"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="#2E2E2E"
        android:gravity="center_horizontal"
        android:paddingBottom="5dp" >

        <TextView
            android:id="@+id/topText"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="center"
            android:paddingTop="5dp"
            android:text="TITLE"
            android:textColor="@color/WHITE"
            android:textSize="18sp" />
    </LinearLayout>

    <View
        android:layout_width="fill_parent"
        android:layout_height="3dp"
        android:background="@color/your_color" />

    <LinearLayout
        android:id="@+id/textLayout"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="#1C1C1C"
        android:paddingTop="5dp" >

        <TextView
            android:id="@+id/text"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:paddingBottom="10dp"
            android:paddingLeft="5dp"
            android:text="MESSAGE BODY"
            android:textColor="#FFFFFF"
            android:textSize="18sp" />
    </LinearLayout>

    <View
        android:layout_width="fill_parent"
        android:layout_height="3dp"
        android:background="@color/GREEN" />

    <LinearLayout
        android:id="@+id/alldismisslayout"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="#2E2E2E" >

        <TextView
            android:id="@+id/dismissText"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:drawableLeft="@drawable/cancel"
            android:drawablePadding="5dp"
            android:paddingLeft="5dp"
            android:text="@string/notificationdismiss"
            android:textColor="#FFFFFF"
            android:textSize="18sp" />
    </LinearLayout>
</LinearLayout>

答案 4 :(得分:1)

试试这个:

创建一个彩色垂直线9补丁图像

然后在android xml文件的View中使用该图像

更改您的XML文件,如:

 <?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="#151515"
android:baselineAligned="false"
android:orientation="horizontal" >
<LinearLayout
    android:id="@+id/iconimagelayout"
    android:layout_width="wrap_content"
    android:layout_height="match_parent"
    android:gravity="center"
    android:orientation="horizontal"
    android:layout_marginRight="10dp"
    android:paddingLeft="5dp" >
    <ImageView
        android:id="@+id/iconimage"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:contentDescription="icon"

        android:src="@drawable/ic_launcher" />

       <View
           android:layout_width="1dp"
           android:layout_height="fill_parent"
            android:background="@drawable/untitled" />
</LinearLayout>
<LinearLayout
    android:id="@+id/NameLayout"
    android:layout_width="0dp"
    android:layout_height="match_parent"
    android:layout_weight=".70"
    android:orientation="vertical"
    android:paddingLeft="10sp" >
    <LinearLayout
        android:id="@+id/topTextlayout"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="#2E2E2E"
        android:gravity="center_horizontal"
        android:paddingBottom="5dp" >
        <TextView
            android:id="@+id/topText"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:paddingTop="5dp"
            android:text="TITLE"
            android:textColor="#FFFFFF"
            android:textSize="18sp" />
    </LinearLayout>
    <LinearLayout
        android:id="@+id/horizontalLayout"
        android:layout_width="match_parent"
        android:layout_height="2dip"
        android:background="#000000"
        android:orientation="horizontal" >
    </LinearLayout>
    <LinearLayout
        android:id="@+id/textLayout"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="#1C1C1C"
        android:paddingTop="5dp" >
        <TextView
            android:id="@+id/text"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:paddingBottom="10dp"
            android:paddingLeft="5dp"
            android:text="MESSAGE BODY"
            android:textColor="#FFFFFF"
            android:textSize="18sp" />
    </LinearLayout>
    <LinearLayout
        android:id="@+id/horizontalLayout2"
        android:layout_width="match_parent"
        android:layout_height="2dip"
        android:background="#000000"
        android:orientation="horizontal" >
    </LinearLayout>
    <LinearLayout
        android:id="@+id/alldismisslayout"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="#2E2E2E" >
        <ImageView
            android:id="@+id/dismissicon"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:contentDescription="dismissicon"
            android:src="@drawable/ic_launcher" />
        <LinearLayout
            android:id="@+id/dismissLayout"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:gravity="center|left" >
            <TextView
                android:id="@+id/dismissText"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:paddingLeft="5dp"
                android:text="notificationdismiss"
                android:textColor="#FFFFFF"
                android:textSize="18sp" />
        </LinearLayout>
    </LinearLayout>
</LinearLayout>
</LinearLayout>

在这里:

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

无标题是我的9补丁图片。 9补丁图像,因为它可以根据屏幕分辨率进行拉伸