Skip to content
forked from lozn00/Banner

布局可xml定制任意布局的banner控件,不仅局限于图片轮播哦,轻松解决各种需求。Android广告图片轮播控件,支持无限循环和多种主题,可以灵活设置轮播样式、动画、轮播和切换时间、位置、图片加载框架 以及视频轮播等!

Notifications You must be signed in to change notification settings

vimforscheme/Banner

 
 

Repository files navigation

AutoScrolll Bannaer

这是一个轮播图,使用viewpager实现页面的滑动,使用postDelay实现自调循环

可以显示标题,也可以显示总数点,效果图可以下载下来试试 就知道啦!

使用方法

Jcenter gradle 目标sdk25.0.3

 compile 'cn.qssq666:banner:v0.4'
 
 
    <cn.qssq666.banner.Banner
        android:id="@+id/asl"
        android:layout_width="match_parent"
        android:layout_height="150dp"></cn.qssq666.banner.Banner>

jcenter 最新改版出现了毛病推荐使用github的方式 在repositories {}节点加入

Add it in your root build.gradle at the end of repositories: 在根目录build.gradle或者项目build.gralde 的repositories 加上。 maven { url 'https://jitpack.io' }

	allprojects {
		repositories {
			...
			maven { url 'https://jitpack.io' }
		}
	}

Step 2. Add the dependency 添加依赖

	dependencies {
	     compile 'com.github.qssq:Banner:v1.0'
	}

Step 3. 然而这也许不是最新版,请点击https://github.com/qssq/Banner/releases 查看释放版本,然后修改上面的v1.0 为你看到的最新版

图片演示

演示图片地址

kotlin banner

https://github.com/qssq/kotlinbanner

常用方法

    banner.setPointSize(8);//dp
        banner.setPointMargin(20);//dp
        banner.setItem(listImgInfo);
        banner.setEnableAutoScroll(true);//如果不设置无法自动滚动,调用startAutoScroll()会抛出异常,这主要是用来解决触摸停止滚动立刻屏幕恢复滚动设置的标记,如果你的业务滚动需要请告诉它!
        banner.setScrollTime(1000);
    banner.startAutoScroll();
   banner.getViewPager().setPageTransformer(false, transformer);
   

本库的优点

优点就是布局diy基于布局文件的,这是别人的banner库最大的痛处,这个痛处导致稍微变通一下就没法解决了,这不是需求的变态,而是库写的不好,文档写的那么花哨,很多点赞,却坑了很多人,这是何必呢? 所以各位多多给我点赞吧! 只需要创建一个一模一样的view_auto_scroll_layout 稍微调整一下就可以了,或者继承该类,因为可以这样,什么需求还做不到?能滚动的各种view都通通可以。

后续更新

2017年7月19日 18:03:30 不需要实现imageUrl,因为banner基于view, 所以 图片加载部分直接又用户构思, 不会用的朋友可以跑demo.MainActivity.this有介绍

吐槽

受够了别人的banner库,banner多扩展差劲,bugN多 ,也是醉了, ok ,本banner非常精简没有那么多垃圾代码,而且无bug,接口形式 非常容易扩展,你要的动画翻页都有。 完全可以自定义任意指示器 标题栏布局 支持自己拿Viewpager,方便用户进行更多操作。甚至包括修改轮播逻辑。

常见调整

隐藏指示点 隐藏标题 ,

  banner.setNeedPoint(true);
 banner.setNeedTitle(true);
           

变态需求与解决方案

场景一 给指示器搞特效

让指示器或 标题在外部非viewpager区域显示需求 so easy ,只需要保持id什么一样就行了,所以复制一份R.layout.view_auto_scroll_layout然后把指示器容器布局弄到外面就行,然后继承Banner类复写getLayout 方法,因为指示器是根据findById来的,所以这个需求不在话下。 或者直接直接复制一个到自己的项目中,也行,android studio默认识别宿主项目 的布局文件,切记别把id给删除了。

场景二 给标题搞特效

自由通过Xml调整布局,比如让标题发生一下旋转,倒影,或者描边, 总所周知,通过xml调节的方法更亲民,扩展性更好,因此解决方案就是场景1 采用接口形式 非常容易扩展 抽出轮播view里面的布局,也就是说你可以不是图片,那么这个代码自己写就好

场景三 微调

    //你能拿到这个对象 你还不知道怎么调间距吗?xml 或者 代码编写 都可以.你喜欢哪个姿势呢?

/* TextView titleView = banner.getTitleView(); ViewGroup titleGroup = banner.getTitleGroup(); LinearLayout pointViewGroup = banner.getPointViewGroup();*/

场景四

