切换导航抽屉片段很慢

3
我有一个应用程序,带有导航抽屉,并为每个菜单项使用碎片。
每次点击一个项目,我替换当前的碎片。
问题是,用户点击后显示新的碎片需要很长时间,并且会卡住。最花费时间的碎片是一个内部也有选项卡的碎片(其中一个碎片包含RecyclerView)。
是否有任何方法可以加速碎片的加载?(如果可能的话,事先初始化它们?)
以下是我的代码:
protected override void OnCreate(Bundle bundle)
    {
        drawerLayout = FindViewById<DrawerLayout>(Resource.Id.drawer_layout);
        navigationView = FindViewById<NavigationView>(Resource.Id.nav_view);
        drawerLayout.DrawerClosed += DrawerLayout_DrawerClosed;


        navigationView.NavigationItemSelected += (sender, e) =>
        {
            e.MenuItem.SetChecked(true);
            //react to click here and swap fragments or navigate

            switch (e.MenuItem.ItemId)
            {
                case (Resource.Id.nav_home):
                    ListItemClicked(0);
                    break;

                case (Resource.Id.nav_halachot):
                    ListItemClicked(1);
                    break;

                case (Resource.Id.nav_times):
                    ListItemClicked(2);
                    break;

                case (Resource.Id.nav_siddur):
                    ListItemClicked(3);
                    break;
                case (Resource.Id.nav_compass):
                    ListItemClicked(4);
                    break;

                case (Resource.Id.nav_settings):
                    ListItemClicked(5);
                    break;
            }


            drawerLayout.CloseDrawers();                
        };

        if (bundle == null)
        {
            ListItemClicked(0);
            navigationView.Menu.GetItem(0).SetChecked(true);
            fragment = new HomeFragment();
            SupportFragmentManager.BeginTransaction()
            .Replace(Resource.Id.content_frame, fragment)
            .Commit();
        }
    }

 public override void OnBackPressed()
    {

        if (drawerLayout.IsDrawerOpen((int)GravityFlags.Start))
        {
            drawerLayout.CloseDrawer((int)GravityFlags.Start);
        }
        else
        {
            base.OnBackPressed();
        }
    }

    private void ListItemClicked(int position)
    {

        switch (position)
        {
            case 0:
                fragment = new HomeFragment();
                Title = "Home";
                SupportActionBar.Elevation = 8;
                break;
            case 1:
                fragment = new HalachaFragment();
                Title = "aaa";
                SupportActionBar.Elevation = 0;
                break;
            case 2:
                fragment = new TimesFragment();
                Title = "bbb";
                SupportActionBar.Elevation = 8;

                break;
            case 3:
                fragment = new SiddurFragment();
                Title = "ccc";
                SupportActionBar.Elevation = 8;
                break;
            case 4:
                fragment = new CompassFragment();
                Title = "ddd";
                SupportActionBar.Elevation = 8;
                break;
            case 5:
                fragment = new SettingsFragment();
                Title = "eee";
                break;
        }



    }

    private void DrawerLayout_DrawerClosed(object sender, DrawerLayout.DrawerClosedEventArgs e)
    {
        SupportFragmentManager.BeginTransaction()
            .Replace(Resource.Id.content_frame, fragment).AddToBackStack("BACK")
            .Commit();

    }

HalachaFragment.cs(包含选项卡的片段):

public class HalachaFragment : Fragment
{
    private ViewPager halachotPager;
    private PagerSlidingTabStrip tabs;

    public HalachaFragment()
    {
        this.RetainInstance = true;
    }
    public override void OnCreate(Bundle savedInstanceState)
    {
        base.OnCreate(savedInstanceState);

        // Create your fragment here
    }

    public override View OnCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState)
    {
        // Use this to return your custom view for this Fragment

        var view = inflater.Inflate(Resource.Layout.HalachaSection, container, false);

        var fragments = new Android.Support.V4.App.Fragment[]
       {
           new HalachotFragment(),
           new BooksFragment(),
       };

        var titles = CharSequence.ArrayFromStringArray(new[]
        {
                "הלכות",
                "ספרים",
        });

        halachotPager = view.FindViewById<ViewPager>(Resource.Id.halachotPager);

        halachotPager.Adapter = new TabsFragmentPagerAdapter(this.ChildFragmentManager, fragments, titles);
        halachotPager.OffscreenPageLimit = 2;
        halachotPager.SetCurrentItem(1, true);
        // Bind the tabs to the ViewPager
        tabs = view.FindViewById<PagerSlidingTabStrip>(Resource.Id.halachotTabs);

        tabs.SetViewPager(halachotPager);

        return view;

    }
}

希望有人能够帮助我。

谢谢。

1个回答

2

请参考这个解决方案。只需使用线程来加载片段子项,当您更改onItemClick时。

layoutDrawer.closeDrawer(linearDrawer);
setLastPosition(posicao);
new Handler().postDelayed(new Runnable() {
        @Override
        public void run() {
            setFragmentList(lastPosition);
        }
    }, 0);

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接