Android:ナビゲーションドロワーのアイテムサイズ
Aug 19 2020
ナビゲーションドロワーを備えたAndroidアプリがあります。ドロワーは、メニューリソースファイルからアイテムを取得します。
<com.google.android.material.navigation.NavigationView
android:id="@+id/nav_view"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:layout_gravity="start"
android:fitsSystemWindows="true"
app:headerLayout="@layout/nav_header_main"
app:menu="@menu/activity_main_drawer" />
アクティブなアイテムの上に半透明のレイヤーがあり、これがデフォルトのものです。私の問題は、そのレイヤーのサイズ/マージンにあります。
私はこれが欲しいです:

これの代わりに: https://i.stack.imgur.com/Zlp9p.png
この答えに従って正方形にすることはできますが、それでも周囲にわずかなマージンがあります。
どうすればそれを達成できますか?
回答
1 GabrieleMariotti Aug 19 2020 at 13:33
itemShapeInset*
属性を使用して、スペース全体を埋めることができます。
<com.google.android.material.navigation.NavigationView
app:itemShapeInsetStart="0dp"
app:itemShapeInsetEnd="0dp"
app:itemShapeAppearanceOverlay="@style/ShapeAppearanceOverlay.Nav.Square"
とitemShapeAppearanceOverlay
四角い角を持つために:
<style name="ShapeAppearanceOverlay.Nav.Square" parent="">
<item name="cornerSize">0dp</item>
</style>

AagitoEx Aug 19 2020 at 12:02
この属性を変更してみましたかapp:itemHorizontalPadding="0dp"
。
echosoftware Aug 19 2020 at 12:51
あなたはこれを求めている
<com.google.android.material.navigation.NavigationView
android:id="@+id/nav_view"
style="@style/Widget.Custom.NavigationView"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:layout_gravity="start"
android:clipToPadding="false"
android:fitsSystemWindows="true"
android:theme="@style/NavigationTheme"
app:headerLayout="@layout/nav_header_main"
app:itemHorizontalPadding="45dp"
app:itemIconPadding="@dimen/_17sdp"
app:itemIconTint="#000"
app:itemTextColor="#000"
app:menu="@menu/activity_main_drawer" />
スタイル
<style name="Widget.Custom.NavigationView" parent="Widget.Design.NavigationView">
<item name="itemIconTint">?attr/colorNavigationItem</item>
<item name="itemTextColor">?attr/colorNavigationItem</item>
<item name="itemBackground">?attr/drawableNavigationItemBackground</item>
</style>
<style name="NavigationTheme" parent="AppTheme">
<item name="android:layout_marginBottom">4dp</item>
</style>
追加attr.xml
するvalues
<?xml version="1.0" encoding="utf-8"?>
<resources>
<attr name="colorNavigationItem" format="color" />
<attr name="colorNavigationItemSelected" format="color" />
<attr name="drawableNavigationItemBackground" format="reference" />
</resources>