web-dev-qa-db-ja.com

スナックバープッシュビューを上向きにする

スナックバーを表示するときにビューを上に押す方法はありますか?

snackbar

現在、スナックバーが表示されているときは、下のビューにオーバーレイされているため、ボタンの半分が切り取られているように見えますが、画面に表示されているときのソフトキーボードの動作とほぼ同じように「adjustPan」にしたいと思います。

誰かがこれを達成するためのトリックを知っていますか?

13
Simon

ビューをAndroid.support.design.CoordinatorLayout内に配置します

<Android.support.design.widget.CoordinatorLayout
    Android:id="@+id/coordinator"
    Android:layout_width="match_parent"
    Android:layout_height="match_parent"
    Android:layout_alignParentBottom="true"
    Android:layout_centerHorizontal="true">

    <View
        Android:id="@+id/my_view"
        Android:layout_width="wrap_content"
        Android:layout_height="wrap_content"
        app:layout_behavior="com.example.FloatingActionButtonBehavior"/>

</Android.support.design.widget.CoordinatorLayout>

ここで重要なのはapp:layout_behavior属性です。クラスの実装は次のとおりです。

public class FloatingActionButtonBehavior extends CoordinatorLayout.Behavior<FloatingActionButton> {

    public FloatingActionButtonBehavior(Context context, AttributeSet attrs) {
    }

    @Override
    public boolean layoutDependsOn(CoordinatorLayout parent, FloatingActionButton child, View dependency) {

        return dependency instanceof SnackbarLayout;
    }

    @Override
    public boolean onDependentViewChanged(CoordinatorLayout parent, FloatingActionButton child, View dependency) {

        float translationY = Math.min(0, dependency.getTranslationY() - dependency.getHeight());
        child.setTranslationY(translationY);
        return true;
    }
}

次に、スナックバーを表示するときに、CoordinatorLayoutへの参照を渡します。

CoordinatorLayout coordinator = findViewById(R.id.coordinator);
Snackbar.make(coordinator, textResId, Snackbar.LENGTH_LONG)
        .setAction(R.string.accept_ok, new View.OnClickListener() {
            @Override
            public void onClick(View v) {

            }
        })
        .setDuration(Snackbar.LENGTH_INDEFINITE)
        .show();

これがお役に立てば幸いです。

25
sourcerebels

彼はKotlinでジェネリックを使用するSourceRebelesソリューションです。

typealias T = View

class FloatingActionButtonBehavior(context: Context, attrs: AttributeSet) : CoordinatorLayout.Behavior<T>() {

    override fun layoutDependsOn(parent: CoordinatorLayout, child: T, dependency: View): Boolean {

        return dependency is SnackbarLayout
    }

    override fun onDependentViewChanged(parent: CoordinatorLayout, child: T, dependency: View): Boolean {

        val translationY = Math.min(0.0f, (dependency.translationY - dependency.height).toFloat())
        child.translationY = translationY
        return true
    }
}
0
Ryan Newsom

enter image description here

スナックバーは、最も近いCoordinatorLayoutparentViewとして検索します。

 findViewById(R.id.tv_main).setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {
            Snackbar.make(findViewById(R.id.tv_main), "Replace with your own action", Snackbar.LENGTH_LONG)
                    .setAction("Action", null).show();
            toolbar.getChildAt(1).setVisibility(View.GONE);
        }
    });

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:Android="http://schemas.Android.com/apk/res/Android"
    Android:orientation="vertical" Android:layout_width="match_parent"
    Android:layout_height="match_parent">
    <TextView
    Android:text="s"
    Android:layout_weight="1"
    Android:layout_width="match_parent"
    Android:layout_height="wrap_content" />
    <Android.support.design.widget.CoordinatorLayout
        Android:layout_width="match_parent"
        Android:layout_marginBottom="200dp"
        Android:layout_height="100dp">
        <TextView
            Android:id="@+id/tv_main"
            Android:background="#4b14b1"
            Android:layout_width="100dp"
            Android:layout_height="100dp" />
    </Android.support.design.widget.CoordinatorLayout>
</RelativeLayout>
0
tiny sunlight