Osiągnąłem efekt, o którym wspomniałem, za pomocą poniższej metody. Właśnie dodałem widok za pływającym przyciskiem i nad innymi układami i utrzymuję widoczność widoku GONE, dopóki menu nie zostanie rozwinięte. Następnie ustawię widoczność widoku na WIDOCZNY. I tak, ustawić tło widoku na dowolny nieprzezroczysty kolor, który chcesz.
Mój kod
Mój plik XML
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
xmlns:fab="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="match_parent">
<TextView
android:text="Other View here"
android:textSize="50dp"
android:layout_centerHorizontal="true"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
<View
android:id="@+id/background_dimmer"
android:visibility="gone"
android:background="#55000000"
android:layout_width="match_parent"
android:layout_height="match_parent"/>
<com.getbase.floatingactionbutton.FloatingActionsMenu
android:id="@+id/multiple_actions"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:layout_alignParentRight="true"
android:layout_alignParentEnd="true"
fab:fab_addButtonColorNormal="@color/white"
fab:fab_addButtonColorPressed="@color/white_pressed"
fab:fab_addButtonPlusIconColor="@color/half_black"
fab:fab_labelStyle="@style/menu_labels_style"
android:layout_marginBottom="16dp"
android:layout_marginRight="16dp"
android:layout_marginEnd="16dp">
<com.getbase.floatingactionbutton.FloatingActionButton
android:id="@+id/action_a"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
fab:fab_colorNormal="@color/white"
fab:fab_title="Action A"
fab:fab_colorPressed="@color/white_pressed"/>
</com.getbase.floatingactionbutton.FloatingActionsMenu>
A na aktywny lub jego fragment, gdzie FloatingButtons są obsługiwane
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_map);
setFloatingButtonControls();
}
private void setFloatingButtonControls(){
this.bckgroundDimmer = findViewById(R.id.background_dimmer);
this.floatingActionsMenu = (FloatingActionsMenu) findViewById(R.id.multiple_actions);
this.floatingActionsMenu.setOnFloatingActionsMenuUpdateListener(new FloatingActionsMenu.OnFloatingActionsMenuUpdateListener() {
@Override
public void onMenuExpanded() {
bckgroundDimmer.setVisibility(View.VISIBLE);
}
@Override
public void onMenuCollapsed() {
bckgroundDimmer.setVisibility(View.GONE);
}
});
}
To da efekt chciałeś. Mam nadzieję że to pomoże. To na pewno mi pomogło. :)
Wyświetlam FloatingActionMenu w Fragment i użycie powyższego rozwiązania nie powoduje nałożenia paska akcji. Masz pomysł, jak uzyskać nakładkę na pełnym ekranie? –
@PawanKumar Napotkasz problem w Fragment. Każdy widok nakładki będzie z tyłu fragmentu lub będzie na górze wszystkiego. FAB zostanie również nałożony. Lepiej będzie używać FAB w Activity. –