【问题标题】:Sliding tabs inside actionbar tabs操作栏选项卡内的滑动选项卡
【发布时间】:2015-08-03 12:26:51
【问题描述】:

我正在尝试在 actionBar 选项卡中实现滑动选项卡,就像翻转板一样。因此,主要选项卡之一将具有三个选项卡。子选项卡将首先滚动,一旦所有选项卡都滚动,主选项卡就会成为焦点并开始滚动。

我附上flipBoard UI的截图

有人做过吗?请帮忙。

【问题讨论】:

  • 谢谢大家..@MimmoGrottoli 任何想法flipboard如何改变viewpager onPageScroll上的文本颜色
  • 我猜他们有一个透明图像作为文本,他们移动了一个放置在选项卡下的红色矩形
  • 或者文本的颜色只是透明的:)
  • 您可以删除操作栏并添加您的服装控制,如寻呼机、选项卡视图。 Tab-1 => t11,t12,t13 Tab2=> t21,t22,t23 and Tab-3=> t31,t32,t33 像这样。

标签: android android-viewpager flipboard android-actionbar-tabs


【解决方案1】:

它似乎已经由 Android 管理:您只需要在外部活动中创建一个 ViewPager,并且为 ViewPager 托管的每个片段创建一个 ViewPager。这是我的测试项目:

MainActivity.java

public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        MyPagerAdapter adapter = new MyPagerAdapter(getSupportFragmentManager());
        ViewPager viewPager = (ViewPager) findViewById(R.id.pager_activity);
        viewPager.setAdapter(adapter);
    }

    private class MyPagerAdapter extends FragmentStatePagerAdapter {

        public MyPagerAdapter(FragmentManager fm) {
            super(fm);
        }

        @Override
        public android.support.v4.app.Fragment getItem(int i) {
            return new InnerFragment();
        }

        @Override
        public int getCount() {
            return 3;
        }

        @Override
        public CharSequence getPageTitle(int position) {
            return "ACTIVITY TITLE " + (position+1);
        }
    }
}

activity_main.xml

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity">

    <android.support.v4.view.ViewPager
        xmlns:android="http://schemas.android.com/apk/res/android"
        android:id="@+id/pager_activity"
        android:layout_width="match_parent"
        android:layout_height="match_parent">

        <android.support.v4.view.PagerTitleStrip
            android:id="@+id/pager_title_strip_activity"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_gravity="top"
            android:background="#33b5e5"
            android:textColor="#fff"
            android:paddingTop="4dp"
            android:paddingBottom="4dp" />

    </android.support.v4.view.ViewPager>

</RelativeLayout>

InnerFragment.java(活动视图页面中托管的片段之一)

public class InnerFragment extends Fragment {

    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
                             Bundle savedInstanceState) {
        View root = inflater.inflate(R.layout.fragment_inner, container, false);
        ViewPager pager = (ViewPager) root.findViewById(R.id.pager);
        MyPagerAdapter adapter = new MyPagerAdapter(getChildFragmentManager());
        pager.setAdapter(adapter);
        return root;
    }

    private class MyPagerAdapter extends FragmentStatePagerAdapter {

        public MyPagerAdapter(FragmentManager fm) {
            super(fm);
        }

        @Override
        public android.support.v4.app.Fragment getItem(int i) {
            return PageFragment.newInstance(i+1);
        }

        @Override
        public int getCount() {
            return 3;
        }

        @Override
        public CharSequence getPageTitle(int position) {
            return "FRAGMENT " + (position+1) + " TITLE " + (position+1);
        }
    }
}

及其布局fragment_inner.xml

<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="it.test.testflipboardviewpager.InnerFragment">

    <android.support.v4.view.ViewPager
        xmlns:android="http://schemas.android.com/apk/res/android"
        android:id="@+id/pager"
        android:layout_width="match_parent"
        android:layout_height="match_parent">

        <android.support.v4.view.PagerTitleStrip
            android:id="@+id/pager_title_strip"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_gravity="top"
            android:background="#33b5e5"
            android:textColor="#fff"
            android:paddingTop="4dp"
            android:paddingBottom="4dp" />

    </android.support.v4.view.ViewPager>

</FrameLayout>

PageFragment.java - InnerFragment viewpager 托管的片段之一

public class PageFragment extends Fragment {

    private int mPosition;

    public static PageFragment newInstance(int position) {
        PageFragment fragment = new PageFragment();
        Bundle args = new Bundle();
        args.putInt("position", position);
        fragment.setArguments(args);
        return fragment;
    }

    public PageFragment() {
        // Required empty public constructor
    }

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        if (getArguments() != null) {
            mPosition = getArguments().getInt("position");
        }
    }

    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
                             Bundle savedInstanceState) {
        // Inflate the layout for this fragment
        View root = inflater.inflate(R.layout.fragment_page, container, false);
        TextView textView = (TextView) root.findViewById(R.id.text);
        textView.setText("" + mPosition);
        return root;
    }
}

及其布局fragment_page.xml

<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="it.test.testflipboardviewpager.PageFragment">

    <TextView
        android:id="@+id/text"
        android:textSize="25sp"
        android:gravity="center"
        android:layout_width="match_parent"
        android:layout_height="match_parent" />

</FrameLayout>

就是这样!试着告诉我。

编辑: 忘了说第一个组件不是ActionBar。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2023-03-25
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多