【问题标题】:Open ViewPager In Fragment Make App Crash在 Fragment 中打开 ViewPager 使应用程序崩溃
【发布时间】:2020-10-02 04:40:21
【问题描述】:

我正在开发一个在片段上实现 View-pager 的布局,问题出现在我在 Fragment 上实现 View-pager 布局时。当我从底部导航打开 View-pager Main Fragment 时,应用程序崩溃并在其中不显示任何内容。 这是我实现 View-pager 的 Xml 文件主片段。 这个布局是在线性布局之后实现的

<com.google.android.material.tabs.TabLayout
android:id="@+id/tablayout"
android:layout_width="match_parent"
android:layout_height="wrap_content" />
<androidx.viewpager.widget.ViewPager
android:id="@+id/viewpager"
android:layout_width="match_parent"
android:layout_height="0dp"
android:layout_weight="1" />

这是 Kotlin 文件的主要片段

class ViewPagerFragmentMain : Fragment() {

override fun onCreate(savedInstanceState: Bundle?) {
    super.onCreate(savedInstanceState)

    val viewPager: ViewPager = view!!.findViewById(R.id.viewpager)
    val tabLayout: TabLayout = view!!.findViewById(R.id.tablayout)

    // attach tablayout with viewpager

    tabLayout.setupWithViewPager(viewPager)

    val adapter = ViewPagerAdapter(childFragmentManager)

    // add your fragments

    // add your fragments
    adapter.addFrag(FragmentViewPagerHistory(), "Tab1")
    adapter.addFrag(FragmentViewPagerHistorySecond(), "Tab2")
    // set adapter on viewpager

    // set adapter on viewpager
    viewPager.adapter = adapter


}

override fun onCreateView(
    inflater: LayoutInflater, container: ViewGroup?,
    savedInstanceState: Bundle?
): View? {
    // Inflate the layout for this fragment
    return inflater.inflate(R.layout.fragment_view_pager_main, container, false)
}

从主活动我调用这个方法来打开片段

 private fun ShowFragmentViewPager() {
    val newFragment: Fragment = ViewPagerFragmentMain()
    val transaction1: FragmentTransaction = supportFragmentManager.beginTransaction();
    transaction1.replace(R.id.frameLayout, newFragment);
    transaction1.addToBackStack(null);
    transaction1.commit();
}

调试器结果是这样的

在 Logcat 中它什么也没有显示

我无法理解我做错了什么......

[https://stackoverflow.com/questions/32356867/app-crashes-viewpager][5]

实施更改后的代码如下所示

【问题讨论】:

    标签: android android-studio kotlin android-fragments android-viewpager


    【解决方案1】:

    您需要了解lifecycle of Fragment。您在onCreate() 中编写的代码必须在onViewCreated() 中。或者在onCreateView(),设置好视图后。所以基本上

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
    
        val viewPager: ViewPager = view!!.findViewById(R.id.viewpager)
        val tabLayout: TabLayout = view!!.findViewById(R.id.tablayout)
    
        // attach tablayout with viewpager
    
        tabLayout.setupWithViewPager(viewPager)
    
        val adapter = ViewPagerAdapter(childFragmentManager)
    
        // add your fragments
    
        // add your fragments
        adapter.addFrag(FragmentViewPagerHistory(), "Tab1")
        adapter.addFrag(FragmentViewPagerHistorySecond(), "Tab2")
        // set adapter on viewpager
    
        // set adapter on viewpager
        viewPager.adapter = adapter
    } 
    

    以上代码导致空指针异常。因为onCreate() 中的视图还没有准备好,而您正在尝试访问该视图。


    onCreateView() 乱码后更新

    您需要在onCreateView() 中编写代码,如下所示

    override fun onCreateView(inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle?): View? {
        val rootView = inflater.inflate(R.layout.fragment_view_pager_main, container, false)
    
        val viewPager: ViewPager = rootView.findViewById(R.id.viewpager)
        val tabLayout: TabLayout = rootView.findViewById(R.id.tablayout)
    
        // attach tablayout with viewpager
    
        tabLayout.setupWithViewPager(viewPager)
    
        val adapter = ViewPagerAdapter(childFragmentManager)
    
        // add your fragments
    
        // add your fragments
        adapter.addFrag(FragmentViewPagerHistory(), "Tab1")
        adapter.addFrag(FragmentViewPagerHistorySecond(), "Tab2")
        // set adapter on viewpager
    
        // set adapter on viewpager
        viewPager.adapter = adapter
        
        return rootView
    }
    

    【讨论】:

    • 我使用的是 Fragment,因为它只包含充气机和容器
    • 我已经实现了这个 onCreateView 但问题仍然存在
    • 是的。无论您如何使用 Fragment,生命周期都保持不变。
    • 将您添加的代码添加到onCreateView中
    • 我已经完成了,这解决了问题,因为我在做所有事情后都在膨胀
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2015-08-30
    • 1970-01-01
    • 1970-01-01
    • 2020-12-06
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多