gpt4 book ai didi

Android:对话框最小边距

转载 作者:塔克拉玛干 更新时间:2023-11-02 08:30:42 25 4
gpt4 key购买 nike

我使用 android android.app.Dialog 创建自定义对话框(用于按钮和背景)在我的对话框中,我在 ScrollView 中有一个 TextView,而我有一个简短的文本,这完美地显示了我想要的方式,但如果文本非常大,我的 Dialog 会占据全屏我希望对话框和屏幕边缘之间的边距最小。

我的问题是我希望对话框不要比需要的大,而且我不能为此设置固定大小?

这是今天的样子.....我有这样的边距

How my Dialog is now. I want a margin like this.


GameDialog.java

public class GameDialog extends Dialog {

public GameDialog(Context ct, int titleID, int messageID) {
super(ct, R.style.dialog_style);
this.setContentView(R.layout.dialog_layout);

}
// This exist more code but this has noting with the layout to do,only set the text and show the button that exist since the XML file.

}

R.style.dialog_style

<style name="dialog_style" parent="@android:style/Theme.Dialog">
<item name="android:windowBackground">?button_image</item>
<item name="android:windowNoTitle">true</item>
<item name="android:textColor">#FF000000</item>
<item name="android:textSize">20sp</item>
</style>

R.layout.dialog_layout

<?xml version="1.0" encoding="utf-8"?>


<!-- Dialog layout that show title and a textarea, and under this allow a row of button that is center layout. -->
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="wrap_content">

<LinearLayout android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_marginLeft="14px"
android:layout_marginRight="14px">


<TextView
android:layout_gravity="center_vertical"
android:id="@+id/text_title"
android:layout_width="fill_parent"
android:layout_height="wrap_content">
</TextView>

</LinearLayout>

<LinearLayout android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="0px"
android:layout_weight="1"
android:layout_marginLeft="14px"
android:layout_marginRight="14px">

<ScrollView
android:layout_width="fill_parent"
android:layout_height="fill_parent"
>

<TextView android:id="@+id/text_main"
android:padding="5px"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
>
</TextView>

</ScrollView>

</LinearLayout>

<LinearLayout
android:id="@+id/layout_button"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:gravity="center"
android:orientation="horizontal">
<!-- this will be show while need to show a button -->
<ImageView
style="?icon_size.button"
android:visibility="gone"/>
<ImageView
style="?icon_size.button"
android:visibility="gone"/>
<ImageView
style="?icon_size.button"
android:visibility="gone"/>
<ImageView
style="?icon_size.button"
android:visibility="gone"/>
<ImageView
style="?icon_size.button"
android:visibility="gone"/>
</LinearLayout>
</LinearLayout>

最佳答案

框架实际上是在背景图像本身上执行此操作。换句话说,如果您查看为框架定义的主题,它们的 windowBackground属性只是一种清晰的颜色,即:

<item name="android:windowBackground">@android:color/transparent</item>

然后放置在根布局项上的背景图像是一个 9 block 补丁,在所有边上都有内置填充(即图像中内置的额外空间,因此当图像拉伸(stretch)以填满屏幕时您仍然可以看到周围边缘)。查看 AOSP 源代码中的一个面板,了解我的意思 ( link )。

因此,对于您的解决方案,我会推荐两件事:

  1. 使用 windowBackground 修改您的自定义样式如上所述
  2. 更新您的自定义背景图片以包含固有的透明边距

对于第 2 步,如果您的图像当前是 9 补丁,请执行与 Google 相同的操作。如果您使用 XML 创建图像,则可以使用 <layer-list>像下面的示例一样,将可见矩形嵌入另一个带有填充的矩形中:

<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android" >
<item>
<shape android:shape="rectangle" >
<solid android:color="@android:color/transparent" />
<padding
android:bottom="10dp"
android:left="10dp"
android:right="10dp"
android:top="10dp" />
</shape>
</item>
<!-- This shape will be inset by the padding set above -->
<item>
<shape android:shape="rectangle" >
<solid android:color="#262626" />
</shape>
</item>
</layer-list>

在这种情况下,填充不会转移到内容,因此您还需要向根布局项添加填充,以使内容边界与图像显示相匹配。

关于Android:对话框最小边距,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13298617/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com