728x90
반응형

Fragment는 Activity의 파트를 나눈것들이다. Activity가 너무 길어지면 관리 포인트가 많아 관리가 어려워지기 때문에 Fragment를 사용해서 나누어 해결한다. Activity가 라이프사이클이 있는 것처럼 Fragment도 라이프사이클이 있다. 

 

Fragment 사용방법
1. XML에 ViewComponent로 추가한다
2. 코드로(동적)으로 추가한다

 

Fragment를 만들기 위해서 class를 만들어 fragment()를 상속받아 준다. (Activity 만들때는 AppCompatActivity()를 상속받은 것처럼)

class FragmentOne:Fragment()

override method를 통해서 onAttach(), onCreate(), onCreateView(), onViewCreated(), onActivityCreated(), onStart(), onResume(), onPause(), onStop(), onDestroyView(), onDetach()를 만들어주었다.

 

xml에서 Fragment를 사용해서 넣어주면 된다.

<fragment
        android:id="@+id/fragment_one"
        android:name="com.example.myapplication.FragmentOne"
        android:layout_width="match_parent"
        android:layout_height="300dp"/>

id와 name을 꼭 넣어주어야 한다. name은 fragment태그에 들어갈 내용을 의미한다. FragmentOne 클래스를 넣어준다.

FragmentOne에서 List를 그려야 한다. LifeCycle중에서 onCreateView()를 이용해서 그린다. onCreateView()는 fragment가 interface를 처음으로 그릴때 호출된다. Activity는 setContentView가 책임졌다면 fragment는 onCreateView()가 책임진다.

override fun onCreateView(
        inflater: LayoutInflater,
        container: ViewGroup?,
        savedInstanceState: Bundle?
    ): View? {
        Log.d("life_cycle","F onCreateView")
        // fragment 가 인터페이스를 처음으로 그릴 때 호출된다.
        // inflater -> 뷰를 그려주는 역할
        // container -> 부모뷰 달라붙을 곳
        return inflater.inflate(R.layout.fragment_one,container,false)
    }

fragment는 setContentView와는 달리 inflater와 container가 들어온다. inflater는 뷰를 그려주는 역할, container는 부모뷰를 의미한다. inflater중에 inflate함수가 있다. xml으로 fragment_one을 만들고 붙여주면 된다.

 

이번엔 Fragment를 동적으로 추가해보자. 버튼을 눌러서 fragment를 달아주는 모습을 보여주자. Fragment를 동적으로 추가하기 위해서는 FragmentManager의 도움을 받아야한다. supportFragmentManager는 Activity가 가지고 있다. supportFragmentManager를 가지고 와서 FragmentManager에 넣어준다.

 Transaction이라는 것도 만들어주어야 한다. Transaction은 작업의 단위이고 시작과 끝이 있다. fragmentTransaction에서 beginTransaction()을 실행해주고 할일(replace/add)를 입력해준다. 끝은 commit()이라는 것으로 명령해준다.

	val fragmentOne:FragmentOne= FragmentOne()
	val button:Button=findViewById(R.id.button)
        button.setOnClickListener {
            // fragment를 동적으로 작동하는 방법 -> 코드 입력
            // fragment 붙이는 방법 replace/add
            val fragmentManager:FragmentManager = supportFragmentManager

            // Transaction
            // 작업의 단위 -> 시작과 끝이 있다
            val fragmentTransaction=fragmentManager.beginTransaction()
            fragmentTransaction.replace(R.id.container,fragmentOne)

            fragmentTransaction.commit()
            // 끝을 내는 방법
            // commit -> 시간 될 때 해
            // commitnow -> 지금 당장해
        }

 

Fragment를 떼는 방법

	val fragmentOne:FragmentOne= FragmentOne()
	val button2:Button=findViewById(R.id.button2)
        button2.setOnClickListener {
            // fragment remove/detach 하는 방법
            val fragmentManager:FragmentManager=supportFragmentManager
            val fragmentTransaction=fragmentManager.beginTransaction()
            fragmentTransaction.detach(fragmentOne)
            fragmentTransaction.commit()
        }

detach/remove : remove는 다시 붙일 수 있고 detach는 안됨.

 

Fragment에 data를 넣어주는 방법

데이터 전달 방법
- Activity -> Fragment : argument bundle
- Fragment -> Activity : 자체 구현(리스너 구현)

 

budle이라는 것을 만들어서 Fragment에 끼워 넣어줘야 한다.

	// fragment 에 data 를 넣어주는 방법
        val bundle:Bundle = Bundle()
        bundle.putString("hello","hello")
        fragmentOne.arguments=bundle

(bundle은 type을 고려해주어야 한다)

putString 해주었으면 FragmentOne에서 꺼내주면 된다.

 override fun onActivityCreated(savedInstanceState: Bundle?) {
        Log.d("life_cycle","F onActivityCreated")
        val data = arguments?.getString("hello")
        // Log.d("data",data)
        super.onActivityCreated(savedInstanceState)
    }

 

Fragment -> Activity 데이터 전달은 리스너를 만들어서 구현한다.

    interface OnDataPassListener{
        fun onDataPass(data:String?)
    }
    lateinit var dataPassListener:OnDataPassListener
    override fun onAttach(context: Context) {
        super.onAttach(context)
        dataPassListener = context as OnDataPassListener
    }
override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
        Log.d("life_cycle","F onViewCreated")
        super.onViewCreated(view, savedInstanceState)
        // Activity의 OnCreate에서 했던 작업을 여기에서 한다
        val pass:Button=findViewById(R.id.pass)
        pass.setOnClickListener {
            dataPassListener.onDataPass("Good Bye")
        }
    }

이렇게 하고 FragmentActivity에 달아주면 된다.

class FragmentActivity : AppCompatActivity(),FragmentOne.OnDataPassListener {

    override fun onDataPass(data: String?) {
        Log.d("pass",""+data)
    }

 

728x90
반응형

'App > Android' 카테고리의 다른 글

[1] Android 소개  (0) 2022.03.08
RecyclerView  (0) 2021.08.25
Intent  (0) 2021.08.23
첫 프로젝트 만들기  (0) 2021.03.07
안드로이드(Android) 개요와 설치  (0) 2021.03.03

+ Recent posts