こんにちは、フルスクリーンの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>
このようにコードでレイアウトパラメータを手動で設定することができます。それが役に立てば幸い ! :)。また、これを確認してくださいSO Androidのカスタムダイアログボックスのサイズの調整
Window window = myDialog.getWindow();
window.setLayout(LayoutParams.FILL_PARENT, LayoutParams.FILL_PARENT);
これは私があなたの問題を処理するために見つけた解決策です:
@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));
}
}
以下のソリューションは私にとって完璧に機能しました。
以下のようなフラグメントダイアログのスタイルを作成します。
<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;
}
}
ハッピーコーディング!!!
次のようなこともできます
@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);
}
以下は私の解決策です。
<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>
スタイルとテーマを変更する方法があります。
/* theme is optional, I am using leanback... */
setStyle(STYLE_NORMAL, R.style.AppTheme_Leanback);
フルスクリーンを取得するためにテストし、シンプルなレイアウトでうまく動作しました。
getDialog().getWindow().addFlags(WindowManager.LayoutParams.FLAG_DRAWS_SYSTEM_BAR_BACKGROUNDS);
getDialog().getWindow().addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);
上記のいずれも機能しない場合(私には役に立たなかったなど)、 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)
}
FWIW、@ style/Base.Theme.AppCompat.Lightをサブクラス化した特別なスタイルを設定する必要がありました。それ以外の場合、サポートライブラリフィールドはどれも正しく見えませんでした。 @ style/Base.Theme.AppCompat.Light.Dialogを使用すると、私が望んでいないフローティングな外観が作成されます。