2013-01-08 31 views
4

我想弄清楚如何为横向导航创建三个视图,但developer.android.com提供的示例是无用的,因为它们仅用于API 11转发。我一直在寻找一个简单的复制/粘贴滑动导航的例子,但我没有任何运气。Android上的滑动导航示例?

我发现教程swype之间的活动,或不同的布局,但它不是我想要做的,我需要以编程方式生成每个“屏幕”。这是因为我正在做一些应该像主屏幕一样工作的东西,并且屏幕数量可能会有所不同。

有人可以提供一些例子/教程如何以编程方式创建三个横向导航视图?任何事情都会有帮助。

+0

您可以使用Android支持库实现轻松导航。 –

回答

12

这是主要的活动更好地库:

public class MainActivity extends Activity { 

    @Override 
    public void onCreate(Bundle savedInstanceState) { 
     super.onCreate(savedInstanceState); 
     setContentView(R.layout.activity_main); 
     MyPagerAdapter adapter = new MyPagerAdapter(); 
     ViewPager myPager = (ViewPager) findViewById(R.id.home_pannels_pager); 
     myPager.setAdapter(adapter); 
     myPager.setCurrentItem(0); 
    } 

} 

创建在同一包装的另一个类称为MyPagerAdapter:

public class MyPagerAdapter extends PagerAdapter { 

     // State number of pages 
     public int getCount() { 
      return 5; 
     } 

     // Set each screen's content 
     @Override 
     public Object instantiateItem(View container, int position) { 
      Context context = container.getContext(); 
      LinearLayout layout = new LinearLayout(context); 
      // Add elements 
      TextView textItem = new TextView(context); 

      buttonItem.setOnClickListener(new View.OnClickListener() { 
       @Override 
       public void onClick(View v) { 
        Intent intent = new Intent("com.phone"); 
        // myFancyMethod(v); 
       } 
      }); 


      switch (position) { 
      case 0: 
       textItem.setText("First Screen"); 
       break; 
      case 1: 
       textItem.setText("Second Screen"); 
       break; 
      case 2: 
       textItem.setText("Third Screen"); 
       break; 


    case 3: 
      textItem.setText("Fourth Screen"); 
      break; 
     case 4: 
      textItem.setText("Fifth Screen"); 
      break; 
     } 
     layout.addView(textItem); 
     ((ViewPager) container).addView(layout, 0); // This is the line I added 
     return layout; 
    } 
    @Override 
    public void destroyItem(View arg0, int arg1, Object arg2) { 
     ((ViewPager) arg0).removeView((View) arg2); 
    } 
    @Override 
    public boolean isViewFromObject(View arg0, Object arg1) { 
     return arg0 == ((View) arg1); 
    } 
    @Override 
    public Parcelable saveState() { 
     return null; 
    } 
} 

最后在/ res/layout中创建activity_main.xml:

<?xml version="1.0" encoding="utf-8"?> 
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    android:orientation="vertical" 
    android:layout_width="fill_parent" 
    android:layout_height="fill_parent"> 
    <android.support.v4.view.ViewPager 
     android:layout_width="match_parent" 
     android:layout_height="match_parent" 
     android:id="@+id/home_pannels_pager"/> 
</LinearLayout> 
3

参观site其给出刷卡视图导航

+0

这个链接真的很有用。谢谢 – 2013-04-29 11:56:08