圖片輪播算是我們用的比較多的一個功能,我之前也寫過類似的文章(http://blog.csdn.net/double2hao/article/details/48896297),但是說實話自己寫並不是特別方便,而且往往bug會比較多。而在github上有一些大神專門寫了viewpager的輪播框架並且開源,供大家學習參考,這篇博客就教大家如何簡單地使用開源框架RollViewPager。
對RollViewPager有興趣,或者希望更深入學習的可以直接去github下載源碼學習:https://github.com/Jude95/RollViewPager
效果:(源碼在文章結尾)
主要支持的一些功能:
支持無限循環。 觸摸時會暫停播放,直到結束觸摸一個延遲週期以後繼續播放。 看起來就像這樣。指示器可以爲點可以爲數字還可以自定義,位置也可以變。
主要操作過程:
1、在gradle中導入包:
1
|
compile 'com.jude:rollviewpager:1.2.9' |
效果如圖:
2、設置播放時間間隔、透明度、指示器(指示器可以是默認原點,數字,也可以自定義圖片)
3、設置適配器,本demo中是StaticPagerAdapter,這個比較簡單,用的比較多,有其他需要的可以看github源碼。
主要需要設置圖片、圖片數量等等。
MainActivity:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
|
package com.example.double2.rollviewpagertest; import android.graphics.Color; import android.os.Bundle; import android.support.v7.app.AppCompatActivity; import android.view.Menu; import android.view.MenuItem; import android.view.View; import android.view.ViewGroup; import android.widget.ImageView; import com.jude.rollviewpager.RollPagerView; import com.jude.rollviewpager.adapter.StaticPagerAdapter; import com.jude.rollviewpager.hintview.ColorPointHintView; public class MainActivity extends AppCompatActivity { private RollPagerView mRollViewPager; @Override protected void onCreate(Bundle savedInstanceState) { super .onCreate(savedInstanceState); setContentView(R.layout.activity_main); mRollViewPager = (RollPagerView) findViewById(R.id.roll_view_pager); //設置播放時間間隔 mRollViewPager.setPlayDelay( 1000 ); //設置透明度 mRollViewPager.setAnimationDurtion( 500 ); //設置適配器 mRollViewPager.setAdapter( new TestNormalAdapter()); //設置指示器(順序依次) //自定義指示器圖片 //設置圓點指示器顏色 //設置文字指示器 //隱藏指示器 //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); } private class TestNormalAdapter extends StaticPagerAdapter { private int [] imgs = { R.drawable.img1, R.drawable.img2, R.drawable.img3, R.drawable.img4, }; @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 getCount() { return imgs.length; } } } |
activity_main:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
<? xml version = "1.0" encoding = "utf-8" ?> android:layout_width = "match_parent" android:layout_height = "match_parent" tools:context = ".MainActivity" > < com.jude.rollviewpager.RollPagerView android:id = "@+id/roll_view_pager" android:layout_width = "match_parent" android:layout_height = "180dp" app:rollviewpager_play_delay = "3000" /> </ RelativeLayout > |