この方法を使用すると、ヘッダー フッター xml を作成し、それを任意のアクティビティに使用できます。また、HeaderFooter.java で一度ヘッダー フッターのコントロールのコードを記述するだけで、プロジェクトにアクセスできます。
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/commonlayout"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:background="#FFFFFF"
android:orientation="vertical"
android:weightSum="10" >
<LinearLayout
android:id="@+id/llheader"
android:layout_width="fill_parent"
android:layout_height="0dp"
android:layout_weight="1" >
<RelativeLayout
android:id="@+id/relativeLayout1"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:layout_gravity="center" >
<Button
android:id="@+id/Button_HeaderFooterSubscribe"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentRight="true"
android:layout_centerVertical="true"
android:layout_marginRight="2dp" />
<Button
android:id="@+id/Button_logout"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentRight="true"
android:layout_centerVertical="true"
android:layout_marginRight="2dp" />
<Button
android:id="@+id/Button_playlist"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_centerVertical="true"
android:layout_marginLeft="2dp" />
</RelativeLayout>
</LinearLayout>
<LinearLayout
android:id="@+id/lldata"
android:layout_width="fill_parent"
android:layout_height="0dp"
android:layout_weight="8"
android:background="#FFFFFF" >
</LinearLayout>
<LinearLayout
android:id="@+id/llfooter"
android:layout_width="fill_parent"
android:layout_height="0dp"
android:layout_margin="0dp"
android:layout_weight="1"
android:gravity="center"
android:orientation="horizontal"
android:visibility="visible"
android:weightSum="5.0" >
<Button
android:id="@+id/home"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="1"
android:background="@drawable/home"
android:padding="10px"
android:textColor="#FFFFFF" >
</Button>
<Button
android:id="@+id/issue"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="1"
android:padding="10px"
android:textColor="#FFFFFF" >
</Button>
<Button
android:id="@+id/browse"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="1"
android:padding="10px"
android:textColor="#FFFFFF" >
</Button>
<Button
android:id="@+id/search"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="1"
android:padding="10px"
android:textColor="#FFFFFF" >
</Button>
<Button
android:id="@+id/favorite"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="1"
android:padding="10px"
android:textColor="#FFFFFF" >
</Button>
</LinearLayout>
</LinearLayout>
次に、1 つの HeaderFooter.java アクティビティを作成します。
public class HeaderFooter extends Activity {
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.headerfooter);
}
}
上記のアクティビティを他のすべてのアクティビティに拡張し、headerfooter.xml の中央のレイアウトで特定のビューを膨らませます
public class Home extends HeaderFooter
{
@Override
public void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
ViewGroup vg = (ViewGroup) findViewById(R.id.lldata);
ViewGroup.inflate(Home.this, R.layout.home, vg);
}
}