我有一个有按钮的布局。在图形布局编辑器中,按钮填充宽度并具有 wrap_content 高度,这为文本提供了一些填充(就像通常的按钮一样)。然而,当使用这种布局启动一个活动时,按钮有时会决定将文本紧紧地包裹起来,从而形成一个非常小的细按钮。
当我说有时,我的意思是有时,在我的应用程序中执行完全相同的操作可能会也可能不会产生这个结果。
我认为这个问题与启动它的活动有关,这是一个带有相机预览的活动。像其他人所做的那样,这个应用程序使用带有垂直组件的横向布局,以使其在纵向握住手机时看起来正确(我知道它一团糟,但我们希望支持 api7)。
因此,我的有问题的活动/布局是从此启动的cameraActivity
,并且在此过程中,方向发生了变化。我相信这是问题的根源。
有按钮布局:
<Button android:id="@+id/ContinueBtn"
android:text="@string/btn_continue"
style="@style/main_button"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:layout_centerHorizontal="true"
android:typeface="normal"
android:onClick="onButtonAction"
android:background="@drawable/button_animated" >
</Button>
作为参考,在设置包含此按钮的布局之前,活动将自身设置为纵向。
总而言之,有时我会得到一个又薄又宽的按钮。其他时候我得到一个正常、健康、不挨饿的按钮。我相信这是由于屏幕方向发生了变化——随着方向的变化,布局引擎有时会设法错过按钮的默认填充。我的问题首先是,这是什么原因造成的?我对吗?其次:我该如何防止这种情况?
我还应该补充一点,我认为这与我的图像自定义背景有关 - 我无法使用默认按钮实现它。
此外,这里有一些问题的图像: EDIT2:所以,在下面的评论中提出了一些解决方案。但谁能解释为什么这种效果如此不一致?有某种比赛条件吗?