Flyco大神的Android View輪播控件使用簡單方便,屬性豐富,擴展性強。項目地址:https://github.com/H07000223/FlycoBanner_Master
只是控件有些時間沒有更新了,現(xiàn)在需求是一張圖片不能滾動,我們只有改改大神的代碼了
我們找到類BaseBanner,找到protected ViewPager mViewPager;所以我們要修改ViewPager,當只有一張的時候我們不滾動
1.創(chuàng)建一個可以禁止滑動的ViewPager
public class NoScrollViewPager extends ViewPager {
private boolean noScroll = false;
public NoScrollViewPager(Context context, AttributeSet attrs) {
super(context, attrs);
// TODO Auto-generated constructor stub
}
public NoScrollViewPager(Context context) {
super(context);
}
/**
* 供外部調用的方法:設置是否可以滑動
* @param noScroll true:表示禁止滑動,false:表示可以滑動
*/
public void setNoScroll(boolean noScroll) {
this.noScroll = noScroll;
}
@Override
public void scrollTo(int x, int y) {
super.scrollTo(x, y);
}
@Override
public boolean onTouchEvent(MotionEvent arg0) {
/* return false;//super.onTouchEvent(arg0); */
if (noScroll)
return false;
else
return super.onTouchEvent(arg0);
}
/**
* 返回true:表示攔截
* 返回false:表示不攔截
* @param arg0
* @return
*/
@Override
public boolean onInterceptTouchEvent(MotionEvent arg0) {
if (noScroll)
return false;
else
return super.onInterceptTouchEvent(arg0);
}
@Override
public void setCurrentItem(int item, boolean smoothScroll) {
super.setCurrentItem(item, smoothScroll);
}
@Override
public void setCurrentItem(int item) {
super.setCurrentItem(item);
}
}
2.把BaseBanner里的ViewPager換成NoScrollViewPager
3.在setViewPager()方法中,添加判斷
if (mDatas.size() <= 1){
mViewPager.setNoScroll(true);
}
4.在startScroll()中修改,只有大于一張圖才顯示小點
if (mDatas.size() > 1){
//create indicator
View indicatorViews = onCreateIndicator();
if (indicatorViews != null) {
mLlIndicatorContainer.removeAllViews();
mLlIndicatorContainer.addView(indicatorViews);
}
}
這樣就完成了