1. 程式人生 > >android實現頂部滑動列表

android實現頂部滑動列表

(1)定義一個xml  viewpager控制元件

<?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/bannerFrame"
android:layout_width="match_parent"
android:layout_height="match_parent">

<android.support.v4.view.ViewPager
android:layout_width="match_parent" android:layout_height="188dp" android:id="@+id/vp_main_viewPage"/> <LinearLayout android:id="@+id/linearIndicator" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_gravity="right" android:gravity="right" android:layout_marginTop=
"158dp" android:orientation="horizontal"> </LinearLayout> </FrameLayout>
(2)使用介面卡
public class MainActivity extends AppCompatActivity {
    private static final String TAG = "BannerActivity";
    private ViewPager mYViewPager;
    private LinearLayout mLinearIndicator;
    private List<ImageView> mImageViews
; private int mTotalCount = 0; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); mYViewPager = (ViewPager) findViewById(R.id.vp_main_viewPage); mLinearIndicator = (LinearLayout) findViewById(R.id.linearIndicator); initImgs(); mYViewPager.setAdapter(new ImagePagerAdapter()); mYViewPager.setCurrentItem(0); mYViewPager.addOnPageChangeListener(new YViewPager.OnPageChangeListener() { @Override public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) { } @Override public void onPageSelected(int position) { setIndicator(position%mImageViews.size()); Log.d(TAG,"POSITION=====>"+mYViewPager.getCurrentItem()); } @Override public void onPageScrollStateChanged(int state) { } }); } private void setIndicator(int pos) { mLinearIndicator.removeAllViews(); for (int i = 0; i < mImageViews.size(); i++) { int resId = i == pos ? R.drawable.circle_selected : R.drawable.circle_normal; ImageView indicator = new ImageView(this); indicator.setImageResource(resId); LinearLayout.LayoutParams lp = new LinearLayout.LayoutParams(30, 30); indicator.setLayoutParams(lp); mLinearIndicator.addView(indicator); } } private void initImgs() { mImageViews = new ArrayList<>(); ViewPager.LayoutParams lp = new ViewPager.LayoutParams(); lp.gravity = Gravity.LEFT; ImageView imageView1 = new ImageView(this); imageView1.setImageResource(R.mipmap.jay_fantexi); imageView1.setScaleType(ImageView.ScaleType.CENTER_CROP); ImageView imageView2 = new ImageView(this); imageView2.setImageResource(R.mipmap.jay_jay); imageView2.setScaleType(ImageView.ScaleType.CENTER_CROP); ImageView imageView3 = new ImageView(this); imageView3.setImageResource(R.mipmap.logo); imageView3.setScaleType(ImageView.ScaleType.CENTER_CROP); ImageView imageView4 = new ImageView(this); imageView4.setImageResource(R.mipmap.image2); imageView4.setScaleType(ImageView.ScaleType.CENTER_CROP); ImageView imageView5 = new ImageView(this); imageView5.setImageResource(R.mipmap.jay_jay); imageView5.setScaleType(ImageView.ScaleType.CENTER_CROP); ImageView imageView6 = new ImageView(this); imageView6.setImageResource(R.mipmap.logo); imageView6.setScaleType(ImageView.ScaleType.CENTER_CROP); imageView1.setLayoutParams(lp); imageView2.setLayoutParams(lp); imageView3.setLayoutParams(lp); imageView4.setLayoutParams(lp); imageView5.setLayoutParams(lp); imageView6.setLayoutParams(lp); mImageViews.add(imageView1); mImageViews.add(imageView2); mImageViews.add(imageView3); mImageViews.add(imageView4); mImageViews.add(imageView5); mImageViews.add(imageView6); } class ImagePagerAdapter extends PagerAdapter{ @Override public Object instantiateItem(ViewGroup container, int position) { View img = mImageViews.get(position); container.addView(img); return img; } @Override public int getCount() { return mImageViews.size(); } @Override public boolean isViewFromObject(View view, Object object) { return view == object; } @Override public void destroyItem(ViewGroup container, int position, Object object) { container.removeView((View) object); } } }
(3)circle_normal.xml
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
android:shape="oval">
    <solid
android:color="#d0d7d0"/>
</shape>
(4)circle_selected.xml
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
android:shape="oval">
    <solid
android:color="#f63"/>
</shape>