From 387f59b7068866fea34a88bf065c6de96ea6868d Mon Sep 17 00:00:00 2001 From: Material Design Team Date: Wed, 20 Mar 2024 06:03:57 +0000 Subject: [PATCH] [Search] Exclude icons from search bar handwriting bounds PiperOrigin-RevId: 617405112 (cherry picked from commit fb441e6cb8243969b64f92f82eb70502ea19d660) --- .../android/material/search/SearchBar.java | 29 +++++++++++++++++++ 1 file changed, 29 insertions(+) diff --git a/lib/java/com/google/android/material/search/SearchBar.java b/lib/java/com/google/android/material/search/SearchBar.java index 47a1cd474d6..27608b6d15f 100644 --- a/lib/java/com/google/android/material/search/SearchBar.java +++ b/lib/java/com/google/android/material/search/SearchBar.java @@ -420,6 +420,8 @@ private void setNavigationIconDecorative(boolean decorative) { // that, and restore the original background when the icon becomes clickable. navigationIconButton.setBackgroundDrawable( decorative ? null : originalNavigationIconBackground); + + setHandwritingBoundsInsets(); } @Override @@ -448,6 +450,7 @@ protected void onLayout(boolean changed, int left, int top, int right, int botto super.onLayout(changed, left, top, right, bottom); layoutCenterView(); + setHandwritingBoundsInsets(); } @Override @@ -559,6 +562,32 @@ private void layoutChild(View child, int left, int top, int right, int bottom) { } } + private void setHandwritingBoundsInsets() { + if (VERSION.SDK_INT < VERSION_CODES.UPSIDE_DOWN_CAKE) { + return; + } + + boolean isRtl = getLayoutDirection() == View.LAYOUT_DIRECTION_RTL; + + // If the navigation icon is non-decorative, exclude it from the handwriting bounds. + int startInset = 0; + View navigationIconButton = ToolbarUtils.getNavigationIconButton(this); + if (navigationIconButton != null && navigationIconButton.isClickable()) { + startInset = + isRtl ? (getWidth() - navigationIconButton.getLeft()) : navigationIconButton.getRight(); + } + + // Exclude the menu items from the handwriting bounds. + int endInset = 0; + View actionMenuView = ToolbarUtils.getActionMenuView(this); + if (actionMenuView != null) { + endInset = isRtl ? actionMenuView.getRight() : (getWidth() - actionMenuView.getLeft()); + } + + setHandwritingBoundsOffsets( + -(isRtl ? endInset : startInset), 0, -(isRtl ? startInset : endInset), 0); + } + /** Returns the optional centered child view of this {@link SearchBar} */ @Nullable public View getCenterView() {