Flyco大神的Android View轮播控件使用简单方便,属性丰富,扩展性强。项目地址:https://github.com/H07000223/FlycoBanner_Master
只是控件有些时间没有更新了,现在需求是一张图片不能滚动,我们只有改改大神的代码了
我们找到类BaseBanner,找到protected ViewPager mViewPager;所以我们要修改ViewPager,当只有一张的时候我们不滚动
1.创建一个可以禁止滑动的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);
}
}
这样就完成了