我正在尝试导航应用程序演示。我使用按钮,地图视图和导航视图相同的布局。创建布局后,可通过mapview初始化从当前位置获取终点和绘制路线。然后,当单击开始按钮时,Navigationview开始导航。该方案工作正常。
但是有一个问题,当Navigationview开始导航时,mapview视图没有运行。只是地图视图停留在导航视图。
我添加了屏幕截图。
我的布局xml代码:
<Button
android:id="@+id/button_Navigate"
android:layout_width="410dp"
android:layout_height="63dp"
android:layout_marginStart="144dp"
android:layout_marginTop="36dp"
android:text="Start Navigate"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
<androidx.cardview.widget.CardView
android:id="@+id/card_viewMap"
android:layout_width="500dp"
android:layout_height="500dp"
android:layout_marginTop="148dp"
android:layout_marginEnd="60dp"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintTop_toTopOf="parent"
card_view:cardCornerRadius="0dp">
<com.mapbox.mapboxsdk.maps.MapView
android:id="@+id/mapView"
android:layout_width="match_parent"
android:layout_height="match_parent"
mapbox:mapbox_cameraZoom="17"></com.mapbox.mapboxsdk.maps.MapView>
</androidx.cardview.widget.CardView>
<androidx.cardview.widget.CardView
android:id="@+id/card_viewNavigate"
android:layout_width="1000dp"
android:layout_height="500dp"
android:layout_marginTop="148dp"
android:layout_marginEnd="60dp"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintTop_toTopOf="parent"
card_view:cardCornerRadius="0dp">
<com.mapbox.services.android.navigation.ui.v5.NavigationView
android:id="@+id/navigationView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:visibility="visible"></com.mapbox.services.android.navigation.ui.v5.NavigationView>
</androidx.cardview.widget.CardView>
而且我尝试了所有有关setVisibility(View.INVISIBLE)或BringtoFront()函数的问题,但存在相同的问题。
覆盖您的
<androidx.cardview.widget.CardView
android:id="@+id/card_viewMap"
android:layout_width="500dp"
android:layout_height="500dp"
android:layout_marginTop="148dp"
android:layout_marginEnd="60dp"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintTop_toTopOf="parent"
card_view:cardCornerRadius="0dp">
<com.mapbox.mapboxsdk.maps.MapView
android:id="@+id/mapView"
android:layout_width="match_parent"
android:layout_height="match_parent"
mapbox:mapbox_cameraZoom="17"></com.mapbox.mapboxsdk.maps.MapView>
</androidx.cardview.widget.CardView>
使用FrameLayout。
更改:
<FrameLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content">
<androidx.cardview.widget.CardView
android:id="@+id/card_viewMap"
android:layout_width="500dp"
android:layout_height="500dp"
android:layout_marginTop="148dp"
android:layout_marginEnd="60dp"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintTop_toTopOf="parent"
card_view:cardCornerRadius="0dp">
<com.mapbox.mapboxsdk.maps.MapView
android:id="@+id/mapView"
android:layout_width="match_parent"
android:layout_height="match_parent"
mapbox:mapbox_cameraZoom="17"></com.mapbox.mapboxsdk.maps.MapView>
</androidx.cardview.widget.CardView>
</FrameLayout>