활동에서 ViewPager 조각 방법에 액세스
많은 모바일 애플리케이션은 모듈식 화면 섹션을 나타내는 자체 포함 구성 요소인 조각을 활용합니다. 뷰 페이저를 사용하여 여러 조각을 관리하면 원활한 탐색 및 페이지 애니메이션이 가능해집니다. 때때로 개발자는 뷰 호출기에서 사용자 스와이프와 같은 외부 이벤트에 대한 응답으로 조각 내에서 특정 작업을 수행해야 하는 경우가 있습니다. 그러나 이 기능을 구현하는 데는 특정 문제가 발생할 수 있습니다.
초기 접근 방식 및 제한 사항
처음에는 setUserVisibleHint 메서드를 재정의하여 조각 가시성을 감지하려는 시도가 이루어졌습니다. 이 접근 방식은 효과가 있었지만 프래그먼트 전환 중에 눈에 띄는 지연이 발생했습니다.
뷰 페이저에 등록된 리스너인 OnPageChangeListener를 활용하는 대체 접근 방식이 있었는데, 이는 프래그먼트 작업 타이밍에 대한 더 많은 제어를 제공했습니다. 그러나 OnPageChangeListener의 조각 내에서 메서드를 실행하려고 하면 NullPointerException이 발생했습니다.
솔루션
해결책은 호출기 어댑터. ViewPager는 배열이나 컬렉션에 조각 참조를 저장하기 위해 재정의할 수 있는 instantiateItem이라는 메서드를 제공합니다. onPageSelected 이벤트 중에 어댑터에서 원하는 조각 인스턴스에 액세스하고 네트워크 요청 시작과 같은 필요한 작업을 수행할 수 있습니다.
예제 코드(Java)
public class PagerAdapter extends FragmentPagerAdapter {
private Fragment[] fragments;
public PagerAdapter(FragmentManager fm, Context context) {
super(fm);
}
@Override
public Object instantiateItem(ViewGroup container, int position) {
Fragment createdFragment = (Fragment) super.instantiateItem(container, position);
fragments[position] = createdFragment;
return createdFragment;
}
}
// Within your activity that hosts view pager:
onPageChangeListener = new ViewPager.OnPageChangeListener() {
@Override
public void onPageSelected(int position) {
// Assuming you named your fragment FragmentTwo
Fragment frag = adapter.fragments[position];
if (frag != null && frag instanceof FragmentTwo) {
((FragmentTwo) frag).sendGetRequest();
}
}
};
Kotlin 동등 항목(Kotlin 확장 프로그램 및 ViewPager2 포함)
viewPager.registerOnPageChangeCallback(
object : ViewPager2.OnPageChangeCallback() {
override fun onPageSelected(position: Int) {
val frag = mAdapter.fragments[position]
if (frag is FragmentTwo) {
frag.sendGetRequest()
}
}
}
)
결론
이 접근 방식을 구현하면 호스팅 활동의 조각과 효과적으로 통신하여 모바일 애플리케이션 내에서 원활한 통합과 향상된 사용자 경험을 구현할 수 있습니다.
부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.
Copyright© 2022 湘ICP备2022001581号-3