Android 滚动片段应该折叠工具栏

Android 滚动片段应该折叠工具栏,android,android-fragments,android-collapsingtoolbarlayout,Android,Android Fragments,Android Collapsingtoolbarlayout,我有以下程序,我想在其中添加一个折叠工具栏。这是一个选项卡布局,附加了多个片段 XML文件 JAVA文件 我以前试过这个,但是当我用一个折叠的工具栏替换我的工具栏时,如果我滚动工具栏部分,它就会折叠。我需要的是在向下滚动片段时,工具栏应该折叠。我该怎么做呢 另外,我是初学者,请解释一下为什么你的解决方案有效 编辑 好的,我想要的是当我滚动片段时,工具栏应该自行折叠。在下面的解决方案中,我必须首先手动折叠工具栏,然后滚动片段,这不是我想要的。请帮我做同样的事情看来你的布局是正确的,参考这篇文章它将

我有以下程序,我想在其中添加一个折叠工具栏。这是一个选项卡布局,附加了多个片段

XML文件

JAVA文件

我以前试过这个,但是当我用一个折叠的工具栏替换我的工具栏时,如果我滚动工具栏部分,它就会折叠。我需要的是在向下滚动片段时,工具栏应该折叠。我该怎么做呢

另外,我是初学者,请解释一下为什么你的解决方案有效

编辑
好的,我想要的是当我滚动片段时,工具栏应该自行折叠。在下面的解决方案中,我必须首先手动折叠工具栏,然后滚动片段,这不是我想要的。请帮我做同样的事情

看来你的布局是正确的,参考这篇文章它将帮助你实现你的目标

更新:

添加app:layout_scrollFlags=scroll | enterally to toolbar将解决您的问题。

尝试在android studio中创建滚动活动项目。这将为您提供一个折叠工具栏。步骤:Android studio->添加新项目->提供项目详细信息->在步骤中向移动设备添加活动选择滚动活动。完成


像这样更改工具栏

  <android.support.v7.widget.Toolbar
        android:id="@+id/toolbar"
        android:layout_width="match_parent"
        android:layout_height="?attr/actionBarSize"            
        app:layout_scrollFlags="scroll|enterAlways"
        app:popupTheme="@style/ThemeOverlay.AppCompat.Light" />
请参阅此处的示例以获取更多参考,它对我来说运行良好。我希望它能对您有所帮助。

只需将app:layout\u scrollFlags=scroll | enterally添加到您的工具栏,并将android:fitsystemwindows=true添加到您的XML坐标布局中即可
public class Competitions extends AppCompatActivity {
    private Toolbar toolbar;
    private TabLayout tabLayout;
    private ViewPager viewPager;


    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        Intent intent = getIntent();

        setContentView(R.layout.competition);

        toolbar = (Toolbar) findViewById(R.id.toolbar);
        setSupportActionBar(toolbar);
        getSupportActionBar().setTitle("Competitions");
        getSupportActionBar().setHomeButtonEnabled(true);
        getSupportActionBar().setDisplayHomeAsUpEnabled(true);

        viewPager = (ViewPager) findViewById(R.id.viewpager);
        setupViewPager(viewPager);

        tabLayout = (TabLayout) findViewById(R.id.tabs);
        tabLayout.setupWithViewPager(viewPager);
    }

    private void setupViewPager(ViewPager viewPager) {
        ViewPagerAdapter adapter = new ViewPagerAdapter(getSupportFragmentManager());
        adapter.addFragment(new IntChal(), "International Challenges");
        adapter.addFragment(new XMach(), "Xtreme Machines");
        adapter.addFragment(new TVoltz(), "Technovoltz");
        adapter.addFragment(new Robotron(), "Robotron");
        adapter.addFragment(new Dimensions(), "Dimensions");
        adapter.addFragment(new Tinker(), "Tinkerer");
        adapter.addFragment(new Aero(), "Aerostrike");
        adapter.addFragment(new Lamp(), "Solar Urja Lamp");
        viewPager.setAdapter(adapter);
    }

    class ViewPagerAdapter extends FragmentPagerAdapter {
        private final List<Fragment> mFragmentList = new ArrayList<>();
        private final List<String> mFragmentTitleList = new ArrayList<>();

        public ViewPagerAdapter(FragmentManager manager) {
            super(manager);
        }

        @Override
        public Fragment getItem(int position) {
            return mFragmentList.get(position);
        }

        @Override
        public int getCount() {
            return mFragmentList.size();
        }

        public void addFragment(Fragment fragment, String title) {
            mFragmentList.add(fragment);
            mFragmentTitleList.add(title);
        }

        @Override
        public CharSequence getPageTitle(int position) {
            return mFragmentTitleList.get(position);
        }
    }
    public boolean onOptionsItemSelected(MenuItem item) {
        switch (item.getItemId()) {
            case android.R.id.home:
                onBackPressed();
                return true;
        }

        return super.onOptionsItemSelected(item);
    }


}
  <android.support.v7.widget.Toolbar
        android:id="@+id/toolbar"
        android:layout_width="match_parent"
        android:layout_height="?attr/actionBarSize"            
        app:layout_scrollFlags="scroll|enterAlways"
        app:popupTheme="@style/ThemeOverlay.AppCompat.Light" />