Banner图片轮播

 添加依赖

compile 'com.youth.banner:banner:1.4.8'

在AndroidManifest.xml清单文件中添加权限
<!-- if you want to load images from the internet -->
<uses-permission android:name="android.permission.INTERNET" />
<!-- if you want to load images from a file OR from the internet -->
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />

在主布局文件文件中添加Banner,可以设置自定义属性
<com.youth.banner.Banner
xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/banner"
android:layout_width="match_parent"
android:layout_height="300dp" />
private Banner banner;
private List<String> mListImage, mListTitle;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    //实例化Banner
banner = (Banner) findViewById(R.id.banner);
    //设置Banner样式
banner.setBannerStyle(BannerConfig.CIRCLE_INDICATOR_TITLE_INSIDE);
    //设置图片加载器
banner.setImageLoader(new GlideImageLaoder());
    //实例化图片集合
mListImage = new ArrayList<>();
    //将图片放入集合中
mListImage.add("http://img3.imgtn.bdimg.com/it/u=3823223463,3047520970&fm=23&gp=0.jpg");
    mListImage.add("http://img.hc360.com/auto-a/info/images/200803/8998419-10.jpg");
    mListImage.add("http://img.ichemo.cn/model/5188ebc96c74dd.jpg");
    mListImage.add("http://img0.imgtn.bdimg.com/it/u=2631448432,2817427988&fm=214&gp=0.jpg");
    mListImage.add("http://i.ebayimg.com/00/s/MzU1WDcwOQ==/%24%28KGrHqR,%21hYFDuguSMpNBQ8e+seDCQ~~60_1.JPG?set_id=880000500F");
    //设置Banner图片集合
banner.setImages(mListImage);
    //设置Banner动画效果
banner.setBannerAnimation(Transformer.DepthPage);
    //实例化Title集合
mListTitle = new ArrayList<>();
    //将标题放入集合
mListTitle.add("第一张图片");
    mListTitle.add("第二张图片");
    mListTitle.add("第三张图片");
    mListTitle.add("第四张图片");
    mListTitle.add("第五张图片");
    //设置Banner标题集合(当banner样式有显示title时)
banner.setBannerTitles(mListTitle);
    //设置轮播时间
banner.setDelayTime(1000);
    //设置指示器位置(当banner模式中有指示器时)
banner.setIndicatorGravity(BannerConfig.CIRCLE_INDICATOR_TITLE_INSIDE);
    //Banner设置方法全部调用完毕时最后调用
banner.start();
}
public class GlideImageLoader extends ImageLoader {
    @Override
    public void displayImage(Context context, Object path, ImageView imageView) {
        /**
         注意:
         1.图片加载器由自己选择,这里不限制,只是提供几种使用方法
         2.返回的图片路径为Object类型,由于不能确定你到底使用的那种图片加载器,
         传输的到的是什么格式,那么这种就使用Object接收和返回,你只需要强转成你传输的类型就行,
         切记不要胡乱强转!
         */
        //第一种方法:Glide 加载图片简单用法
     //Glide.with(context).load(path).into(imageView);

        //第二种方法:Picasso 加载图片简单用法
        //Picasso.with(context).load(path).into(imageView);
        //第三种方法:fresco加载图片简单用法,记得要写下面的createImageView方法
        Uri uri = Uri.parse((String) path);
        imageView.setImageURI(uri);
}

    //提供createImageView 方法,如果不用可以不重写这个方法,主要是方便自定义ImageView的创建
@Override
    public ImageView createImageView(Context context) {
        //使用fresco,需要创建它提供的ImageView,当然你也可以用自己自定义的具有图片加载功能的ImageView
        SimpleDraweeView simpleDraweeView=new SimpleDraweeView(context);
     return simpleDraweeView;
    }
}




一定要和Fresco加载图片使用