让指示点的选中和被选中是图片 ok,我已经提供了继承方法, protected View onCreatePointView(IImgInfo info, int size, int margin) 你只需要`集成复写就行 对于选中 和不选中 复写这个方法就行 。

    protected void onSelect(int position) {
        mPointContainer.getChildAt(position).setEnabled(false);
    }


    protected void onCancelSelect(int position) {
        mPointContainer.getChildAt(position).setEnabled(true);
    }

demo代码

  super.onCreate(savedInstanceState);
       setContentView(R.layout.activity_main);
       imageLoader = ImageLoader.getInstance();
       imageLoader.init(ImageLoaderConfiguration.createDefault(this));
       banner = (Banner) findViewById(R.id.asl);
       final List<MyImageInfo> listImgInfo = new ArrayList<MyImageInfo>();
       listImgInfo.add(new MyImageInfo("图片1", "http://pic.ffpic.com/files/2012/1109/1106fengyeer07.jpg"));
       listImgInfo.add(new MyImageInfo("美女2", "http://f.hiphotos.baidu.com/image/pic/item/a044ad345982b2b725c274ca33adcbef76099b5b.jpg"));
       listImgInfo.add(new MyImageInfo("美女3", "http://a.hiphotos.baidu.com/image/pic/item/7a899e510fb30f24a23edc1cca95d143ad4b030c.jpg"));
       listImgInfo.add(new MyImageInfo("美女4", "http://g.hiphotos.baidu.com/image/pic/item/bd3eb13533fa828b38f1a605f91f4134960a5a01.jpg"));

       banner.setPointSize(8);//dp
       banner.setPointMargin(20);//dp
       //你能拿到这个对象 你还不知道怎么调间距吗?xml 或者 代码编写 都可以.你喜欢哪个姿势呢?
  /*     TextView titleView = banner.getTitleView();
       ViewGroup titleGroup = banner.getTitleGroup();
       LinearLayout pointViewGroup = banner.getPointViewGroup();*/

       banner.setItem(listImgInfo);
       banner.setAutoScroll(true);
       banner.setScrollTime(1000);
       banner.setBindHolderProvider(new Banner.OnViewBindHolderProvider<MyImageInfo>() {
           @Override
           public View onCreateView(ViewGroup group, MyImageInfo model, int position) {
               ImageView imageView = new ImageView(group.getContext());
               ViewPager.LayoutParams params = new ViewPager.LayoutParams();
               params.height = ViewGroup.LayoutParams.MATCH_PARENT;
               params.width = ViewGroup.LayoutParams.MATCH_PARENT;
               imageView.setLayoutParams(params);
               imageView.setScaleType(ImageView.ScaleType.CENTER_CROP);
               ImageLoader.getInstance().displayImage(model.getImageUrl(), imageView);
               return imageView;
           }
       });

       banner.setNeedPoint(true);
       banner.setNeedTitle(true);

       banner.setOnItemClickListener(new Banner.OnItemClickListener() {
           @Override
           public void onClick(int index) {
               MyImageInfo iImgInfo = listImgInfo.get(index);
               Toast.makeText(MainActivity.this, "你点击了" + iImgInfo.getBannerTitle(), Toast.LENGTH_SHORT).show();


           }
       });
       ArrayList<Class<? extends ViewPager.PageTransformer>> anims = new ArrayList<>();
//        anims.add(DefaultTransformer.class);
       anims.add(AccordionTransformer.class);
       anims.add(BackgroundToForegroundTransformer.class);

       anims.add(ForegroundToBackgroundTransformer.class);
//        anims.add(CubeInTransformer.class);
       anims.add(CubeOutTransformer.class);
       anims.add(DepthPageTransformer.class);
//        anims.add(FlipHorizontalTransformer.class);
//        anims.add(FlipVerticalTransformer.class);
       anims.add(RotateDownTransformer.class);
       anims.add(RotateUpTransformer.class);
       anims.add(ScaleInOutTransformer.class);
       anims.add(StackTransformer.class);
//        anims.add(TabletTransformer.class);
       anims.add(ZoomInTransformer.class);
       anims.add(ZoomOutTranformer.class);
       anims.add(ZoomOutSlideTransformer.class);
       Class<? extends ViewPager.PageTransformer> aClass = anims.get(new Random().nextInt(anims.size()));
       ViewPager.PageTransformer transformer = null;
       try {
           transformer = aClass.newInstance();
           banner.getViewPager().setPageTransformer(false, transformer);//荣国动画白屏请删除此代码
       } catch (InstantiationException e) {
           e.printStackTrace();
       } catch (IllegalAccessException e) {
           e.printStackTrace();
       }

       banner.startAutoScroll();
       Log.w(TAG, aClass.getSimpleName());


生命周期控制

@Override
protected void onResume() {
   super.onResume();
   banner.startAutoScroll();
}


@Override
protected void onPause() {

super.onPause();
banner.stopAutoScroll();
}

`

另外当手触摸的时候就不会继续滚动了,松开手就会。

轮播图的方式从0->总数 然后逆向回来,那种无限循环实际上网上的项目都有bug,为了提供一个完全无bug兼容对话框里面的布局等 设计,我就自己写了这个。

    maven {//MagicIndicator
        url "https://jitpack.io"

    }
    maven { url "http://maven.restlet.org" }

About

布局可xml定制任意布局的banner控件,不仅局限于图片轮播哦,轻松解决各种需求。Android广告图片轮播控件,支持无限循环和多种主题,可以灵活设置轮播样式、动画、轮播和切换时间、位置、图片加载框架 以及视频轮播等!

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Java 100.0%