안녕하세요.
아래의 뷰페이저 관련해서 궁금한 점이 있어서 글을 올렸습니다.
짧게 구성이 되어 있는 뷰페이저인데, 제가 이부분에 관련해서, 확실하게 구조에 알지 못해서,
다들 시간이 없으시고 바쁘시겠지만 한번 설명을 좀 듣고 싶어서, 이렇게 글을 썼습니다.
제가 풀이해본 결과는 아래와 같습니다.
int를 저장하는 ArrayList인 at_thumnail 을 만들고 String을 저장하는ArrayList인 at_title을 만듭니다.
그리고 xml에서 선언한 뷰페이저를 이어주는 mViewPager을 만들고 위쪽에 SectionPagerAdapter 변수인
mSectionPagerAdapter을 선언했습니다.
mSectionPagerAdapter을 선언한 이유는 mSectionPagerAdapter가 프래그넌트매니저를 상속을 받고, 여기서 키와 값을
PlaceHolderFragment로 넘김으로써 각 이미지들과 텍스트들에 번호를 부여하고, 그렇게 반환된 Fragment를 다시
SectionPagerAdapter로 가게 되며 뷰페이저에 셋어댑터를 통해 (mSectionPagerAdapter)가 되어서 화면에
나타나게 됩니다..
좀 많이 횡설수설 하는데.. 이렇게 구성된 뷰페이저를 좀 제데로 이해를 해보고 싶어서 그러는데 설명한번만
깊게 해주시면 정말 감사드리겠습니다. 
import java.util.ArrayList;
public class Movie_ViewPager extends AppCompatActivity {
private SectionsPagerAdapter mSectionsPagerAdapter;
public static ArrayList<Integer> at_thumnail = new ArrayList<>();
public static ArrayList<String> at_title = new ArrayList<>();
private ViewPager mViewPager;
static String ARG_SECTION_NUMBER = "section_number";
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
super.setTitle("로그인화면 ");
setContentView(R.layout.activity_movie_viewpager);
// 여기같은 경우에는, 뷰페이저에 나타나는 사진임 ..
at_thumnail.add(R.drawable.first_moive_image);
at_thumnail.add(R.drawable.second_movie_image);
at_thumnail.add(R.drawable.third_movie_image);
at_title.add("1. 1번내용");
at_title.add("2. 2번내용");
at_title.add("3. 3번내용");
mSectionsPagerAdapter = new SectionsPagerAdapter(getSupportFragmentManager());
mViewPager = (ViewPager) findViewById(R.id.container);
mViewPager.setAdapter(mSectionsPagerAdapter);
}
public static class PlaceholderFragment extends Fragment {
public PlaceholderFragment() {
}
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
final int position = getArguments().getInt(ARG_SECTION_NUMBER);
// 레이아웃을 객체화시킴.
View rootView = inflater.inflate(R.layout.fragment_sub2, container, false);
TextView title = (TextView) rootView.findViewById(R.id.title);
title.setText(at_title.get(position));
TextView Percent = (TextView) rootView.findViewById(R.id.Reservation_Percent);
Percent.setText(at_ReservationPercent.get(position));
ImageView thunmail = (ImageView) rootView.findViewById(R.id.thunmail);
thunmail.setImageResource(at_thumnail.get(position));
Button btn = (Button) rootView.findViewById(R.id.buy);
thunmail.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
Intent intent = new Intent(getContext(),Movie_Information.class);
intent.putExtra("pos",position); //int타입의 데이터를 전달한다.
startActivity(intent);
}
});
return rootView;
}
}
public class SectionsPagerAdapter extends FragmentPagerAdapter {
public SectionsPagerAdapter(FragmentManager fm) {
super(fm);
}
// 번들 : 객체를 저장할수 있는것
// getItem : 페이지를 생성할때
@Override
public Fragment getItem(int position) {
Bundle args = new Bundle(); // 번들 생성
args.putInt(ARG_SECTION_NUMBER, position);
//프래그먼트를 생성
PlaceholderFragment fragment = new PlaceholderFragment();
fragment.setArguments(args);
return fragment; // 객체가 반환되는순간.
}
@Override
public int getCount() {
return 3;
}
}
}