Android App 에서 Handler 로 ViewPager 페이지 자동 전환

많은 전자상거래 홈 페이지 와 app 에서 자동 으로 전환 되 는 상품 의 홍보 가 빠 르 고 체험 이 좋 은 것 같 습 니 다.마침 오늘 은 ViewPager 를 사용 하 는 것 을 배 웠 기 때문에 비슷 한 기능 을 가 진 demo 도 실현 되 었 습 니 다.
다음은 그 중의 두 개의 캡 처 입 니 다.
2016517184555197.jpg (241×383) 2016517184629006.jpg (241×382)
자동 재생 기능 을 실현 하 는 ViewPager 는 주로 다음 과 같은 몇 가지 부분 을 해 야 합 니 다.
ViewPager Adapter 를 실현 하여 ViewPager 에 전시 내용 을 제공 합 니 다(예 를 들 어 위의 고양이 사진 두 장).

 public class ViewPagerAdapter extends PagerAdapter {
    private List<View> mData;
    public ViewPagerAdapter(List<View> mData) {
      this.mData = mData;
    }

    @Override
    public int getCount() {
      return mData.size();
    }

    @Override
    public boolean isViewFromObject(View arg0, Object arg1) {
      return arg0 == arg1;
    }
    
    @Override
    public Object instantiateItem(ViewGroup container, int position) {
      View v = mData.get(position);
      container.addView(v);
      return v;
    }
    
    @Override
    public void destroyItem(ViewGroup container, int position, Object object) {
//  super.destroyItem(container, position, object);
      container.removeView(mData.get(position));
    }
    
  }

OnPageChangeListener 를 실현 합 니 다.이렇게 하면 페이지 전환 후 현재 페이지 가 있 는 위 치 를 알려 줍 니 다.(예 를 들 어 위의 그림 에서 왼쪽 아래 에 있 는 3 개의 원점,빨간색 은 현재 페이지 를 표시 합 니 다)

 private class ViewPageChangeListener implements OnPageChangeListener {

    @Override
    public void onPageScrollStateChanged(int arg0) {
    }

    @Override
    public void onPageScrolled(int arg0, float arg1, int arg2) {
    }

    //           viewIndicator      
    @Override
    public void onPageSelected(int arg0) {
      int len = viewIndicator.getChildCount();
      for(int i = 0; i < len; ++i)
        viewIndicator.getChildAt(i).setBackgroundResource(R.drawable.tip_normal);
      viewIndicator.getChildAt(arg0).setBackgroundResource(R.drawable.tip_select);
    }
    
  }

일정 시간 간격 으로 UI 를 수정 하 는 Handler 구현(현재 표 시 된 그림 을 다음 으로 전환)

private Handler mHandler = new Handler() {
    public void handleMessage(android.os.Message msg) {
      switch(msg.what) {
      case 1:
        int totalcount = pagers.size();//autoChangeViewPager.getChildCount();
        int currentItem = autoChangeViewPager.getCurrentItem();
        
        int toItem = currentItem + 1 == totalcount ? 0 : currentItem + 1;
        
        Log.i(TAG, "totalcount: " + totalcount + "  currentItem: " + currentItem + "  toItem: " + toItem);
        
        autoChangeViewPager.setCurrentItem(toItem, true);
        
        //        message,    viewPager    
        this.sendEmptyMessageDelayed(1, 2000);
      }
    }
  };

위의 3 단 은 주요 코드 입 니 다.이 외 에 도 onResume()에서 시작 message 를 보 내 고 onStop()에서 ViewPager 페이지 의 자동 전환 을 중지 하 는 등 내용 이 필요 합 니 다.
전체 코드 는 다음 과 같 습 니 다:

public class MainActivity extends Activity {
  private static final String TAG = MainActivity.class.getSimpleName();
  private ViewPager autoChangeViewPager;
  
  //              
  private LinearLayout viewIndicator;
  
  //    ViewPager      
  private List<View> pagers;
  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    
    autoChangeViewPager = (ViewPager) findViewById(R.id.autoVP);
    viewIndicator = (LinearLayout) findViewById(R.id.vpindicator);
    
    initAdapter();
    
