欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android實現(xiàn)viewpager實現(xiàn)循環(huán)輪播效果

 更新時間:2018年03月28日 17:19:10   作者:姜小輝  
這篇文章主要為大家詳細介紹了Android實現(xiàn)viewpager實現(xiàn)循環(huán)輪播效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下

在網上看到很多利用viewpager實現(xiàn)輪播都是通過設置一個很大的值,讓viewpager開始顯示在這個數值區(qū)間的中間,但這種輪播個人感覺不是真正的輪播,因此自己實現(xiàn)了一個輪播的效果。大致思路是這樣的,假如有5張圖adcde是要輪播展示的,這時創(chuàng)建一個新的集合eadcdea,然后再讓viewpager設置當前展示第一張圖,也就是顯示a。這樣當往左滑時顯示的是e,此時設置viewpager.setCurrentItem(5),當右滑到e的時候在往右滑,此時設置viewpager.setCurrentItem(1),這樣就實現(xiàn)了輪播效果。

效果圖如下所示:

話不多說上一下代碼:

/**
 * viewpager切換頁面時動畫
 */
public class MainActivity extends AppCompatActivity {

  private ViewPager viewPager;
  private ViewPaagerAdapter adapter;
  private ArrayList<View> viewlist=new ArrayList<>();//承載圖片
  private ArrayList<TextView> tvList=new ArrayList<>();//底部圓點集合
  private int []imgList={R.drawable.img8,R.drawable.img1,R.drawable.img2,R.drawable.img3,R.drawable.img4,R.drawable.img5,
      R.drawable.img6, R.drawable.img7,R.drawable.img8,R.drawable.img1};//圖片數組
  boolean isStop=false;
  private LinearLayout line;//小圓圈父視圖
  private ScheduledThreadPoolExecutor executor;

  private int currentPage;
  private Handler handler=new Handler(){
    @Override
    public void handleMessage(Message msg) {
      super.handleMessage(msg);
      switch (msg.what) {
        case 1:
          viewPager.setCurrentItem(msg.arg1);
          break;

        default:
          break;
      }
    }
  };

  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    supportRequestWindowFeature(Window.FEATURE_NO_TITLE);
    setContentView(R.layout.activity_main);
    viewPager= (ViewPager) findViewById(mybanner_viewpager);
    line= (LinearLayout) findViewById(R.id.line);
    setView();//設置輪播顯示的底圖
    adapter=new ViewPaagerAdapter(this,viewlist);
    viewPager.setAdapter(adapter);
    viewPager.setCurrentItem(1);
    viewPager.setOffscreenPageLimit(10);//加這個是為了防止第一張往左滑動會出現(xiàn)閃爍


    startService();//啟動輪播

    viewPager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() {
      @Override
      public void onPageScrolled(final int position, float positionOffset, int positionOffsetPixels) {
        Log.i("tag","位置"+position+"positionOffset"+positionOffset+"positionOffsetPixels"+positionOffsetPixels);
        Log.i("tag","weizhi"+viewPager.getCurrentItem());
        if (position==imgList.length-1) {
          viewPager.setCurrentItem(1,false);

        }else if(viewPager.getCurrentItem()==0&& positionOffsetPixels==0) {
          viewPager.setCurrentItem(imgList.length-2, false);

        }
        currentPage=viewPager.getCurrentItem();
      }

      @Override
      public void onPageSelected(final int position) {
        Log.i("tag","位置wwwww"+position);
        setEnbale();
        if (position==imgList.length-1) {
          tvList.get(0).setEnabled(true);
        }
        else if (position==0) {
          tvList.get(imgList.length-3).setEnabled(true);
        }
        else{
          tvList.get(position-1).setEnabled(true);

        }


      }

      @Override
      public void onPageScrollStateChanged(int state) {


      }
    });


  }


  public void setView() {
    LinearLayout.LayoutParams params=new LinearLayout.LayoutParams(15,15);
    params.leftMargin=10;
    params.rightMargin=10;
    for (int i = 0; i < imgList.length; i++) {
      View view= LayoutInflater.from(this).inflate(R.layout.layout,null,false);

      ImageView img= (ImageView) view.findViewById(R.id.img);
      img.setBackgroundResource(imgList[i]);
      TextView textView= (TextView) view.findViewById(R.id.tv);
      textView.setText(i+"");
      viewlist.add(view);
    }
    for (int i = 0; i < imgList.length-2; i++) {
      TextView view=new TextView(this);
      view.setBackgroundResource(R.drawable.item);


      view.setLayoutParams(params);
      view.setEnabled(false);

      line.addView(view);
      tvList.add(view);

    }
    tvList.get(0).setEnabled(true);

  }

  public void setEnbale(){
    for (TextView tvcycle: tvList) {
      tvcycle.setEnabled(false);
    }
  }

  /**
   * 啟動線程池開啟循環(huán)任務
   */
  public void startService(){
    executor=new ScheduledThreadPoolExecutor(1);
    executor.scheduleWithFixedDelay(runnable,1,2, TimeUnit.SECONDS);

  }

  /**
   * 停止任務
   */
  public void stopService(){
    executor.shutdown();
  }

  Runnable runnable=new Runnable() {
    @Override
    public void run() {

      currentPage=currentPage+1%10;
      Message message= Message.obtain();
      message.what=1;
      message.arg1=currentPage;
      handler.sendMessage(message);



    }
  };

  @Override
  protected void onDestroy() {
    super.onDestroy();
    stopService();

  }
}

