안드로이드 프로그래밍[Kotiln Code]/뷰페이저

[안드로이드 Kotiln 코틀린] 뷰페이저-1

훈츠 2020. 6. 3. 18:46
반응형

 

 

 

안녕하세요. 훈츠입니다. 금일은 뷰페이저 만들기에 관해 포스팅 합니다.

뷰페이저2 는 이 글에서 설명하고 있지 않습니다. 간단한 실습 코드를 통해 뷰페이저에 대해 익힐수 있도록 준비했습니다.

 

목 차 

  1. 뷰페이저 구성

  2. 탭 레이아웃 구성 

  3. 뷰페이저 선택 화면 이동하기 

  4. 뷰페이저 터치 및 스크롤 방지 

  5. 뷰페이저 전체 코드

  6. 뷰페이저 동작 화면 

  7. 뷰페이저 코드 공유 


뷰페이저 구성 

뷰페이저를 구성할 화면에 ViewPager 를 구성 합니다. 

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
//Hoons Blog---https://rain2002kr.tistory.com------------------------------------------------------------------코드///
 
<androidx.constraintlayout.widget.ConstraintLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="match_parent">
 
    <androidx.viewpager.widget.ViewPager
        android:id="@+id/pager"
        android:layout_width="match_parent"
        android:layout_height="0dp"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        app:layout_constraintVertical_bias="0.85">
 
    </androidx.viewpager.widget.ViewPager>
 
 
</androidx.constraintlayout.widget.ConstraintLayout>
cs

탭 레이아웃 구성 

뷰페이저 밑에 추가로 탭 레이아웃을 구성 합니다. 

 

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
//Hoons Blog---https://rain2002kr.tistory.com------------------------------------------------------------------코드///
 
<androidx.constraintlayout.widget.ConstraintLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="match_parent">
 
    <androidx.viewpager.widget.ViewPager
        android:id="@+id/pager"
        android:layout_width="match_parent"
        android:layout_height="0dp"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        app:layout_constraintVertical_bias="0.85">
 
        <com.google.android.material.tabs.TabLayout
            android:id="@+id/tab_layout"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            app:tabIndicatorColor="#FF0000"
            app:tabMode="scrollable"
            app:tabSelectedTextColor="#FF0000" />
 
 
    </androidx.viewpager.widget.ViewPager>
 
 
</androidx.constraintlayout.widget.ConstraintLayout>
cs

뷰페이저 선택화면 이동 

시작 화면을 지정하는 방법입니다. 다음 펑션을 구성하면 원하는 화면을 스타트 화면으로 지정 가능 합니다.

 

1
2
3
4
5
6
//Hoons Blog---https://rain2002kr.tistory.com------------------------------------------------------------------코드///
 
 
//TODO 뷰페이저 시작 페이지 설정 
//pager 는 ViewPager 의 id 입니다. 
pager.setCurrentItem(startFragment)
cs

 


뷰페이저 터치 및 스크롤 방지 

뷰페이저 화면에서 터치 및 스크롤 방지 하는 방법 입니다. 다음 펑션을 이용하면 가능 합니다. 

 

1
2
3
4
5
6
7
8
9
10
11
12
13
//Hoons Blog---https://rain2002kr.tistory.com------------------------------------------------------------------코드///
 
 
//TODO 뷰페이저 시작 페이지 설정 
//pager 는 ViewPager 의 id 입니다. 
pager.setOnTouchListener(object : View.OnTouchListener {
                    override fun onTouch(v: View?, event: MotionEvent?): Boolean {
                        return true
                    }
})
 
 
 
cs

뷰페이저 화면 전체 코드 

다음 코드를 보시면 이해 하시는데 도움이 됩니다. 

 

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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
//Hoons Blog---https://rain2002kr.tistory.com------------------------------------------------------------------코드///
 
 
 
class FragMain : Fragment() {
    val listName = mutableListOf<String>(
        "main","frag1","frag2","frag3"
    )
 
    override fun onCreateView(inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle?): View? {
        val view = inflater.inflate(R.layout.fragmain , container, false)
        return view
    }
 
    override fun onActivityCreated(savedInstanceState: Bundle?) {
        super.onActivityCreated(savedInstanceState)
        init(0)
        val uc = UC()
        val TAG = "FragMain"
 
        //TODO 페이지의 스크롤을 안먹게 만드는 코드
        pager.addOnPageChangeListener(object : ViewPager.OnPageChangeListener{
            override fun onPageScrollStateChanged(state: Int) { }
            override fun onPageScrolled(position: Int,positionOffset: Float,positionOffsetPixels: Int) { }
            override fun onPageSelected(position: Int) {
                Log.d(TAG,"페이지번호${pager.currentItem}")
                val page = pager.currentItem
                if(page == 0 ){
                    uc.pagerDisable(true)
                } else {
                    uc.pagerDisable(false)
                }
            }
        })
    }
 
    fun init(startFragment :Int) {
        pager.setOffscreenPageLimit(10)
        val adapter = Pager1Adapter((activity as MainActivity).supportFragmentManager, listName)
 
        //TODO 추가 메뉴 구성해야함. 어뎁터에 프래그 담기
        val listFrag = listOf<Fragment>(
            Fragmenu(),Frag1(),Frag2(),Frag3()
        )
        //TODO Pager 어뎁터에 담을 프래그먼트 추가
        listFrag.forEach {
            adapter.addItem(it)
        }
 
        //TODO 탭 레이아웃 설정
        tab_layout.setupWithViewPager(pager)
        pager.adapter = adapter
 
        //TODO 뷰페이저 시작 페이지 설정
        pager.setCurrentItem(startFragment)
    }
    inner class UC {
        fun pagerDisable(sw : Boolean){
            if(sw){
                pager.setOnTouchListener(object : View.OnTouchListener {
                    override fun onTouch(v: View?, event: MotionEvent?): Boolean {
                        return true
                    }
                })
                tab_layout.setVisibility(View.INVISIBLE)
            }
            else {
                pager.setOnTouchListener(object : View.OnTouchListener {
                    override fun onTouch(v: View?, event: MotionEvent?): Boolean {
                        return false
                    }
                })
                tab_layout.setVisibility(View.VISIBLE)
            }
        }
    }
}
 
 
 
 
 
 
cs

뷰페이저 동작 화면

 

youtu.be/WmAR3GKEbI0

 

 


코드 공유 

github.com/rain2002kr/ViewPagerExam1.git

 

rain2002kr/ViewPagerExam1

뷰페이저 예제입니다. Contribute to rain2002kr/ViewPagerExam1 development by creating an account on GitHub.

github.com

 

 

 

반응형