ti-enxame.com

Como alterar a cor de fundo em torno de um DialogFragment?

Estou construindo um personalizado DialogFragment. O layout da caixa de diálogo está definido como my_dialog.xml, mas como posso modificar a cor ao redor da caixa de diálogo (o cinza transparente)?

enter image description here

my_dialog.xml

<RelativeLayout xmlns:Android="http://schemas.Android.com/apk/res/Android"
    Android:layout_width="wrap_content"
    Android:layout_height="wrap_content"
    Android:layout_gravity="center" >

    <TextView
        Android:id="@+id/hello"
        Android:layout_width="100dp"
        Android:layout_height="100dp"
        Android:background="@Android:color/holo_orange_light"
        Android:gravity="center"
        Android:text="hello" />

</RelativeLayout>

MyDialogFragment.Java

public class MyDialogFragment extends DialogFragment {

    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
            Bundle savedInstanceState) {

        View view = inflater.inflate(R.layout.my_dialog, container);

        getDialog().getWindow().requestFeature(Window.FEATURE_NO_TITLE);

        return view;
    }
}
39
jul

Eu tive que definir Android:windowIsFloating para false e Android:windowBackground para minha cor personalizada no estilo de diálogo:

styles.xml

<resources xmlns:Android="http://schemas.Android.com/apk/res/Android">

    <style name="MyDialog" parent="@Android:style/Theme.Dialog">
        <item name="Android:windowFrame">@null</item>
        <item name="Android:windowBackground">@color/orange_transparent</item>
        <item name="Android:windowIsFloating">false</item>
        <item name="Android:windowContentOverlay">@null</item>
        <item name="Android:windowTitleStyle">@null</item>
        <item name="Android:colorBackgroundCacheHint">@null</item>
        <item name="Android:windowAnimationStyle">@Android:style/Animation.Dialog</item>
        <item name="Android:windowSoftInputMode">stateUnspecified|adjustPan</item>
        <item name="Android:gravity">center</item>
    </style>

</resources>

MyDialogFragment

public class MyDialogFragment extends DialogFragment {

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setStyle(DialogFragment.STYLE_NO_TITLE, R.style.MyDialog);
    }
}
50
jul

Eu queria um plano de fundo transparente para o meu DialogFragment, e, no código, isso funciona bem:

@Override
public void onStart() {
    super.onStart();

    Window window = getDialog().getWindow();
    window.setBackgroundDrawableResource(Android.R.color.transparent);
}

Obviamente, você pode especificar qualquer cor ou Drawable usando setBackgroundDrawable() ou setBackgroundDrawableResource().

Isso funciona pelo menos em onStart(), mas não em onCreate(), e não necessariamente em onCreateView(), ao que parece .

Dito isto, na maioria dos casos, provavelmente é mais limpo fazer isso em XML, usando estilos , seguindo estas linhas:

<style name="MyDialogStyle" parent="@Android:style/Theme.Holo.Light.Dialog">
    <item name="Android:windowBackground">@Android:color/transparent</item>
</style>
26
Jonik

Para obter uma caixa de diálogo totalmente transparente, você pode definir em onCreateView o seguinte

  • setBackgroundDrawable para Color.TRANSPARENT
  • setDimAmount para 0

Veja o exemplo de código aqui:

public class TextEditor extends DialogFragment {

    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
        View view = inflater.inflate(R.layout.fragment_text_editor, container);

        // make dialog itself transparent
        getDialog().getWindow().setBackgroundDrawable(new ColorDrawable(Color.TRANSPARENT));

        // remove background dim 
        getDialog().getWindow().setDimAmount(0);

        //[add more custom code here...]

        return view;
    }
}
17
Dirk

Eu descobri que só precisava fazer isso:

<style name="MyDialog" parent="@Android:style/Theme.Dialog">
    <!--  other attributes  -->
    <item name="Android:backgroundDimEnabled">false</item>
</style>
14
Blundell

Substituir onCreate e definir o estilo deve funcionar.

@Override
public void onCreate(Bundle savedInstance){
    super.onCreate(savedInstance);
    setStyle(DialogFragment.STYLE_NO_FRAME, Android.R.style.Theme_Translucent);
}
2
amafernandes

Aqueles que estão usando o construtor AlertDialog em 'onCreateDialog' em vez de 'onCreateView' podem atribuir um tema como o código a seguir. Um conjunto completo de temas pode ser encontrado em R.style . Não esqueça que alguns deles são compatíveis recentemente e não estão disponíveis em telefones de dispositivos antigos.

@Override
    public Dialog onCreateDialog(Bundle savedInstanceState) {

        AlertDialog.Builder builder = new AlertDialog.Builder(getActivity(), Android.R.style.Theme_Translucent);
        View view = getActivity().getLayoutInflater().inflate(R.layout.dialog_album, null);
        builder.setView(view);

        return builder.create();
    }
2
Hesam

A resposta de Jul foi quase boa para mim. Mas parece que não funciona ao usar um AlertDialog.Builder.

Eu tive que definir o estilo aqui:

@Override
public Dialog onCreateDialog(Bundle savedInstanceState) {

    // Use the Builder class for convenient dialog construction
    AlertDialog.Builder builder = new AlertDialog.Builder(getActivity(), R.style.MyDialog );
1
Ignacio Roda

altere seu texto Background no XML, apenas editei seu código, substitua-o pelo seu

<RelativeLayout xmlns:Android="http://schemas.Android.com/apk/res/Android"
Android:layout_width="wrap_content"
Android:layout_height="wrap_content"
Android:layout_gravity="center" >

<TextView
    Android:id="@+id/hello"
    Android:layout_width="100dp"
    Android:layout_height="100dp"
    Android:gravity="center"
    Android:text="hello" />

porque você deu a TextView altura e largura de 100dp. e defina um plano de fundo que preencherá toda a caixa de diálogo. pois seu layout principal é wrap_content. por favor aceite a resposta se isso o ajudou.
Editar: para alterar o background basta adicionar ao seu layout ou à sua exibição de texto Android:background="#232323", você pode alterar esse número para qualquer cor que desejar. ou você pode definir um plano de fundo do drawable como Android:background="@drawable/yourpicturename"

0
k0sh