Android FragmentStatePagerAdapterを使ってレイアウトが共通のページを作るサンプルコード
FragmentStatePagerAdapterは便利な機能で、たとえば読ませたいコンテンツがあったとしたら、右、左のフリックで切り替えたり、共通のレイアウトを持たせたりすることができます。
「次へ」ボタンとかを配置したかったり、最後のページは「次へ」がないようにする、などのサンプルコードを書いておきます。
フリックだけだと先に進めない人がいるので、「次へ」ボタンをつけています。
このサンプルは、4ページのチュートリアルです。
ページの上にタイトルバー、中央に中身のコンテンツ、下の方に「次へ」と「スキップ」ボタンが配置されています。
//元になるアクティビティ
//TutorialBeforeStartActivity.java内
public class TutorialBeforeStartActivity extends FragmentActivity {
private ViewPager viewPager;
private Button skip;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.tutorial_before_start_fragment);
viewPager = (ViewPager) findViewById(R.id.pager);
viewPager.setAdapter(
new MyFragmentStatePagerAdapter(getSupportFragmentManager(), this));
ImageView next_button = (ImageView)findViewById(R.id.goto_next);
//「次へ」ボタンをタップすると、次のページへ進む処理
next_button.setOnTouchListener(new OnTouchListener() {
@Override
public boolean onTouch(View arg0, MotionEvent arg1) {
switch (arg1.getAction()) {
case MotionEvent.ACTION_DOWN: {
int current_page_num = viewPager.getCurrentItem();
viewPager.setCurrentItem(current_page_num + 1);
break;
}
}
return true;
}
});
//最後のページだけ、「次へ」ボタンを表示しない処理
viewPager.setOnPageChangeListener(new ViewPager.SimpleOnPageChangeListener() {
@Override
public void onPageSelected(int position) {
ImageView next_button = (ImageView)findViewById(R.id.goto_next);
if(position==3){
next_button.setVisibility(View.INVISIBLE);
}else{
next_button.setVisibility(View.VISIBLE);
}
}
});
skip = (Button) findViewById(R.id.skip);
skip.setOnClickListener(new OnClickListener(){
@Override
public void onClick(View v) {
if (v == skip ) {
//スキップをタップした時の処理
}
}
});
}
//アダプター
//MyFragmentStatePagerAdapter.java内
public class MyFragmentStatePagerAdapter
extends FragmentStatePagerAdapter {
private Context localContext;
public MyFragmentStatePagerAdapter(FragmentManager fm, Context context) {
super(fm);
localContext = context;
}
@Override
public Fragment getItem(int i) {
switch (i) {
case 0:
return new TutorialCreditFragment();
case 1:
return new TutorialGroupFragment();
case 2:
return new TutorialJoinFragment();
case 3:
return new TutorialAdminFragment();
default:
return new TutorialCreditFragment();
}
}
@Override
public int getCount() {
return 4;
}
@Override
public CharSequence getPageTitle(int position) {
// return "Page " + position;
switch (position) {
case 0:
return localContext.getString(R.string.credit_explanation_title);
case 1:
return localContext.getString(R.string.group_explanation_title);
case 2:
return localContext.getString(R.string.join_explanation_title);
case 3:
return localContext.getString(R.string.admin_explanation_title);
default:
return localContext.getString(R.string.tutorial_before);
}
}
}
//個別のフラグメント
//TutorialCreditFragment.java 内
//他のフラグメントも同様な感じなので、省略します。
public class TutorialCreditFragment extends Fragment {
@Override
public View onCreateView(LayoutInflater inflater,
ViewGroup container,
Bundle savedInstanceState) {
View v = inflater.inflate(R.layout.tutorial_credit, null);
return v;
}
}
//レイアウトファイル tutorial_before_start_fragment.xml内 //上にタイトルバーがあり、下に次へボタンとSkipボタンがある構成 <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" > <!-- ページャーのホルダー 個々のページは、フラグメント内 --> <android.support.v4.view.ViewPager xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/pager" android:layout_width="match_parent" android:layout_height="wrap_content" > <android.support.v4.view.PagerTitleStrip android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_gravity="top" android:background="#e38e66" android:padding="10dp" android:textColor="@color/white" android:textSize="14sp" /> </android.support.v4.view.ViewPager> <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_alignParentBottom="true" android:orientation="vertical" > <ImageView android:id="@+id/goto_next" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center" android:layout_margin="5dp" android:contentDescription="@string/swipe_left" android:src="@drawable/goto_next" /> <Button android:id="@+id/skip" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginTop="5dp" android:background="#aaa6a4" android:gravity="bottom|left" android:padding="5dp" android:text="@string/skip" android:textColor="@color/white" android:textSize="12sp" /> </LinearLayout> </RelativeLayout>
//個々のフラグメントのレイアウトファイル //tutorial_credit.xml内 //他のフラグメントも同様なので、省略 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="wrap_content" android:background="#f9eee9" android:gravity="center_horizontal" android:orientation="vertical" android:padding="10dp" android:textColor="#000000" > <LinearLayout android:layout_width="fill_parent" android:layout_height="wrap_content" android:gravity="center_horizontal" android:orientation="vertical" > <TextView android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="@string/step1" android:textColor="#c04208" android:textSize="14sp" /> <ImageView android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginBottom="10dp" android:contentDescription="@string/credit_image" android:gravity="center_horizontal" android:src="@drawable/registration_explanation_credit" /> <TextView android:layout_width="fill_parent" android:layout_height="wrap_content" android:layout_marginBottom="10dp" android:text="@string/credit_explanation_text" android:textColor="@android:color/black" android:textSize="14sp" /> </LinearLayout> </LinearLayout>
