반응형
250x250
Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 카이스트맛집
- computergraphics
- glfw
- node.js
- 위상정렬
- 프래그먼트
- html
- DP
- 알고리즘
- 대전맛집
- 안드로이드스튜디오
- 프로그래머스
- 타입스크립트
- 우선순위큐
- 카이스트
- 분리집합
- 자바
- 몰입캠프
- 앱개발
- 백준
- MySQL
- 리사이클러뷰
- nodeJS
- 자바스크립트
- 몰입캠프후기
- 후기
- 어은동맛집
- BFS
- 궁동
- 컴퓨터그래픽스
Archives
- Today
- Total
소근소근
TabLayout , ViewPager2 , fragment로 탭 구조 구현하기 [AndroidStudio-JAVA] 본문
AndroidStudio
TabLayout , ViewPager2 , fragment로 탭 구조 구현하기 [AndroidStudio-JAVA]
JJureng 2021. 7. 5. 13:32728x90
반응형
SMALL
세개의 탭으로 이루어진 앱 화면을 구현해보았다.
activity_main.xml 코드
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@color/white">
<com.google.android.material.tabs.TabLayout
android:id="@+id/tablayout_control"
app:layout_constraintTop_toTopOf="parent"
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:tabIndicatorColor="@color/black"
app:tabSelectedTextColor="@color/black"
app:tabTextColor="@color/black">
<com.google.android.material.tabs.TabItem
android:id="@+id/tab1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="phone" />
<com.google.android.material.tabs.TabItem
android:id="@+id/tab2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="gallery" />
<com.google.android.material.tabs.TabItem
android:id="@+id/tab3"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="morse" />
</com.google.android.material.tabs.TabLayout>
<androidx.viewpager2.widget.ViewPager2
android:id="@+id/viewpager_control"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintTop_toBottomOf="@id/tablayout_control"
android:layout_width="match_parent"
android:layout_height="0dp" />
</androidx.constraintlayout.widget.ConstraintLayout>
MainActivity.java 코드
public class MainActivity extends AppCompatActivity {
private ViewPager2 viewPager;
private PagerAdapter pagerAdapter;
private frag1_class frag1;
private frag2_class frag2;
private frag3_class frag3;
private TabLayout tabLayout;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
createFragment();
createViewpager();
settingTabLayout();
}
private void createFragment() {
frag1 = new frag1_class();
frag2 = new frag2_class();
frag3 = new frag3_class();
}
private void createViewpager(){
viewPager = (ViewPager2)findViewById(R.id.viewpager_control);
pagerAdapter = new PagerAdapter(getSupportFragmentManager(), getLifecycle());
pagerAdapter.addFragment(frag1);
pagerAdapter.addFragment(frag2);
pagerAdapter.addFragment(frag3);
viewPager.setAdapter(pagerAdapter);
viewPager.setUserInputEnabled(false); //이 줄을 주석처리 하면 슬라이딩으로 탭을 바꿀 수 있다
}
private void settingTabLayout(){
tabLayout = (TabLayout)findViewById(R.id.tablayout_control);
tabLayout.addOnTabSelectedListener(new TabLayout.OnTabSelectedListener() {
@Override
public void onTabSelected(TabLayout.Tab tab) {
int pos = tab.getPosition();
switch(pos){
case 0:
viewPager.setCurrentItem(0);
break;
case 1:
viewPager.setCurrentItem(1);
break;
case 2:
viewPager.setCurrentItem(2);
break;
}
}
@Override
public void onTabUnselected(TabLayout.Tab tab) {
}
@Override
public void onTabReselected(TabLayout.Tab tab) {
}
});
}
}
각 3개의 프래그먼트는 Fragment 를 상속받은 클래스를 정의해주면 된다.(예 : 위 코드에서 frag1_class)
viewPager를 구현하기 위해서는 페이지 adapter도 필요하다.
public class PagerAdapter extends FragmentStateAdapter{
private final List<Fragment> mFragmentList = new ArrayList<>();
public PagerAdapter(@NonNull FragmentManager fragmentManager, @NonNull Lifecycle lifecycle) {
super(fragmentManager, lifecycle);
}
public void addFragment(Fragment fragment){
mFragmentList.add(fragment);
}
@NonNull
@Override
public Fragment createFragment(int position) {
return mFragmentList.get(position);
}
@Override
public int getItemCount() {
return mFragmentList.size();
}
}
완성된 화면은 상단에 각 탭의 이름이 나오고, 클릭하면 탭이 이동한다.
728x90
반응형
LIST
'AndroidStudio' 카테고리의 다른 글
안드로이드 스튜디오 일정시간 카메라 플래시 켜고 끄기 [AndroidStudio-JAVA] (0) | 2021.07.05 |
---|---|
EditText 입력 시 키보드 화면 밀림 현상 해결[AndroidStudio-JAVA] (0) | 2021.07.05 |
휴대폰 주소록 사진 불러오기(비트맵Bitmap, ImageView) [AndroidStudio-JAVA] (0) | 2021.07.05 |
이미지뷰(ImageView) 안보이는 현상 해결[AndroidStudio-JAVA] (0) | 2021.07.05 |
리사이클러뷰(RecyclerView)에서 클릭(click)이벤트 처리[AndroidStudio-JAVA] (0) | 2021.07.04 |