4

我正在尝试创建一个布局(使用 eclipse),我需要在其中垂直对齐各种控件,如 TextView 和 Button。我试图保持所有小部件完全左对齐。即使我为控件指定了相同的左边距/填充,在不同类型的控件之间仍然可以看到 1-2 个像素的差异。

问题是小部件的边框(日食中的蓝色矩形)和小部件的内容/图形之间的距离因小部件(例如 TextView 和 Button)而异。

我可以通过为 TextView 指定左填充或通过减少按钮容器的左边距来应用变通方法。但我正在寻找更清洁的解决方案。我找不到任何控制小部件边框和内容之间差异的属性。关于如何控制这个差距的任何指示?

演示问题的快照如下。这是我用于解决此问题的布局 XML:-

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:orientation="vertical" >

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Hello World" />

    <Button
        android:id="@+id/button1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Dummy Button" />

</LinearLayout>

下图显示了虚拟应用程序的快照。请注意“Hello World”TextView 和“Dummy Button”的左侧边距之间的区别。

第二张图片显示了在 Eclipse 中选择时的按钮小部件。蓝色矩形表示小部件边界/边框。按钮的边框(蓝色矩形)和内容(灰色矩形)之间的区别是否可以通过某些属性来控制?

虚拟应用程序快照 带边界的按钮

4

1 回答 1

2

这是一个难点,TextView 和其他 Android 小部件可能有自己的一些内在风格(也取决于 Android 版本)。

因此,要解决这个问题,您必须创建自己的风格。

在创建自己的样式时,请始终参考有关此主题的 android 源代码:

https://github.com/android/platform_frameworks_base/tree/master/core/res/res/values

https://github.com/android/platform_frameworks_base/blob/master/core/res/res/values/themes.xml

https://github.com/android/platform_frameworks_base/blob/master/core/res/res/values/styles.xml

有多种方法可以创建自己的风格。

一种方法是在清单中为您的活动设置主题。首先,您需要一个位于 /values/ 文件夹中的 styles.xml 文件。在这里,您将声明您的新样式:

<style name="Theme.MyTheme.Dark" parent="@android:style/Theme.NoTitleBar">
    <item name="android:textViewStyle">@style/Widget.TextView.Black</item>
</style>

<style name="Theme.MyTheme.Light" parent="@android:style/Theme.NoTitleBar">
    <item name="android:textViewStyle">@style/Widget.TextView.White</item>
</style>

它上面的样式继承自隐藏标题栏的Android样式,您可以从其他东西继承。在这个主题中,我们然后覆盖 textViewStyle,这允许我们为我们TextView的 's 设置自定义值并覆盖一些内在值。

<style name="Widget.TextView.White" parent="@android:style/Widget.TextView">
    <item name="android:textColor">#FFFFFF</item>
</style>

<style name="Widget.TextView.Black" parent="@android:style/Widget.TextView">
    <item name="android:textColor">#000000</item>
</style>

最后,您在 AndroidManifest.xml 中为您的活动设置主题:

     <activity
        android:name=".ui.phone.FirstActivity"
        android:theme="@style/Theme.MyTheme.Dark" />

     <activity
        android:name=".ui.phone.SecondActivity"
        android:theme="@style/Theme.MyTheme.Light" />

现在,当您在 FirstActivity 中使用 TextView 时,默认情况下它的文本是黑色的,而在第二个活动中它将是白色的。

对于您的具体问题:

您必须查看我在顶部链接的源代码文件,看看是否有任何填充或 minWidth 或 size 属性影响您的小部件和布局。

于 2012-05-29T12:17:39.883 回答