我试图实现一个SlidingDrawer
将占据全屏宽度,但其高度是由其内容动态确定的:换言之,标准的fill_parent
布局行为的宽度和wrap_content
的高度。这正是我在布局XML中指定的方式(请参见下文),但滑动抽屉始终打开到全屏高度。我的内容高度各不相同,但通常只有屏幕高度的一半左右,所以我最终会在它下面留下很大的空隙。我想要的内容是整齐地坐在屏幕的底部。Android:可以使用wrap_content设置SlidingDrawer的高度吗?
我试过了所有我能想到的解决方法,但目前为止没有任何工作。如果我将SlidingDrawer
的layout_height
设置为一个特定值(例如160dip
),它可以工作,但这不是我所需要的:它必须是动态的。当然,我已确保所有子元素的高度都设置为wrap_content
。
SlidingDrawer上的文档有点含糊其词,我还没有找到任何能够做我后来做的事情的例子。如果任何人都能看到我要出错的地方,我会非常感谢你的帮助!
<RelativeLayout
android:layout_width="fill_parent"
android:layout_height="fill_parent" >
<ViewFlipper
android:id="@+id/ImageFlipper"
android:layout_width="fill_parent"
android:layout_height="fill_parent" >
<ImageView
android:id="@+id/imageView0"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:scaleType="centerCrop" />
<ImageView
android:id="@+id/imageView1"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:scaleType="centerCrop" />
<ImageView
android:id="@+id/imageView2"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:scaleType="centerCrop" />
</ViewFlipper>
<SlidingDrawer
android:id="@+id/infoDrawer"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:handle="@+id/infoDrawerHandle"
android:content="@+id/infoDrawerContent"
android:allowSingleTap="false"
android:layout_alignParentBottom="true"
android:orientation="vertical" >
<!-- Sliding drawer handle -->
<ImageView
android:id="@id/infoDrawerHandle"
android:src="@drawable/info_handle_closed"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
<!-- Sliding drawer content: a scroller containing a group of text views
laid out in a LinearLayout -->
<ScrollView
android:id="@id/infoDrawerContent"
android:background="@drawable/info_background"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:fillViewport="false" >
<LinearLayout
android:id="@id/infoDrawerContent"
android:orientation="vertical"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:paddingRight="5dip" >
<TextView
android:id="@+id/infoTitle"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textColor="#ffffff"
android:textSize="16dip"
android:textStyle="bold" />
<TextView
android:id="@+id/infoCreator"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textColor="#ffffff"
android:textSize="14dip"
android:textStyle="italic"
android:paddingBottom="10dip" />
<TextView
android:id="@+id/infoDescription"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textColor="#ffffff"
android:textSize="14dip"
android:paddingBottom="10dip" />
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textColor="#ffcc00"
android:textSize="14dip"
android:textStyle="bold"
android:text="@string/heading_pro_tip" />
<TextView
android:id="@+id/infoProTip"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textColor="#ffcc00"
android:textSize="14dip" />
</LinearLayout>
</ScrollView>
</SlidingDrawer>
</RelativeLayout>
好东西!这个滑动抽屉问题让我挣扎了好几个星期。非常感谢! – Gratzi 2010-11-25 08:08:46
它的好n帮助了我很多..谢谢:) – Hussain 2011-04-13 09:40:08
奇妙:感谢这样一个详细的答案,并对不起,它花了我很长的时间来接受它! – 2011-08-04 09:54:48