8

我需要设计以下屏幕,我需要你的建议:

在此处输入图像描述

解释:

标题是静态的/固定的,我不需要对它做任何事情。

黄色:这是有趣的部分,我需要设计一个ViewPager可以左右滚动最多 4 个屏幕的类似屏幕。

红色:在每个屏幕中,如果不适合屏幕大小,我需要添加一个可以滚动的表格/网格。

绿色:可以使用屏幕底部的绿色按钮或滚动 来完成页面切换ViewPager

问题是:这种行为可以使用 aViewPager还是应该使用来实现Fragments?如果 Fragment 是要走的路,那么我将如何使用滑动手势实现页面切换?如果是,ViewPager那么如何添加内部滚动以及如何使用底部的按钮来控制它?

任何帮助将不胜感激,谢谢。

4

2 回答 2

7

我认为这应该通过Non Swipeable ViewPager来解决。视图寻呼机底层Fragments 无法响应滑动手势。覆盖以禁用滑动的方法ViewPager是:

  1. onTouchEvent()- 返回false
  2. onInterceptTouchEvent()- 返回false

有关如何实现此目的的更多信息,请参阅此 SO 问题。

接下来,您希望Fragment在每个寻呼机持有人中使用 s。所以我们正在构建以下布局:

在父活动FragmentPagerAdapter中实例化 a 并且您的选项卡添加了标签:

活动变化

@Override
protected void onCreate(final Bundle saveInstanceState) {
    final FragmentPagerAdapter myTabAdapter = new MyFragmentPagerAdapter(
            <Your ViewPager View>, <Your activity context, this>);
    myTabAdapter.addTab(getActionBar().newTab(), "YOUR TAG", "Your Title");
    // etc...
}

所以这给了我们上图的框架。一个托管活动,包含一个ViewPager和基础选项卡。接下来是将Fragments (包含您的表格)放入每个相应的选项卡中。这由FragmentPagerAdapter实现处理:

片段适配器(活动的内部类):

private class MyFragmentPagerAdapter extends FragmentPagerAdapter implements
        ActionBar.TabListener, ViewPager.OnPageChangeListener {

    /**
     * Constructs a pager adapter to back a {@link ViewPager}.
     * 
     * @param pager
     *            The {@link ViewPager} widget.
     * @param activityContext
     *            The context the widget is being added under.
     */
    public SpotMenuFragmentPagerAdapter(final ViewPager pager,
            final Context activityContext) {
        super(getFragmentManager());
        pager.setAdapter(this);
        this.context = activityContext;
    }

    /**
     * Adds a tab to the hosting activity action bar.
     * 
     * @param newTab
     *            The tab to add.
     * @param tag
     *            The tab tag for id purposes.
     * @param label
     *            The label of the tab displayed to the user.
     */
    public void addTab(final ActionBar.Tab newTab, final String tag,
            final String label) {
        newTab.setTag(tag);
        newTab.setText(label);
        newTab.setTabListener(this);
        getSupportActionBar().addTab(newTab);
    }

    /**
     * This is where you do the work of building the correct fragment based
     * on the tab currently selected.
     * 
     * @see FragmentPagerAdapter#getItem(int)
     */
    @Override
    public Fragment getItem(final int position) {
        final Tab tab = getActionBar().getTabAt(position);
        if ("MY TAG".equals(tab.getTag().toString()) {
            // instantiate the fragment (table) for "MY TAG"
        } else {
            // instantiate something else...
        }
    }

    /**
     * One fragment per tab.
     * 
     * @see android.support.v4.view.PagerAdapter#getCount()
     */
    @Override
    public int getCount() {
        return getSupportActionBar().getTabCount();
    }

    /**
     * @see ViewPager.OnPageChangeListener#onPageScrollStateChanged(int)
     */
    @Override
    public void onPageScrollStateChanged(final int arg0) {
        // No-op.
    }

    /**
     * @see ViewPager.OnPageChangeListener#onPageScrolled(int, float, int)
     */
    @Override
    public void onPageScrolled(final int arg0, final float arg1,
            final int arg2) {
        // No-op.
    }

    /**
     * @see ViewPager.OnPageChangeListener#onPageSelected(int)
     */
    @Override
    public void onPageSelected(final int position) {
        getSupportActionBar().setSelectedNavigationItem(position);
    }

    /**
     * @see TabListener#onTabSelected(app.ActionBar.Tab,
     *      app.FragmentTransaction)
     */
    @Override
    public void onTabSelected(final Tab tab, final FragmentTransaction ft) {
        viewPager.setCurrentItem(tab.getPosition());
    }

    /**
     * @see TabListener#onTabUnselected(ActionBar.Tab,
     *      app.FragmentTransaction)
     */
    @Override
    public void onTabUnselected(final Tab tab, final FragmentTransaction ft) {
        // No-op.
    }

    /**
     * @see TabListener#onTabReselected(ActionBar.Tab,app.FragmentTransaction)
     */
    @Override
    public void onTabReselected(final Tab tab, final FragmentTransaction ft) {
        // No-op.
    }
}

因此,希望到此为止,我们有一个托管“不可滑动”视图寻呼机的活动,以及一个在标题下方(或根据屏幕大小而定)以标签栏形式切换标签的机制。从这一点开始,我相信您可以自定义以用一些导航箭头替换标签栏。

注意:很多内容都是凭记忆写的,但希望我已经传达了我将如何处理的要点。

更新

针对更新的问题:您可以将选项卡设置为任何旧视图。相应地设置TabSpec。抱歉,我自己没有使用过这个。

于 2013-03-18T20:02:53.853 回答
3

您必须使用 Horizo​​ntalScrollView 它将包含一个 LinearLayout 而 Linear 将包含您的各个元素

XML 会看到类似这样的内容

 <HorizontalScrollView
        android:id="@+id/horizontal_scroll_parent"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:scrollbars="horizontal"
        android:scrollbarStyle="outsideInset">

       <LinearLayout android:id="@+id/content_scroll"
                android:layout_width="wrap_content"
                android:layout_height="match_parent"
                android:orientation="horizontal"
                android:gravity="center_vertical" />

</HorizontalScrollView>
于 2013-04-15T17:10:18.440 回答