Inoltre, ecco un demo litte come lo SlideingDrawer viene utilizzato:
/src - SliderActivity.java:
import android.app.Activity;
import android.os.Bundle;
import android.widget.Button;
import android.widget.SlidingDrawer;
import android.widget.SlidingDrawer.OnDrawerCloseListener;
import android.widget.SlidingDrawer.OnDrawerOpenListener;
public class SliderActivity extends Activity {
Button slideHandleButton;
SlidingDrawer slidingDrawer;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
slideHandleButton = (Button) findViewById(R.id.slideHandleButton);
slidingDrawer = (SlidingDrawer) findViewById(R.id.SlidingDrawer);
slidingDrawer.setOnDrawerOpenListener(new OnDrawerOpenListener() {
@Override
public void onDrawerOpened() {
slideHandleButton.setBackgroundResource(R.drawable.arrowdown);
}
});
slidingDrawer.setOnDrawerCloseListener(new OnDrawerCloseListener() {
@Override
public void onDrawerClosed() {
slideHandleButton.setBackgroundResource(R.drawable.arrowup);
}
});
}
}
/res/disposizione - main.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout android:id="@+id/LinearLayout01"
android:layout_width="fill_parent" android:layout_height="fill_parent"
xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical" android:gravity="bottom">
<SlidingDrawer android:layout_width="wrap_content"
android:id="@+id/SlidingDrawer" android:handle="@+id/slideHandleButton"
android:content="@+id/contentLayout" android:padding="10dip"
android:layout_height="200dip">
<Button android:layout_width="wrap_content"
android:layout_height="wrap_content" android:id="@+id/slideHandleButton"
android:background="@drawable/arrowup"></Button>
<LinearLayout android:layout_width="wrap_content"
android:id="@+id/contentLayout" android:orientation="vertical"
android:gravity="center|top" android:padding="10dip"
android:background="#505050" android:layout_height="wrap_content">
<TextView android:id="@+id/TextView01" android:layout_width="wrap_content"
android:layout_height="fill_parent" android:layout_weight="8" android:text="Hello Slider"></TextView>
<Button android:id="@+id/Button02" android:layout_weight="2" android:layout_width="wrap_content"
android:layout_height="wrap_content" android:text="Do anything"></Button>
</LinearLayout>
</SlidingDrawer>
</LinearLayout>
Inoltre è necessario immagini nella cartella/res/drawable - in questo caso come arrowup.png
e arrowdown.png
Se metti che tutti insieme si scopre a guardare in quel modo:
Ciao! Grazie mille ... cercherò di aggiungere questo al mio applicaton. – chrisonline
Funziona alla grande, ma come posso sovrapporre il contenuto sopra? Il mio problema è che lo SlidingDrawer si ferma alla fine del mio LinearLayout precedente. Ma dovrei sovrapporre l'intero LinearLayout qui sopra. Come nell'app Facebook. – chrisonline
L'ho trovato. Non aggiungerlo al XML di layout principale. Invece crea un nuovo XML solo con il cassetto scorrevole e aggiungi il seguente codice: LayoutInflater inflater = getLayoutInflater(); Visualizza view = inflater.inflate (R.layout.drawer, null); getWindow(). AddContentView (view, params); – chrisonline