web-dev-qa-db-ja.com

Android:dialogFragmentをフルスクリーンにする方法

こんにちは、フルスクリーンのdialogFragmentにテーマをオーバーライドしようとしましたが、私が欲しかったフルスクリーンは前のアクティビティの上にオーバーレイだったので、dialogFragmentを開いたときに、画面とdialogFragmentの間のパディングからバックアクティビティを見ることができます。

これは私がフルスクリーンに使用したスタイルです

<style name="fullscreen_dialog" parent="Android:Theme" >
    <item name="Android:windowNoTitle">true</item>
    <item name="Android:windowFullscreen">true</item>
    <item name="Android:windowIsFloating">false</item>
</style>
10
LittleFunny

このようにコードでレイアウトパラメータを手動で設定することができます。それが役に立てば幸い ! :)。また、これを確認してくださいSO Androidのカスタムダイアログボックスのサイズの調整

Window window = myDialog.getWindow();
window.setLayout(LayoutParams.FILL_PARENT, LayoutParams.FILL_PARENT);
1
Doug Ray

これは私があなたの問題を処理するために見つけた解決策です:

@Override
    public Dialog onCreateDialog(Bundle savedInstanceState) {
        Dialog dialog = super.onCreateDialog(savedInstanceState);    
        dialog.getWindow().requestFeature(Window.FEATURE_NO_TITLE);
        return dialog;
    }

    @Override
    public void onStart() {
        super.onStart();
        Dialog dialog = getDialog();
        if (dialog != null) {
           dialog.getWindow().setLayout(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT);
            dialog.getWindow().setBackgroundDrawable(new ColorDrawable(Color.TRANSPARENT));
        }
    }
43
droidev

以下のソリューションは私にとって完璧に機能しました。

以下のようなフラグメントダイアログのスタイルを作成します。

<style name="dialog_theme" parent="Android:Theme" >
    <item name="Android:windowNoTitle">true</item>
    <item name="Android:windowIsFloating">false</item>
</style>

以下のようにJavaクラスを作成します。

public class FiltersDialogFragment extends Android.support.v4.app.DialogFragment {

    static FiltersDialogFragment newInstance() {
        FiltersDialogFragment fragment = new FiltersDialogFragment();
        return fragment;
    }

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setStyle(DialogFragment.STYLE_NORMAL, R.style.dialog_theme);
    }

    @Override
    public void onStart() {
        super.onStart();
        Dialog d = getDialog();
        if (d!=null){
            int width = ViewGroup.LayoutParams.MATCH_PARENT;
            int height = ViewGroup.LayoutParams.MATCH_PARENT;
            d.getWindow().setLayout(width, height);
        }
    }

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

ハッピーコーディング!!!

14
Ahsanwarsi

次のようなこともできます

@Override
  public void onCreate(@Nullable final Bundle savedInstanceState) {
    if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.Lollipop) {
      setStyle(STYLE_NO_TITLE, Android.R.style.Theme_Material_Light_NoActionBar_Fullscreen);
    } else {
      setStyle(STYLE_NO_TITLE, Android.R.style.Theme_DeviceDefault_Light_NoActionBar);
    }
    super.onCreate(savedInstanceState);

  }
8
Vaibhav Sharma

以下は私の解決策です。

<style name="Dialog.App" parent="Theme.AppCompat.Dialog"></style>
<style name="Dialog.App.Fullscreen">
    <item name="Android:windowActionBar">false</item>
    <item name="Android:windowNoTitle">true</item>
    <item name="Android:windowContentOverlay">@null</item>
    <item name="Android:colorBackground">@null</item>
    <item name="Android:colorBackgroundCacheHint">@null</item>
    <item name="Android:windowFrame">@null</item>
    <item name="Android:windowBackground">@null</item>

    <!--the key attribute for fullscreen dialog -->
    <item name="Android:windowIsFloating">false</item>

    <!-- only width fill screen -->
    <!--<item name="Android:windowMinWidthMajor">100%</item>-->
    <!--<item name="Android:windowMinWidthMinor">100%</item>-->
</style>
3
ggaier

スタイルとテーマを変更する方法があります。

/* theme is optional, I am using leanback... */
setStyle(STYLE_NORMAL, R.style.AppTheme_Leanback);

フルスクリーンを取得するためにテストし、シンプルなレイアウトでうまく動作しました。

1
arenaq
    getDialog().getWindow().addFlags(WindowManager.LayoutParams.FLAG_DRAWS_SYSTEM_BAR_BACKGROUNDS);
    getDialog().getWindow().addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);
1
dinus

上記のいずれも機能しない場合(私には役に立たなかったなど)、 Android Developer Dialogs Guide でこれを実現する方法の詳細を確認してください。

public void showDialog() {
    FragmentManager fragmentManager = getSupportFragmentManager();
    CustomDialogFragment newFragment = new CustomDialogFragment();

    if (mIsLargeLayout) {
        // The device is using a large layout, so show the fragment as a dialog
        newFragment.show(fragmentManager, "dialog");
    } else {
        // The device is smaller, so show the fragment fullscreen
        FragmentTransaction transaction = fragmentManager.beginTransaction();
        // For a little polish, specify a transition animation
        transaction.setTransition(FragmentTransaction.TRANSIT_FRAGMENT_OPEN);
        // To make it fullscreen, use the 'content' root view as the container
        // for the fragment, which is always the root view for the activity
        transaction.add(Android.R.id.content, newFragment)
                   .addToBackStack(null).commit();
    }
}

私のように、上記の戦略を利用した後もActionBarが表示される場合は、 Iにいくつかのフラグを設定する必要があります です。

private fun hideSystemUI() {
    // Enables regular immersive mode.
    // For "lean back" mode, remove SYSTEM_UI_FLAG_IMMERSIVE.
    // Or for "sticky immersive," replace it with SYSTEM_UI_FLAG_IMMERSIVE_STICKY
    window.decorView.systemUiVisibility = (View.SYSTEM_UI_FLAG_IMMERSIVE
            // Set the content to appear under the system bars so that the
            // content doesn't resize when the system bars hide and show.
            or View.SYSTEM_UI_FLAG_LAYOUT_STABLE
            or View.SYSTEM_UI_FLAG_LAYOUT_HIDE_NAVIGATION
            or View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN
            // Hide the nav bar and status bar
            or View.SYSTEM_UI_FLAG_HIDE_NAVIGATION
            or View.SYSTEM_UI_FLAG_FULLSCREEN)
}
0
airowe

説明でこの質問に答えました

このスレッドで

お役に立てれば :)

0
Biswajit

FWIW、@ style/Base.Theme.AppCompat.Lightをサブクラス化した特別なスタイルを設定する必要がありました。それ以外の場合、サポートライブラリフィールドはどれも正しく見えませんでした。 @ style/Base.Theme.AppCompat.Light.Dialogを使用すると、私が望んでいないフローティングな外観が作成されます。

0
kenyee