在 Android 中滑动浏览视图
Swiping through views in Android
我已经看到很多关于此的已回答问题,但是 none 关于我真正想要的,所以在这里(如果有关于此的已回答线程,我将不胜感激):
我想创建一种 "level selection" 应用程序,您基本上必须从右向左滑动才能看到下一个级别列表,但我想在没有标签的情况下执行此操作(还没有找到怎么做)。
谢谢。
编辑:通过简单地使用 ViewPager 解决它,甚至不用打扰或注意 ActionBar 部分 Android 告诉你添加(我刚刚创建了我的几个片段,我的 viewpager,最后一个做了休息,甚至不需要使用手势检测器进行滑动,因为 viewpager 已经提供了这个动画)。
任何教你如何在选项卡之间滑动的 ViewPager 教程基本上都有我需要的所有信息:) 谢谢大家!
为此你应该使用 ViewPager
这很容易 !
布局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>
定义片段
public class FirstFragment extends Fragment {
// 存储实例变量
私有字符串标题;
私有页面;
// 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;
}
}
设置 FragmentPagerAdapter
public class 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;
}
}
}
应用适配器
public class MainActivity 扩展了 FragmentActivity {
FragmentPagerAdapter adapterViewPager;
@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);
}
// ...
}
设置 OnPageChangeListener
// 在 activity 中附加页面更改侦听器
vpPager.setOnPageChangeListener(新的 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
}
});
如果您需要更多信息,请参阅此 link(它还解释了如何使用制表符):
https://github.com/codepath/android_guides/wiki/ViewPager-with-FragmentPagerAdapter
您必须使用 HorizontalScrollView
(http://developer.android.com/reference/android/widget/HorizontalScrollView.html),它会自行管理水平滚动。只需在里面放置另一个视图就可以了。
编辑:通过简单地使用 ViewPager 解决了它,甚至没有打扰或注意 ActionBar 部分 Android 告诉你添加(我刚刚创建了我的几个片段,我的 viewpager,最后一个做了休息,甚至不需要使用手势检测器进行滑动,因为 viewpager 已经提供了这个动画)。
任何教您如何在选项卡之间滑动的 ViewPager 教程基本上都有我需要的所有信息:) 谢谢大家!
我已经看到很多关于此的已回答问题,但是 none 关于我真正想要的,所以在这里(如果有关于此的已回答线程,我将不胜感激):
我想创建一种 "level selection" 应用程序,您基本上必须从右向左滑动才能看到下一个级别列表,但我想在没有标签的情况下执行此操作(还没有找到怎么做)。
谢谢。
编辑:通过简单地使用 ViewPager 解决它,甚至不用打扰或注意 ActionBar 部分 Android 告诉你添加(我刚刚创建了我的几个片段,我的 viewpager,最后一个做了休息,甚至不需要使用手势检测器进行滑动,因为 viewpager 已经提供了这个动画)。
任何教你如何在选项卡之间滑动的 ViewPager 教程基本上都有我需要的所有信息:) 谢谢大家!
为此你应该使用 ViewPager
这很容易 !
布局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>
定义片段
public class FirstFragment extends Fragment { // 存储实例变量 私有字符串标题; 私有页面;
// 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; }
}
设置 FragmentPagerAdapter
public class 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; } }
}
应用适配器
public class MainActivity 扩展了 FragmentActivity { FragmentPagerAdapter adapterViewPager;
@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); } // ...
}
设置 OnPageChangeListener
// 在 activity 中附加页面更改侦听器 vpPager.setOnPageChangeListener(新的 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 }
});
如果您需要更多信息,请参阅此 link(它还解释了如何使用制表符):
https://github.com/codepath/android_guides/wiki/ViewPager-with-FragmentPagerAdapter
您必须使用 HorizontalScrollView
(http://developer.android.com/reference/android/widget/HorizontalScrollView.html),它会自行管理水平滚动。只需在里面放置另一个视图就可以了。
编辑:通过简单地使用 ViewPager 解决了它,甚至没有打扰或注意 ActionBar 部分 Android 告诉你添加(我刚刚创建了我的几个片段,我的 viewpager,最后一个做了休息,甚至不需要使用手势检测器进行滑动,因为 viewpager 已经提供了这个动画)。
任何教您如何在选项卡之间滑动的 ViewPager 教程基本上都有我需要的所有信息:) 谢谢大家!