Missing buttons on AlertDialog | Android 7.0 (Nexus 5x)

前端 未结 9 1762
别那么骄傲
别那么骄傲 2020-12-05 13:19

I am trying to create an AlertDialog but the buttons are not showing. Only seeing this issue in Android 7.0:

final AlertDialog.Builder builder =         


        
相关标签:
9条回答
  • 2020-12-05 13:33

    You need use a theme, like this:

    Android.App.AlertDialog.Builder alert = new Android.App.AlertDialog.Builder (Activity, Android.Resource.Style.ThemeMaterialDialogAlert);
    0 讨论(0)
  • 2020-12-05 13:34

    Indeed it seems that AlertDialog theme needs to be defined. An alternative approach to above would be to define AlertDialog theme in Application theme:

    <style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar">
        <!-- ... other AppTheme items ... -->
        <item name="android:alertDialogTheme">@style/AlertDialogTheme</item>
    </style>
    
    <style name="AlertDialogTheme" parent="Theme.AppCompat.Light.Dialog.Alert">
        <item name="colorPrimary">@color/colorPrimary</item>
        <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
        <item name="colorAccent">@color/colorAccent</item>
    </style>
    

    Then it is enough create AlertDialog.Builder only with Context parameter.

    Note: The above seems to work only for android.app.AlertDialog.Builder and is not working for AppCompat builder (android.support.v7.app.AlertDialog.Builder, at least as of version 25.0.1). In case of AppCompat builder, I had to pass theme ID as second parameter to Builder constructor to have buttons visible.

    0 讨论(0)
  • 2020-12-05 13:34

    What worked for me was in styles.xml:

    <style name="LightDialogTheme" parent="Theme.AppCompat.Light.Dialog.Alert">
        <item name="android:textColor">@android:color/primary_text_light</item>
        <item name="colorAccent">#007fff</item>
        <item name="buttonBarButtonStyle">@style/DialogButtonStyle</item>   
    </style>
    

    and

    <style name="DialogButtonStyle" parent="@style/Widget.AppCompat.Button.ButtonBar.AlertDialog">
        <item name="android:textColor">#007fff</item>                   
    </style>
    

    and in your program:

    final AlertDialog.Builder alertDialog = new AlertDialog.Builder(getActivity(), R.style.LightDialogTheme);
    
    0 讨论(0)
  • 2020-12-05 13:37

    You can add custom colour to button. Below your code

    builder.show();
    

    Write this

    Button bg = dialog.getButton(DialogInterface.BUTTON_POSITIVE);
    bg.setTextColor(Color.BLUE);
    
    0 讨论(0)
  • 2020-12-05 13:38

    Sorry for late answer, Its about import problem. you need to select v7.alertDialog, not use app.alertDialog.

    Please change your code to v7.alertDialog and you will show button color in nexus as well.

    0 讨论(0)
  • 2020-12-05 13:42

    You can create a custom theme for Alert Dialog, and set alertDialogTheme in your app theme.

    <!--Alert Dialog Theme -->
    <style name="AlertDialogTheme" parent="Theme.AppCompat.Light.Dialog.Alert">
    
        <item name="android:textColor">@color/colorPrimary</item>
        <item name="buttonBarButtonStyle">@style/DialogButtonStyle</item>
        <item name="colorAccent">@color/colorAccent</item>
    
        <!--If minimum API level is greater than or equal to 23, you can define the color of Title text separately  -->
        <item name="android:titleTextColor">@SomeColor</item> 
    
    </style>
    
    <!--This is to style the buttons of alert dialog-->
    <style name="DialogButtonStyle" parent="@style/Widget.AppCompat.Button.ButtonBar.AlertDialog">
        <item name="android:textColor">@color/colorAccent</item>
    </style>
    

    and finally, set the custom created theme to alertDialogTheme in Application Theme:

    <style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
        <!--To make the change global to application-->
        <item name="alertDialogTheme">@style/AlertDialogTheme</item>
    </style>
    

    Tested for android.support.v7.app.AlertDialog

    0 讨论(0)
提交回复
热议问题