将EditText / TextView放在MapView Android上

时间:2017-09-29 05:59:39

标签: android

我正在构建一个需要mapview和textview才能启用地点/位置选择器的应用。它就像“uber”,mapview填充整个屏幕,然后用于选择位置的editext视图叠加在地图视图的顶部。问题是我的设计xml文件将textviews置于mapview“后面”,以便它们被地图覆盖并且不可见。我怎么能这样做,他们出现在mapview上;而mapview仍然覆盖了100%的屏幕高度?我的xml文件如下所示:

<?xml version="1.0" encoding="utf-8"?>
   <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
     xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
app:layout_behavior="@string/appbar_scrolling_view_behavior"
>
<LinearLayout
    android:layout_width="match_parent"
    android:orientation="vertical"
    android:layout_height="wrap_content"
    android:layout_alignParentTop="true"
    android:layout_centerHorizontal="true">
<TextView
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_margin="10dp"
    android:textColor="@color/colorPrimary"
    android:text="Pickup Location"
    android:id="@+id/pickup"
    android:textSize="15sp"
    />
<TextView
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_margin="10dp"
    android:textColor="@color/colorPrimary"
    android:text="Drop Location"
    android:id="@+id/drop"
    android:textSize="15sp"
    android:layout_alignParentLeft="true"
    android:layout_below="@id/pickup"
    />
<TextView
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:id="@+id/ride_start"
    android:layout_margin="10dp"
    android:textSize="15sp"
    android:visibility="gone"
    android:textColor="@color/colorPrimary"
    android:layout_below="@+id/drop"
    android:text="Start"/>
</LinearLayout>


<fragment xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/map"
    android:name="com.google.android.gms.maps.SupportMapFragment"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="MainActivity"

    />
<LinearLayout
    android:layout_width="match_parent"
    android:id="@+id/info"
    android:layout_height="wrap_content"
    android:layout_alignParentBottom="true"
    android:layout_centerHorizontal="true"
    android:background="#F8CA2B"
    android:gravity="center_vertical" >
    <TextView
        android:id="@+id/totaldistance"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:padding="3dp"
        android:textColor="#000" />

    <View
        android:layout_width="2dp"
        android:layout_height="25dp"
        android:layout_marginLeft="10dp"
        android:background="#fff" />

    <TextView
        android:id="@+id/cost"
        android:padding="3dp"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:textColor="#000" />

</LinearLayout>

3 个答案:

答案 0 :(得分:1)

首先设置地图分片然后覆盖相对布局可能会有所帮助。

<?xml version="1.0" encoding="utf-8"?>
 <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
            xmlns:app="http://schemas.android.com/apk/res-auto"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:paddingBottom="@dimen/activity_vertical_margin"
            android:paddingLeft="@dimen/activity_horizontal_margin"
            android:paddingRight="@dimen/activity_horizontal_margin"
            android:paddingTop="@dimen/activity_vertical_margin"
            app:layout_behavior="@string/appbar_scrolling_view_behavior">


     <fragment xmlns:android="http://schemas.android.com/apk/res/android"
          xmlns:tools="http://schemas.android.com/tools"
          android:id="@+id/map"
          android:name="com.google.android.gms.maps.SupportMapFragment"
          android:layout_width="match_parent"
          android:layout_height="match_parent"
          tools:context="MainActivity"/>


<RelativeLayout
    android:layout_width="match_parent"
    android:layout_height="wrap_content">
<LinearLayout
    android:layout_width="match_parent"
    android:orientation="vertical"
    android:layout_height="wrap_content"
    android:layout_alignParentTop="true"
    android:layout_centerHorizontal="true">
    <TextView
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_margin="10dp"
        android:textColor="@color/colorPrimary"
        android:text="Pickup Location"
        android:id="@+id/pickup"
        android:textSize="15sp"
        />
    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_margin="10dp"
        android:textColor="@color/colorPrimary"
        android:text="Drop Location"
        android:id="@+id/drop"
        android:textSize="15sp"
        android:layout_alignParentLeft="true"
        android:layout_below="@id/pickup"
        />
    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:id="@+id/ride_start"
        android:layout_margin="10dp"
        android:textSize="15sp"
        android:visibility="gone"
        android:textColor="@color/colorPrimary"
        android:layout_below="@+id/drop"
        android:text="Start"/>
   </LinearLayout>

