Android BottomSheetDialogFragment имеет цвет за закругленными углами - PullRequest
0 голосов
/ 08 января 2019

Я использую BottomSheetDialogFragment, и я округляю углы в верхнем правом / левом углу, и он работает правильно, но я заметил, что за закругленными углами он не прозрачен и очень раздражает.

Это заметно на скриншоте ниже:

enter image description here

Как мне сделать их прозрачными?

Ответы [ 2 ]

0 голосов
/ 30 июня 2019

Создайте собственный стиль, как показано ниже.

 <style name="AppBottomSheetDialogTheme" parent="Theme.Design.Light.BottomSheetDialog">
        <item name="bottomSheetStyle">@style/AppModalStyle</item>
    </style>

    <style name="AppModalStyle" parent="Widget.Design.BottomSheet.Modal">
        <item name="android:background">@drawable/rounded_corner_top_only</item>
    </style>

затем переопределите этот метод в пользовательском фрагменте.

 @Override
    public void onCreate(@Nullable Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        //bottom sheet round corners can be obtained but the while background appears to remove that we need to add this.
        setStyle(DialogFragment.STYLE_NO_FRAME,R.style.AppBottomSheetDialogTheme);
    }

Это работает со мной, надеюсь, это будет работать с вами.

0 голосов
/ 09 апреля 2019

Вы должны изменить bottom sheet theme, чтобы получить верхнюю круглую раскладку

Создание настраиваемого рисованного background_bottom_sheet_dialog_fragment.xml:

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
   android:shape="rectangle">
    <corners
       android:topLeftRadius="8dp"
        android:topRightRadius="8dp" />
    <padding android:top="0dp" />
    <solid android:color="@color/white" />
</shape>

Затем переопределите bottomSheetDialogTheme для styles.xml, используя рисование в качестве фона:

<!--Bottom sheet-->
<style name="BottomSheet" parent="@style/Widget.Design.BottomSheet.Modal">
    <item 
    name="android:background">@drawable/background_bottom_sheet_dialog_fragment
    </item>
</style>

<style name="BaseBottomSheetDialog" 
    parent="@style/Theme.Design.Light.BottomSheetDialog">
    <item name="android:windowIsFloating">false</item>
    <item name="bottomSheetStyle">@style/BottomSheet</item>
</style>

<style name="BottomSheetDialogTheme" parent="BaseBottomSheetDialog" />

Это изменит фоновую раскладку нижнего листа

ПРИМЕЧАНИЕ. Удалите весь фон из макета диалогового окна нижнего листа.

...