国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 系統 > Android > 正文

RollViewPager圖片輪播效果開源框架使用方法詳解

2019-10-22 18:24:48
字體:
來源:轉載
供稿:網友

RollViewPager是一個自動輪播的Viewpager,支持無限循環。 觸摸時會暫停播放,直到結束觸摸一個延遲周期以后繼續播放。 看起來就像這樣。指示器可以為點可以為數字還可以自定義,位置也可以變。

附上RollViewPager Github地址:https://github.com/Jude95/RollViewPager

使用Android Studio開發在gradle添加依賴:

compile 'com.jude:rollviewpager:1.4.5'

在布局文件當中使用:

<com.jude.rollviewpager.RollPagerView  android:layout_width="match_parent"  android:layout_height="180dp"  app:rollviewpager_play_delay="3000"/>

要使用到RollViewPager自定義屬性的時候,在布局文件當中我們必須添加:

xmlns:app="http://schemas.android.com/apk/res-auto

RollPagerView自定義屬性:

app:rollviewpager_play_delay="3000" 播放間隔時間,單位ms。填0則不播放。默認為0 app:rollviewpager_hint_gravity="center" 指示器位置,提供left,center,right。默認center
app:rollviewpager_hint_color="#7c7c7c" 指示器背景顏色.默認黑色
app:rollviewpager_hint_alpha="80" 指示器背景透明度。0全透明,255不透明。默認0.
app:rollviewpager_hint_paddingLeft="16dp" 指示器左邊距
app:rollviewpager_hint_paddingRight="16dp" 指示器右邊距
app:rollviewpager_hint_paddingTop="16dp" 指示器上邊距
app:rollviewpager_hint_paddingBottom="16dp" 指示器下邊距

一般指定一下間隔時間。

RollViewPager提供了自定義指示器的類:HintView 用法

參數說明:上下文,當前輪播圖指示器圖片 默認指示器圖片
mRollViewPager.setHintView(new IconHintView(this,R.drawable.point_focus,R.drawable.point_normal));
mRollViewPager.setHintView(new ColorPointHintView(this, Color.YELLOW,Color.WHITE));
mRollViewPager.setHintView(new TextHintView(this));
mRollViewPager.setHintView(null);//隱藏指示器

設置點擊事件:

pagerView.setOnItemClickListener(new OnItemClickListener() {      @Override      public void onItemClick(int position) {        Toast.makeText(MainActivity.this,""+position,Toast.LENGTH_SHORT).show();      }    });

提供以下三種種方便的PagerAdapter供使用。

本ViewPager也可以使用其他任意PagerAdapter。

StaticPagerAdapter:

存儲頁面的Adapter。view添加進去就存儲不會再次getView,減少頁面創建消耗,消耗內存。一般自動播放的情況這種方案比較好。不然會大量構造View。 概念參照FragmentPagerAdapter??梢杂糜谄渌鸙iewPager。

class MyPagerAdapter extends StaticPagerAdapter {    private int[] image = {R.mipmap.one, R.mipmap.two, R.mipmap.three, R.mipmap.four};    // SetScaleType(ImageView.ScaleType.CENTER_CROP);    // 按比例擴大圖片的size居中顯示,使得圖片長(寬)等于或大于View的長(寬)    @Override    public View getView(ViewGroup container, int position) {      ImageView imageView = new ImageView(container.getContext());      imageView.setImageResource(image[position]);      imageView.setScaleType(ImageView.ScaleType.CENTER_CROP);      imageView.setLayoutParams(new ViewGroup.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT));      return imageView;    }    @Override    public int getCount() {      return image.length;    }  }

DynamicPagerAdapter (跟以上Adapter用法一樣)
動態的Adapter。當創建3號view時會銷毀1號view(遞推),會時常調用getView。增加頁面創建消耗,減小內存消耗。 概念參照FragmentStatePagerAdapter。可以用于其他ViewPager。

LoopPagerAdapter

無限循環的Adapter。無限循環上采用的是getCount返回int大數的方法(并沒有什么缺點,另外估計1s的間隔時間你在有生之年看不到他播放到底)。實測比第N頁跳轉到第1頁的效果好。

數據采用StaticPagerAdapter的方案。節省創建View開銷。 本Adapter只能用于本RollViewPager;

無需其他設置,很簡單。

mRollViewPager.setAdapter(new TestLoopAdapter(mRollViewPager));private class TestLoopAdapter extends LoopPagerAdapter{  private int[] imgs = {      R.drawable.img1,      R.drawable.img2,      R.drawable.img3,      R.drawable.img4,  };  public TestLoopAdapter(RollPagerView viewPager) {    super(viewPager);  }  @Override  public View getView(ViewGroup container, int position) {    ImageView view = new ImageView(container.getContext());    view.setImageResource(imgs[position]);    view.setScaleType(ImageView.ScaleType.CENTER_CROP);    view.setLayoutParams(new ViewGroup.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT));    return view;  }  @Override  public int getRealCount() {    return imgs.length;  }}