</RelativeLayout>



<LinearLayout
    android:layout_width="match_parent"
    android:id="@+id/info"
    android:layout_height="wrap_content"
    android:layout_alignParentBottom="true"
    android:layout_centerHorizontal="true"
    android:background="#F8CA2B"
    android:gravity="center_vertical" >
    <TextView
        android:id="@+id/totaldistance"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:padding="3dp"
        android:textColor="#000" />

    <View
        android:layout_width="2dp"
        android:layout_height="25dp"
        android:layout_marginLeft="10dp"
        android:background="#fff" />

    <TextView
        android:id="@+id/cost"
        android:padding="3dp"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:textColor="#000" />

</LinearLayout>

答案 1 :(得分:0)

使用以下代码

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    app:layout_behavior="@string/appbar_scrolling_view_behavior">

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_alignParentTop="true"
        android:layout_centerHorizontal="true"
        android:orientation="vertical">

        <TextView
            android:id="@+id/pickup"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_margin="10dp"
            android:text="Pickup Location"
            android:textColor="@color/colorPrimary"
            android:textSize="15sp" />

        <TextView
            android:id="@+id/drop"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_alignParentLeft="true"
            android:layout_below="@id/pickup"
            android:layout_margin="10dp"
            android:text="Drop Location"
            android:textColor="@color/colorPrimary"
            android:textSize="15sp" />

        <TextView
            android:id="@+id/ride_start"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_below="@+id/drop"
            android:layout_margin="10dp"
            android:text="Start"
            android:textColor="@color/colorPrimary"
            android:textSize="15sp"
            android:visibility="gone" />
    </LinearLayout>

    <RelativeLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent">


        <fragment xmlns:android="http://schemas.android.com/apk/res/android"
            xmlns:tools="http://schemas.android.com/tools"
            android:id="@+id/map"
            android:name="com.google.android.gms.maps.SupportMapFragment"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            tools:context="MainActivity"

            />

        <LinearLayout
            android:id="@+id/info"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_alignBottom="@+id/map"
            android:layout_centerHorizontal="true"
            android:layout_marginBottom="15dp"
            android:background="#F8CA2B"
            android:gravity="center_vertical">

            <TextView
                android:id="@+id/totaldistance"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:padding="3dp"
                android:textColor="#000" />

            <View
                android:layout_width="2dp"
                android:layout_height="25dp"
                android:layout_marginLeft="10dp"
                android:background="#fff" />

            <TextView
                android:id="@+id/cost"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:padding="3dp"
                android:textColor="#000" />

        </LinearLayout>
    </RelativeLayout>
</RelativeLayout>

答案 2 :(得分:0)

<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
xmlns:circular="http://schemas.android.com/tools"
android:id="@+id/content_frame"
xmlns:app="http://schemas.android.com/apk/res-auto">
<FrameLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_below="@+id/content_frame_child">
<!--Your map fragment-->
<fragment xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/map"
android:name="com.google.android.gms.maps.SupportMapFragment"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context="MainActivity"/>
<!--Your map fragment ends--> 
</FrameLayout>
<LinearLayout
android:layout_width="match_parent"
android:id="@+id/info"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:layout_centerHorizontal="true"
android:background="#F8CA2B"
android:gravity="center_vertical" >
<TextView
    android:id="@+id/totaldistance"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:padding="3dp"
    android:textColor="#000" />
<View
    android:layout_width="2dp"
    android:layout_height="25dp"
    android:layout_marginLeft="10dp"
    android:background="#fff" />

<TextView
    android:id="@+id/cost"
    android:padding="3dp"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:textColor="#000" />
</LinearLayout>
</FrameLayout>

使用框架布局进行叠加