【问题标题】:Swiping through views in Android在 Android 中滑动浏览视图
【发布时间】:2015-01-22 12:07:16
【问题描述】:

我已经看到很多关于此的已回答问题,但没有关于我到底想要什么,所以就在这里(如果有关于此的已回答线程,我将不胜感激):

我想创建一种“关卡选择”应用程序,您基本上必须从右向左滑动才能看到下一个关卡列表,但是我想在没有标签的情况下进行(避风港)还不知道怎么做)。

谢谢。

编辑:通过简单地使用 ViewPager 来解决它,甚至无需打扰或关注 Android 告诉您添加的 ActionBar 部分(我刚刚创建了我的几个片段,我的 viewpager,最后一个完成了剩下的工作,甚至没有需要使用手势检测器进行滑动,因为 viewpager 已经提供了这个动画)。

任何教你如何在标签之间滑动的 ViewPager 教程基本上都有我需要的所有信息 :) 谢谢大家!

【问题讨论】:

  • 所以没有浏览器?
  • 是的,我只想要视图和将转到下一个视图的“滑动动作”,就像游戏会让你从一个巨大的列表中选择一个级别。

标签: android view fragment swipe


【解决方案1】:

为此,您应该使用ViewPager
这很容易 !

  1. 布局ViewPager

    <android.support.v4.view.ViewPager
        android:id="@+id/vpPager"
        android:layout_width="match_parent"
        android:layout_height="wrap_content">
    </android.support.v4.view.ViewPager>
    

  2. 定义片段

    公共类 FirstFragment 扩展片段 { // 存储实例变量 私有字符串标题; 私有 int 页面;

    // newInstance constructor for creating fragment with arguments
    public static FirstFragment newInstance(int page, String title) {
        FirstFragment fragmentFirst = new FirstFragment();
        Bundle args = new Bundle();
        args.putInt("someInt", page);
        args.putString("someTitle", title);
        fragmentFirst.setArguments(args);
        return fragmentFirst;
    }
    
    // Store instance variables based on arguments passed
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        page = getArguments().getInt("someInt", 0);
        title = getArguments().getString("someTitle");
    }
    
    // Inflate the view for the fragment based on layout XML
    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
        View view = inflater.inflate(R.layout.fragment_first, container, false);
        TextView tvLabel = (TextView) view.findViewById(R.id.tvLabel);
        tvLabel.setText(page + " -- " + title);
        return view;
    }
    

    }

  3. 设置 FragmentPagerAdapter

    公共类 MainActivity 扩展 FragmentActivity { // ...

    public static class MyPagerAdapter extends FragmentPagerAdapter {
    private static int NUM_ITEMS = 3;
    
        public MyPagerAdapter(FragmentManager fragmentManager) {
            super(fragmentManager);
        }
    
        // Returns total number of pages
        @Override
        public int getCount() {
            return NUM_ITEMS;
        }
    
        // Returns the fragment to display for that page
        @Override
        public Fragment getItem(int position) {
            switch (position) {
            case 0: // Fragment # 0 - This will show FirstFragment
                return FirstFragment.newInstance(0, "Page # 1");
            case 1: // Fragment # 0 - This will show FirstFragment different title
                return FirstFragment.newInstance(1, "Page # 2");
            case 2: // Fragment # 1 - This will show SecondFragment
                return SecondFragment.newInstance(2, "Page # 3");
            default:
                return null;
            }
        }
    
        // Returns the page title for the top indicator
        @Override
        public CharSequence getPageTitle(int position) {
            return "Page " + position;
        }
    
    }
    

    }

  4. 应用适配器

    公共类 MainActivity 扩展 FragmentActivity { FragmentPagerAdapteradapterViewPager;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_home);
        ViewPager vpPager = (ViewPager) findViewById(R.id.vpPager);
        adapterViewPager = new MyPagerAdapter(getSupportFragmentManager());
        vpPager.setAdapter(adapterViewPager);
    }
    
    // ...
    

    }

  5. 设置 OnPageChangeListener

    // 在activity内部附加页面变化监听器 vpPager.setOnPageChangeListener(new OnPageChangeListener() {

    // This method will be invoked when a new page becomes selected.
    @Override
    public void onPageSelected(int position) {
        Toast.makeText(HomeActivity.this, 
                    "Selected page position: " + position, Toast.LENGTH_SHORT).show();
    }
    
    // This method will be invoked when the current page is scrolled
    @Override
    public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
        // Code goes here
    }
    
    // Called when the scroll state changes: 
    // SCROLL_STATE_IDLE, SCROLL_STATE_DRAGGING, SCROLL_STATE_SETTLING
    @Override
    public void onPageScrollStateChanged(int state) {
        // Code goes here
    }
    

    });

如果您需要更多信息,请查看此链接(它还解释了如何使用选项卡):

https://github.com/codepath/android_guides/wiki/ViewPager-with-FragmentPagerAdapter

【讨论】:

  • 据我所知,ViewPager 给出了选项卡的效果,我只想要一个级别列表(例如,第一页从 1 到 20,第二页从 21 到 40 ...) 但我不想要任何选项卡,只想要带有级别和滑动操作的视图。
  • 我希望这个链接可以帮助你:developer.android.com/training/implementing-navigation/…
  • 我会试试的,虽然我认为它所说的 ViewPager 是我不想要的,但是谢谢! :)
  • 我认为如果你想使用片段 ViewPager 是最简单的方法!但是你可能会用动画来做点什么!
【解决方案2】:

您必须使用 HorizontalScrollView (http://developer.android.com/reference/android/widget/HorizontalScrollView.html) 自己管理水平滚动。 Juste在里面放置其他视图,你很好。

【讨论】:

  • 这实际上是解决我的问题的好方法,我只需要不显示滚动条本身就可以了。尽管如此,我还是想要 ViewPager 的效果,只是没有它提供的选项卡,就像在 swipe -> next page of levels 中一样,但不显示选项卡。如果我找不到办法,我肯定会使用水平滚动条,谢谢!
【解决方案3】:

编辑:通过简单地使用 ViewPager 解决了这个问题,甚至没有打扰或关注 Android 告诉你添加的 ActionBar 部分(我刚刚创建了我的几个片段,我的 viewpager,最后一个完成了剩下的工作,甚至没有需要使用手势检测器进行滑动,因为 viewpager 已经提供了这个动画)。

任何教你如何在标签之间滑动的 ViewPager 教程基本上都有我需要的所有信息 :) 谢谢大家!

【讨论】:

    最近更新 更多