From bc6bc091c7337b091f77f71894dbbdb8b2ea1add Mon Sep 17 00:00:00 2001 From: Jean-Baptiste Date: Mon, 15 Dec 2025 18:02:38 +0100 Subject: [PATCH] [android] Fix camera cutout offset in navigation Signed-off-by: Jean-Baptiste --- .../java/app/organicmaps/routing/NavigationController.java | 5 +++++ android/app/src/main/java/app/organicmaps/util/UiUtils.java | 6 ++++++ android/app/src/main/res/layout-land/layout_nav_top.xml | 6 +++--- android/app/src/main/res/layout/layout_nav_top.xml | 6 +++--- 4 files changed, 17 insertions(+), 6 deletions(-) diff --git a/android/app/src/main/java/app/organicmaps/routing/NavigationController.java b/android/app/src/main/java/app/organicmaps/routing/NavigationController.java index 7ca7e557f..693718ca9 100644 --- a/android/app/src/main/java/app/organicmaps/routing/NavigationController.java +++ b/android/app/src/main/java/app/organicmaps/routing/NavigationController.java @@ -98,6 +98,11 @@ public class NavigationController implements TrafficManager.TrafficCallback, Nav mSpeedLimit = topFrame.findViewById(R.id.nav_speed_limit); mCurrentSpeed = topFrame.findViewById(R.id.nav_current_speed); + View mTopbar = topFrame.findViewById(R.id.statutbar); + ViewCompat.setOnApplyWindowInsetsListener(mTopbar,(v, windowInsets) -> { + UiUtils.setViewNavigationInsetsPaddingNoBottom(v, windowInsets); + return windowInsets; + }); // Show a blank view below the navbar to hide the menu content final View navigationBarBackground = mFrame.findViewById(R.id.nav_bottom_sheet_nav_bar); final View nextTurnContainer = mFrame.findViewById(R.id.nav_next_turn_container); diff --git a/android/app/src/main/java/app/organicmaps/util/UiUtils.java b/android/app/src/main/java/app/organicmaps/util/UiUtils.java index 762973c37..0116c7e54 100644 --- a/android/app/src/main/java/app/organicmaps/util/UiUtils.java +++ b/android/app/src/main/java/app/organicmaps/util/UiUtils.java @@ -281,6 +281,12 @@ public final class UiUtils view.setPadding(systemInsets.left, systemInsets.top, systemInsets.right, view.getPaddingBottom()); } + public static void setViewNavigationInsetsPaddingNoBottom(View view, WindowInsetsCompat windowInsets) + { + final Insets systemInsets = windowInsets.getInsets(WindowInsetsCompat.Type.systemBars() | WindowInsetsCompat.Type.displayCutout()); + view.setPadding(view.getPaddingStart(), systemInsets.top, view.getPaddingEnd(), view.getPaddingBottom()); + } + public static void setupNavigationIcon(@NonNull MaterialToolbar toolbar, @NonNull View.OnClickListener listener) { View customNavigationButton = toolbar.findViewById(R.id.back); diff --git a/android/app/src/main/res/layout-land/layout_nav_top.xml b/android/app/src/main/res/layout-land/layout_nav_top.xml index 1d7bef433..90560821d 100644 --- a/android/app/src/main/res/layout-land/layout_nav_top.xml +++ b/android/app/src/main/res/layout-land/layout_nav_top.xml @@ -11,13 +11,13 @@ diff --git a/android/app/src/main/res/layout/layout_nav_top.xml b/android/app/src/main/res/layout/layout_nav_top.xml index 4587fc510..8cc7d0307 100644 --- a/android/app/src/main/res/layout/layout_nav_top.xml +++ b/android/app/src/main/res/layout/layout_nav_top.xml @@ -11,13 +11,13 @@