播放控制

rollViewPager.pause()rollViewPager.resume()rollViewPager.isPlaying()

MainActivity代碼:

public class MainActivity extends AppCompatActivity {  private RollPagerView pagerView;  @Override  protected void onCreate(Bundle savedInstanceState) {    super.onCreate(savedInstanceState);    setContentView(R.layout.activity_main);    pagerView = (RollPagerView) findViewById(R.id.rollPagerView);    //設置適配器    pagerView.setAdapter(new MyPagerAdapter());    pagerView.setOnItemClickListener(new OnItemClickListener() {      @Override      public void onItemClick(int position) {        Toast.makeText(MainActivity.this,""+position,Toast.LENGTH_SHORT).show();      }    });    //對指示器的自定義 參數說明:上下文,當前輪播圖指示器圖片 默認指示器圖片//    pagerView.setHintView(new IconHintView(this,R.mipmap.ic_launcher,R.mipmap.fouse));  }  class MyPagerAdapter extends StaticPagerAdapter {    private int[] image = {R.mipmap.one, R.mipmap.two, R.mipmap.three, R.mipmap.four};    // SetScaleType(ImageView.ScaleType.CENTER_CROP);    // 按比例擴大圖片的size居中顯示,使得圖片長(寬)等于或大于View的長(寬)    @Override    public View getView(ViewGroup container, int position) {      ImageView imageView = new ImageView(container.getContext());      imageView.setImageResource(image[position]);      imageView.setScaleType(ImageView.ScaleType.CENTER_CROP);      imageView.setLayoutParams(new ViewGroup.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT));      return imageView;    }    @Override    public int getCount() {      return image.length;    }  }}

xml代碼:

<?xml version="1.0" encoding="utf-8"?><RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"  xmlns:app="http://schemas.android.com/apk/res-auto"  android:layout_width="match_parent"  android:layout_height="match_parent">  <!--rollviewpager_play_delay 播放時間間隔默認為0-->  <com.jude.rollviewpager.RollPagerView    android:layout_width="match_parent"    android:layout_height="150dp"    android:id="@+id/rollPagerView"    app:rollviewpager_play_delay="3000"    >  </com.jude.rollviewpager.RollPagerView></RelativeLayout>

附上效果圖:

RollViewPager,圖片輪播

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


注:相關教程知識閱讀請移步到Android開發頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 林芝县| 温州市| 富阳市| 广汉市| 随州市| 偏关县| 苏尼特右旗| 山东省| 灵宝市| 石河子市| 封丘县| 桃源县| 婺源县| 永昌县| 田东县| 泌阳县| 东乡族自治县| 云安县| 德州市| 乌鲁木齐县| 海城市| 舒兰市| 富源县| 东源县| 平阳县| 九寨沟县| 沙洋县| 贵定县| 康保县| 锡林郭勒盟| 桑日县| 台湾省| 汉中市| 康马县| 博客| 道孚县| 崇仁县| 洛扎县| 绥芬河市| 墨竹工卡县| 大埔县|