    //           viewIndicator      
    autoChangeViewPager.setOnPageChangeListener(new ViewPageChangeListener());
    
  }
  
  private void initAdapter() {
    //   viewPager        
    int[] imgs = {R.drawable.i1, R.drawable.i2, R.drawable.i3};
    
    //init pagers;
    pagers = new ArrayList<View>();
    LinearLayout.LayoutParams img_params = new LayoutParams(
        LayoutParams.MATCH_PARENT, LayoutParams.MATCH_PARENT
        );
    for(int i = 0; i < imgs.length; ++i) {
      ImageView iv = new ImageView(this);
      iv.setBackgroundResource(imgs[i]);
      iv.setLayoutParams(img_params);
      final int index = i;
      iv.setOnClickListener(new OnClickListener() {
        // viewPager        ,     activity
        @Override
        public void onClick(View v) {
          Intent i = new Intent(MainActivity.this, InvokedActivity.class);
          i.putExtra("name", "cat " + index);
          MainActivity.this.startActivity(i);
        }
      });
      pagers.add(iv);
    }
    autoChangeViewPager.setAdapter(new ViewPagerAdapter(pagers));
    
    //init indicator
    LinearLayout.LayoutParams ind_params = new LayoutParams(
        LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT
        );
    for(int i = 0; i < imgs.length; ++i) {
      ImageView iv = new ImageView(this);
      if(i == 0)
        iv.setBackgroundResource(R.drawable.tip_select);
      else
        iv.setBackgroundResource(R.drawable.tip_normal);
      iv.setLayoutParams(ind_params);
      viewIndicator.addView(iv);
    }
  }
  
  @Override
  protected void onResume() {
    super.onResume();
    //activity      ,    message,   viewPager          
    mHandler.sendEmptyMessageDelayed(1, 2000);
  }
  
  @Override
  protected void onStop() {
    super.onStop();
    //  viewPager        
    mHandler.removeMessages(1);
  }

  public class ViewPagerAdapter extends PagerAdapter {
    private List<View> mData;
    public ViewPagerAdapter(List<View> mData) {
      this.mData = mData;
    }

    @Override
    public int getCount() {
      return mData.size();
    }

    @Override
    public boolean isViewFromObject(View arg0, Object arg1) {
      return arg0 == arg1;
    }
    
    @Override
    public Object instantiateItem(ViewGroup container, int position) {
      View v = mData.get(position);
      container.addView(v);
      return v;
    }
    
    @Override
    public void destroyItem(ViewGroup container, int position, Object object) {
//  super.destroyItem(container, position, object);
      container.removeView(mData.get(position));
    }
    
  }
  
  private class ViewPageChangeListener implements OnPageChangeListener {

    @Override
    public void onPageScrollStateChanged(int arg0) {
    }

    @Override
    public void onPageScrolled(int arg0, float arg1, int arg2) {
    }

    //           viewIndicator      
    @Override
    public void onPageSelected(int arg0) {
      int len = viewIndicator.getChildCount();
      for(int i = 0; i < len; ++i)
        viewIndicator.getChildAt(i).setBackgroundResource(R.drawable.tip_normal);
      viewIndicator.getChildAt(arg0).setBackgroundResource(R.drawable.tip_select);
    }
    
  }
  
  private Handler mHandler = new Handler() {
    public void handleMessage(android.os.Message msg) {
      switch(msg.what) {
      case 1:
        int totalcount = pagers.size();//autoChangeViewPager.getChildCount();
        int currentItem = autoChangeViewPager.getCurrentItem();
        
        int toItem = currentItem + 1 == totalcount ? 0 : currentItem + 1;
        
        Log.i(TAG, "totalcount: " + totalcount + "  currentItem: " + currentItem + "  toItem: " + toItem);
        
        autoChangeViewPager.setCurrentItem(toItem, true);
        
        //        message,    viewPager    
        this.sendEmptyMessageDelayed(1, 2000);
      }
    }
  };
}

레이아웃 파일 은 다음 과 같 습 니 다.(위의 코드 에 있 는 Invoked Activity 는 매우 간단 합 니 다.여 기 는 생략 합 니 다)

<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
  android:layout_width="match_parent"
  android:layout_height="match_parent" >

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

  <LinearLayout
    android:id="@+id/vpindicator"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_gravity="bottom"
    android:orientation="horizontal" />

</FrameLayout>


좋은 웹페이지 즐겨찾기