實現(xiàn)輪播的重點在這:

 if (position==imgList.length-1) {
          viewPager.setCurrentItem(1,false);

        }else if(viewPager.getCurrentItem()==0&& positionOffsetPixels==0) {
          viewPager.setCurrentItem(imgList.length-2, false);

        }

這里解釋一下onPageScrolled里三個參數的含義,第一個position,這個參數要特別注意一下。當用手指滑動時,如果手指按在頁面上不動,position和當前頁面index是一致的;如果手指向左拖動(相應頁面向右翻動),這時候position大部分時間和當前頁面是一致的,只有翻頁成功的情況下最后一次調用才會變?yōu)槟繕隧撁?;如果手指向右拖動(相應頁面向左翻動),這時候position大部分時間和目標頁面是一致的,只有翻頁不成功的情況下最后一次調用才會變?yōu)樵撁妗?

當直接設置setCurrentItem翻頁時,如果是相鄰的情況(比如現(xiàn)在是第二個頁面,跳到第一或者第三個頁面),如果頁面向右翻動,大部分時間是和當前頁面是一致的,只有最后才變成目標頁面;如果向左翻動,position和目標頁面是一致的。這和用手指拖動頁面翻動是基本一致的。

如果不是相鄰的情況,比如我從第一個頁面跳到第三個頁面,position先是0,然后逐步變成1,然后逐步變成2;我從第三個頁面跳到第一個頁面,position先是1,然后逐步變成0,并沒有出現(xiàn)為2的情況。

positionOffset是當前頁面滑動比例,如果頁面向右翻動,這個值不斷變大,最后在趨近1的情況后突變?yōu)?。如果頁面向左翻動,這個值不斷變小,最后變?yōu)?。positionOffsetPixels是當前頁面滑動像素,變化情況和positionOffset一致。

這里采用線程池開啟了一個循環(huán)任務,線程池的好處不說了,好了到此為止大概實現(xiàn)了viewpager的輪播了。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • Android多媒體應用使用MediaPlayer播放音頻

    Android多媒體應用使用MediaPlayer播放音頻

    這篇文章主要為大家詳細介紹了Android多媒體應用使用MediaPlayer播放音頻,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-12-12
  • 雙緩沖技術實現(xiàn)Android 畫板應用

    雙緩沖技術實現(xiàn)Android 畫板應用

    這篇文章主要介紹了Android 采用雙緩存技術實現(xiàn)畫板應用的相關資料,并附有代碼實例,有需要的小伙伴可以參考下
    2016-07-07
  • Android自定義view實現(xiàn)圓環(huán)進度條效果

    Android自定義view實現(xiàn)圓環(huán)進度條效果

    這篇文章主要為大家詳細介紹了Android自定義view實現(xiàn)圓環(huán)進度條效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • android數據存儲之文件存儲方法

    android數據存儲之文件存儲方法

    本篇文章主要介紹了android數據存儲之文件存儲的方法,具有一定的參考價值,有需要的可以了解一下。
    2016-11-11
  • Android之EditText控制禁止輸入空格和回車

    Android之EditText控制禁止輸入空格和回車

    本文主要介紹了Android中使用EditText控制禁止輸入空格和回車的實現(xiàn)代碼。具有很好的參考價值。下面跟著小編一起來看下吧
    2017-04-04
  • Android自定義可控制速度的跑馬燈

    Android自定義可控制速度的跑馬燈

    這篇文章主要為大家詳細介紹了Android自定義可控制速度的跑馬燈,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-06-06
  • Android 實現(xiàn)單線程輪循機制批量下載圖片

    Android 實現(xiàn)單線程輪循機制批量下載圖片

    這篇文章主要介紹了Android 單線程輪循機制批量下載圖片的相關資料,這里對實現(xiàn)步驟做了詳細介紹,需要的朋友可以參考下
    2017-07-07
  • Android開發(fā)實戰(zhàn)鬧鐘項目

    Android開發(fā)實戰(zhàn)鬧鐘項目

    這篇文章主要介紹了Android開發(fā)實戰(zhàn)鬧鐘項目,根據我們手機鬧鐘設計的一個鬧鐘APP,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-09-09
  • Android之自定義實現(xiàn)BaseAdapter(通用適配器二)

    Android之自定義實現(xiàn)BaseAdapter(通用適配器二)

    這篇文章主要為大家詳細介紹了Android之自定義實現(xiàn)BaseAdapter通用適配器第二篇,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-08-08
  • Android Web3j OOM解決詳解

    Android Web3j OOM解決詳解

    這篇文章主要介紹了Android Web3j OOM解決詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-07-07

最新評論