アクションバーの下に表示されるカスタムDialogFragmentを作成しています。これまでのところ、すべてがうまく機能しています。ダイアログフラグメントのレイアウトパラメーターはmatch_parent
幅とwrap_content
高さ。
レイアウトパラメーター.widthの設定、ディスプレイサイズの取得、テーマの削除など、すべてのソリューションを試しました。ただし、ダイアログの左側、右側、および上側に見えない小さなスペースがあっても関係ありません。このスペースを実際に画面の幅に一致させ、うまくいけば上部のパディングも取り除くように、このスペースを削除する方法を知る必要があります。
カスタムダイアログテーマを使用してそれを理解しました。 windowIsFloating trueは、背景を取り除きますが、背景として背景の下に余分なスペースを追加します。その場合、windowBackground @nullを使用して消去できます。
<style name="CustomDialog" parent="@Android:style/Theme.Holo.Light" >
<item name="Android:windowBackground">@null</item>
<item name="Android:windowIsFloating">true</item>
</style
すべてのスタイル属性を含むリンクをくれたRaghunandanに感謝します。しばらく時間がかかりましたが、そのファイルを調べてみると、非常に興味深い要素が見つかりました。テーマのスタイルを調べるには、以下に掲載されているリンクをぜひご覧ください。
https://groups.google.com/forum/#!topic/Android-developers/NDFo9pF8sHY
ダイアン・ハックボーンの提案から
非ダイアログテーマをAndroid.R.style.Theme
またはAndroid.R.style.Theme_Light
として使用します。
テーマを見てください
このリンクを確認してください
http://developer.Android.com/reference/Android/app/DialogFragment.html
DialogFragment picker = MyDialogFragment.newInstance();
picker.setStyle( DialogFragment.STYLE_NORMAL, Android.R.style.Theme );
picker.show(getFragmentManager(), "MyDialogFragment");
このテーマをダイアログに設定すると、常にフルスクリーンになります
<!-- DIALOG STYLE -->
<style name="You.Dialog" parent="Android:Theme.Holo.Dialog" >
<item name="Android:windowNoTitle">true</item>
<item name="Android:windowFullscreen">true</item>
<item name="Android:windowIsFloating">false</item>
</style>
これを行うには、この setStyle(int、int) メソッドを使用できます。
dialogFragment.setStyle( DialogFragment.STYLE_NORMAL, R.style.You_Dialog );
これは、<API 11のサポートでうまくいきました。
フルスクリーンで背景が透明なスタイルを作成します。
<style name="TransparentDialog" parent="@Android:style/Theme">
<item name="Android:windowBackground">@Android:color/transparent</item>
<item name="Android:background">@Android:color/transparent</item>
</style>
次に、DialogFragmentコード:
public class MyDialog extends DialogFragment {
public static MyDialog newInstance() {
MyDialog dialog = new MyDialog();
dialog.setStyle(DialogFragment.STYLE_NO_FRAME, R.style.TransparentDialog);
return dialog;
}
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
View view = inflater.inflate(R.layout.my_custom_layout, container, false);
return view;
}
}
最後に、わかりやすくするために、my_custom_layout.xmlのコンテンツ:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:Android="http://schemas.Android.com/apk/res/Android"
xmlns:app="http://schemas.Android.com/apk/res/com.kabx"
Android:layout_width="match_parent"
Android:layout_height="match_parent"
Android:background="@color/semi_transparent_grey" >
..........................
..Whatever You Want Here..
..........................
</RelativeLayout>
前に問題に遭遇しました。フルスクリーンを設定している間は常にパディングがあります。 dialogFragmentのonActivityCreated()メソッドで次のコードを試してください。
public void onActivityCreated(Bundle savedInstanceState)
{
Window window = getDialog().getWindow();
LayoutParams attributes = window.getAttributes();
//must setBackgroundDrawable(TRANSPARENT) in onActivityCreated()
window.setBackgroundDrawable(new ColorDrawable(Color.TRANSPARENT));
if (needFullScreen)
{
window.setLayout(LayoutParams.MATCH_PARENT, LayoutParams.MATCH_PARENT);
}
}
最初に、Dialogフラグメントの全画面の処理が通常のDialogコンポーネントと異なることを知っておく必要があります。次に、「user3244180」の回答に従って、ダイアログ@(OnCreateDialog)の実際の作成前にDialogフラグメントをカスタマイズする必要があります- フルスクリーンDialogFragment
@Override
public Dialog onCreateDialog(final Bundle savedInstanceState) {
// the content
final RelativeLayout root = new RelativeLayout(getActivity());
root.setLayoutParams(new ViewGroup.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT));
// creating the fullscreen dialog
final Dialog dialog = new Dialog(getActivity());
dialog.requestWindowFeature(Window.FEATURE_NO_TITLE);
dialog.setContentView(root);
dialog.getWindow().setBackgroundDrawable(new ColorDrawable(Color.TRANSPARENT));
dialog.getWindow().setLayout(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT);
return dialog;
}
DialogFragment(明示的に指定されていない場合)は、カスタムレイアウトをラップする内部スタイルを使用します(フルスクリーンなしなど)。
この問題に対してカスタムテーマを作成する必要はありません。この方法を使用して、選択したスタイルとテーマを設定するだけです:
/* theme is optional, I am using leanback... */
setStyle(STYLE_NORMAL, R.style.AppTheme_Leanback);
<style name="WideDialog" parent="Theme.AppCompat.Light.DialogWhenLarge">
<item name="Android:windowNoTitle">true</item>
<item name="Android:windowFullscreen">false</item>
<item name="Android:windowIsFloating">false</item>
</style>
@Override
public void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setStyle(DialogFragment.STYLE_NORMAL, R.style.WideDialog);
}
以下は私にとって完璧に機能します。フル幅のダイアログ(パディングなしで画面の幅を埋める)を使用できますが、高さはwrap_contentで、ビルダーで行っている他のすべてのスタイリングが保持されます。
<style name="DialogTheme">
<item name="windowMinWidthMajor">100%</item>
<item name="windowMinWidthMinor">100%</item>
<item name="Android:windowBackground">@null</item>
<item name="Android:windowIsFloating">true</item>
<item name="Android:background">#ffffff</item>
</style>
背景が必要であるか、奇妙な繰り返しを行いますが、これをダイアログの背景にしたい色に設定してください。サイズを正しくラップするには、WindowBackgroundとWindowIsFloatingが必要です。
次のようにテーマをビルダーに追加します。
builder = new AlertDialog.Builder(_context, R.style.DialogTheme);
そしてあなたは行ってもいいです!
Nexus 6pとPixelのDialogFragmentで大きなサイドパディングを取得していました。
次のようにカスタムスタイルを定義することでそれを修正しました。
<style name="Custom.Dialog" parent="Android:Theme.DeviceDefault.Dialog.NoActionBar.MinWidth" >
<item name="Android:windowBackground">@null</item>
<item name="Android:windowIsFloating">true</item>
</style>
parent = "Android:Theme.DeviceDefault.Dialog.NoActionBar.MinWidthトリックを行いました