2

我正在尝试设置FragmentDialog4.0 前的样式,使其显示为 4.0 后。

我正在使用ActionBarSherlock,但我必须在冰淇淋三明治之前自己设计它。

我想得到以下外观:

在此处输入图像描述

但我得到了这个:

在此处输入图像描述

所以基本上我希望它不填满整个屏幕。

我尝试了各种样式,但都没有成功,我已经到了希望有一些专家可以帮助我或引导我走向正确方向的地步

我的对话框片段:

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        //TODO Style 2.3 to look like 4.0
        int sdk = android.os.Build.VERSION.SDK_INT;
        if(sdk < android.os.Build.VERSION_CODES.HONEYCOMB) {
            setStyle(DialogFragment.STYLE_NO_TITLE, R.style.Pre_Honeycomb_Holo_Dialog);
        }
    }

    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
            Bundle savedInstanceState) {
        View view = null;
        int sdk = android.os.Build.VERSION.SDK_INT;
        if(sdk < android.os.Build.VERSION_CODES.ICE_CREAM_SANDWICH) {
            view = inflater.inflate(R.layout.info_dialog_view, container);
        } else {
            view = inflater.inflate(R.layout.info_dialog_view_content, container);
            this.getDialog().setTitle(R.string.info_dialog_title);
        }
...

基本上我正在构建冰淇淋三明治之前的标题布局,但内容区域是相同的。

我的 holo_dialog_style:

<?xml version="1.0" encoding="utf-8"?>
<resources xmlns:android="http://schemas.android.com/apk/res/android">
    <style name="Pre.Honeycomb.Holo.Dialog" parent="Theme.Sherlock.Light">
        <item name="android:windowTitleStyle">@null</item>
        <item name="android:windowFrame">@null</item>
        <item name="android:windowBackground">@drawable/panel_bg_holo_light</item>
        <item name="android:windowIsFloating">true</item>
        <item name="android:windowContentOverlay">@null</item>
        <item name="android:windowAnimationStyle">@android:style/Animation.Dialog</item>
        <item name="android:windowSoftInputMode">stateUnspecified|adjustPan</item>
    </style>
</resources>
4

2 回答 2

5

这是图书馆成为您朋友的众多案例之一!

我建议使用Styled Dialogs for Android

它能够生成如下所示的对话框: 示例对话框

要使用它,您需要首先将其添加到 Maven(如果您正在使用它):

<dependency>
    <groupId>eu.inmite.android.lib</groupId>
    <artifactId>android-styled-dialogs</artifactId>
    <version>1.0.1</version>
    <type>apklib</type>
</dependency>

或者如果您使用的是 Ant,那么您可能只想下载最新的 jar

现在,您只需要设置您的主题以使用您想要的主题。将以下内容添加到您的应用程序主题中:

全息灯

<item name="sdlDialogStyle">@style/DialogStyleLight.Custom</item>

全息黑暗

<item name="sdlDialogStyle">@style/DialogStyleDark.Custom</item>

您还可以添加以下样式以允许您根据需要进行自定义:

<style name="DialogStyleLight.Custom">
    <!-- anything can be left out: -->
    <item name="titleTextColor">@color/dialog_title_text</item>
    <item name="titleSeparatorColor">@color/dialog_title_separator</item>
    <item name="messageTextColor">@color/dialog_message_text</item>
    <item name="buttonTextColor">@color/dialog_button_text</item>
    <item name="buttonSeparatorColor">@color/dialog_button_separator</item>
    <item name="buttonBackgroundColorNormal">@color/dialog_button_normal</item>
    <item name="buttonBackgroundColorPressed">@color/dialog_button_pressed</item>
    <item name="buttonBackgroundColorFocused">@color/dialog_button_focused</item>
    <item name="dialogBackground">@drawable/dialog_background</item>
</style>

一旦你有了它,它就很容易使用:

带有简单消息和关闭按钮的对话框

SimpleDialogFragment.createBuilder(this, getSupportFragmentManager()).setMessage(R.string.message).show();

带有标题、消息和关闭按钮的对话框

SimpleDialogFragment.createBuilder(this, getSupportFragmentManager()).setTitle(R.string.title).setMessage(R.string.message).show();

带有标题、消息和两个按钮的对话框

SimpleDialogFragment.createBuilder(this, getSupportFragmentManager()).setTitle(R.string.title).setMessage(R.string.message).setPositiveButtonText(R.string.positive_button).setNegativeButtonText(R.string.negative_button).show();

对于其他示例,还有一些可用的演示

于 2013-10-03T13:18:37.663 回答
2

为避免填满整个屏幕,您可以在 DialogFragment 的 onStart 方法上使用此代码:

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

    // safety check
    if (getDialog() == null)
        return;

    getDialog().getWindow().setLayout(width, height);

}

在getDialog().getWindow().setLayout(width, height);中以编程方式设置所需的宽度和高度 方法。

然后在您正在膨胀的 xml 布局文件(R.layout.info_dialog_view)中设置宽度和高度以匹配父级。

于 2013-10-04T21:03:03.357 回答