RelativeLayout
これは、とSlidingDrawer
ウィジェットを使用して簡単に実装できます。
- 引き出しをレイアウトの下部に取り付けて、写真の
RelativeLayout
上で開くことができるようにするために必要です。
SlidingDrawer
ウィジェットには と の2 つの必須プロパティがandroid:handle
ありandroid:content
ます。きれいなレイアウトの場合、おそらくこれらを別のレイアウト ファイルとして使用することをお勧めします。以下の例では簡単にするために、同じ XML レイアウトに含まれています。
- 背景の不透明度は単純
android:background
です。プロパティを ARGB (アルファ RGB) 値として渡すだけです。以下は、約75%の不透明度で黒の「#BF000000」を使用しています。
- 最後のステップは、ハンドルを非表示にして、イベント ハンドラーを および に追加すること
ImageView
ですSlidingDrawer
。
キックのために、ここに完全に機能する例があります...
レイアウト XML:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
>
<ImageView android:id="@+id/image"
android:src="@drawable/bunnywaffles"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:layout_alignParentTop="true"
/>
<SlidingDrawer android:id="@+id/SlidingDrawer"
android:handle="@+id/slideHandleButton"
android:content="@+id/contentLayout"
android:layout_width="fill_parent"
android:layout_height="150dip"
android:layout_alignParentBottom="true" >
<Button android:id="@+id/slideHandleButton"
android:layout_width="0dip"
android:layout_height="0dip"
android:visibility="gone"
/>
<LinearLayout android:id="@+id/contentLayout"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:orientation="vertical"
android:gravity="center"
android:background="#BF000000">
<LinearLayout android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:gravity="center">
<Button android:id="@+id/Button01"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Button1"
/>
<Button android:id="@+id/Button02"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Button2"
/>
</LinearLayout>
<RatingBar android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:numStars="5" />
</LinearLayout>
</SlidingDrawer>
</RelativeLayout>
そしてあなたの活動 Java:
ImageView _image;
SlidingDrawer _drawer;
Boolean _drawerOpen = false;
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
_image = (ImageView) findViewById( R.id.image );
_image.setOnClickListener(ToggleDrawer);
_drawer = (SlidingDrawer) findViewById( R.id.SlidingDrawer );
_drawer.setOnClickListener(ToggleDrawer);
}
private View.OnClickListener ToggleDrawer = new View.OnClickListener() {
public void onClick(View view) {
if ( _drawerOpen )
_drawer.animateClose();
else
_drawer.animateOpen();
_drawerOpen = !_drawerOpen;
}
};