web-dev-qa-db-ja.com

BottomSheetBehaviour:ビューはBottomSheetBehaviorに関連付けられていません

私はGoogle Design Support Library 25.0.0を使用しています。私のアクティビティでは、

app:layout_behavior="Android.support.design.widget.BottomSheetBehavior"

BottomSheetBehaviourを追加するために参照すると、エラーが発生します

Java.lang.IllegalArgumentException: The view is not associated with BottomSheetBehavior

ここにレイアウトがあります:

<Android.support.design.widget.CoordinatorLayout xmlns:Android="http://schemas.Android.com/apk/res/Android"
xmlns:map="http://schemas.Android.com/apk/res-auto"
Android:layout_width="match_parent"
Android:layout_height="match_parent"
Android:id="@+id/maps_colayout"
xmlns:app="http://schemas.Android.com/tools"
Android:fitsSystemWindows="true"
Android:background="@color/white">

...

<RelativeLayout
    Android:layout_width="match_parent"
    Android:layout_height="280dp"
    Android:layout_gravity="bottom"
    Android:id="@+id/rl_bottomsheet"
    Android:background="#F3F3F3"
    app:layout_behavior="Android.support.design.widget.BottomSheetBehavior">

    ...

</RelativeLayout>

そしてここに活動関連のコードがあります:

CoordinatorLayout colayout = (CoordinatorLayout) findViewById(R.id.maps_colayout);
    View bottomSheet = colayout.findViewById(R.id.rl_bottomsheet);
    BottomSheetBehavior behavior = BottomSheetBehavior.from(bottomSheet);
    behavior.setBottomSheetCallback(new BottomSheetBehavior.BottomSheetCallback() {
        @Override
        public void onStateChanged(@NonNull View bottomSheet, int newState) {
            // React to state change
        }

        @Override
        public void onSlide(@NonNull View bottomSheet, float slideOffset) {
            // React to dragging events
        }
    });
25

この行を線形レイアウトタグ内に追加する必要があります。参照されているもの。

app:layout_behavior="Android.support.design.widget.BottomSheetBehavior"

またはAndroidの場合x

app:layout_behavior="com.google.Android.material.bottomsheet.BottomSheetBehavior"
26
Leslie

誤ったapp名前空間が宣言されています。行を置き換える:

xmlns:app="http://schemas.Android.com/tools"

xmlns:app="http://schemas.Android.com/apk/res-auto"

レイアウトファイルのCoordinatorLayout宣言内。

tools名前空間は、「ツール」(たとえばIDE)にレイアウトに関する追加情報を提供するために使用されます。この情報はアプリから削除されます。

一方、app名前空間は、すべてのカスタム(つまり、Androidシステム)属性では宣言されていない)のグローバル名前空間であり、ユーザーまたはインポートされたライブラリによって宣言されます。 (設計サポートライブラリはあなたのケースです。)これらはアプリに含まれています。

では実際にtools名前空間は何に適しているのでしょうか?最も一般的な使用方法は、レイアウトのプレビューをより適切にレンダリングすることです。たとえば、TextViewがあり、最初は空で、後で入力する必要があるとします。

TextView宣言に属性を追加できます。

tools:text="Some example text here"

このテキストはアプリに表示されません。ただし、Android Studioでレンダリングされたレイアウトプレビューにはそれが含まれているため、モバイルデバイスで何を期待するかを確認できます。

11
Marcin Jedynak

まず、androidXを使用している場合は、「app:layout_behavior="@string/bottom_sheet_behavior" "またはapp:layout_behavior="com.google.Android.material.bottomsheet.BottomSheetBehavior"

2番目に、ボトムシートの動作を伴うビューは、コーディネーターレイアウトの直接の子である必要があります。

最後に、削除layout_widthおよびlayout_height必要に応じて、プログラムで実行する場合は、その要素の属性。

1
Max Droid