私は FAB (フローティングアクションボタン) を持っています
<android.support.design.widget.CoordinatorLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/coordinatorLayout"
android:layout_width="match_parent"
android:layout_height="match_parent">
...
<android.support.design.widget.FloatingActionButton
android:id="@+id/fabButton"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="bottom|right"
android:layout_margin="@dimen/fab_margin"
app:layout_anchorGravity="bottom|right|end"
android:src="@drawable/img"
app:borderWidth="0dp"
/>
この FAB は、スクロールする RecycleView の上に存在します。スクロールの特定の段階で、SnackBar を表示すると、すべてが宣伝どおりに機能します (具体的には、SnackBar はブロックを回避するために FAB をシフトします。
ここで、下にスクロールすると FAB を非表示にするカスタム動作を実装したいと考えています。
だから私はカスタム動作を作成しました:
public class CustomBehavior extends CoordinatorLayout.Behavior<FloatingActionButton> {
private int toolbarHeight;
public CustomBehavior(Context context, AttributeSet attrs) {
super(context, attrs);
this.toolbarHeight = Utils.getToolbarHeight(context);
}
@Override
public boolean layoutDependsOn(CoordinatorLayout parent, FloatingActionButton fab, View dependency) {
return dependency instanceof AppBarLayout;
}
@Override
public boolean onDependentViewChanged(CoordinatorLayout parent, FloatingActionButton fab, View dependency) {
if (dependency instanceof AppBarLayout) {
CoordinatorLayout.LayoutParams lp = (CoordinatorLayout.LayoutParams) fab.getLayoutParams();
int fabBottomMargin = lp.bottomMargin;
int distanceToScroll = fab.getHeight() + fabBottomMargin;
float ratio = (float)dependency.getY()/(float)toolbarHeight;
fab.setTranslationY(-distanceToScroll * ratio);
}
return true;
}
}
これにより、下にスクロールするとFABがほとんど非表示になります(AppBarLayoutと一緒に非表示になるため、これをFAB xml宣言に追加します
app:layout_behavior="com.example.CustomBehavior"
これを行うと、FAB は適切に非表示になりますが、SnackBar は表示時に重なって表示されます。デフォルトの動作がなくなったことを意味します...
両方を持つことは可能ですか?