이 시나리오에서는 6개의 조각이 있는 ViewPager가 활동 내에서 구현됩니다. 조각 간 스와이프가 비활성화되어 있으므로 현재 조각을 변경하는 데 버튼이 사용됩니다. GET 요청이 서버로 전송되고 스와이프가 완료된 후 응답 데이터가 각 조각에 표시됩니다.
첫 번째 접근 방식(setUserVisibleHint 사용)
처음에는 조각이 표시될 때마다 GET 요청을 트리거하기 위해 setUserVisibleHint 메서드가 사용되었습니다. 그러나 이 접근 방식은 요청 즉시 실행으로 인해 스와이프 애니메이션에 지연이 발생했습니다.
두 번째 접근 방식(OnPageChangeListener 사용)
애니메이션 지연을 극복하려면 , OnPageChangeListener가 ViewPager에 추가되었습니다. 이 리스너는 페이지 스크롤 상태를 추적하고 원하는 조각이 완전히 표시되면(즉, 스크롤 상태가 IDLE과 같음) GET 요청을 보냅니다.
문제 및 해결 방법
두 번째 접근 방식은 잘 작동했지만 sendGetRequest()를 실행할 때 NullPointerException이 발생했습니다. 조각 참조를 제대로 얻지 못했기 때문입니다. 이 문제를 해결하려면 FragmentPagerAdapter의 instantiateItem 메서드에 조각에 대한 참조를 저장해야 했습니다. 그런 다음 OnPageChangeListener 내에서 새 조각을 생성하는 대신 ViewPagerPagerAdapter에서 참조된 조각을 사용할 수 있습니다.
ViewPager2용 업데이트 코드(Kotlin)
<code class="kotlin">viewPager.registerOnPageChangeCallback( object: ViewPager2.OnPageChangeCallback() { override fun onPageSelected(position: Int) { super.onPageSelected(position) val frag: Fragment = mAdapter.fragments[position] if (frag != null && frag is FragmentTwo) { (frag as FragmentTwo).sendGetRequest() } } } )</code>
여기서 mAdapter는 ViewPager2 내에서 사용되는 FragmentPagerAdapter를 의미합니다.
위 내용은 활동에서 ViewPager 조각의 메소드에 액세스하고 실행하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!