040_Android Banner框架

Banner Android轮播图框架

Github地址:https://github.com/youth5201314/banner

简单使用:布局文件

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity">

    <com.youth.banner.Banner
        android:id="@+id/banner"
        android:layout_width="match_parent"
        android:layout_height="280dp"/>

</LinearLayout>

MainActivity

package com.example.banner;

import android.content.Context;
import android.os.Bundle;
import android.widget.ImageView;

import androidx.appcompat.app.AppCompatActivity;

import com.alibaba.fastjson.JSON;
import com.bumptech.glide.Glide;
import com.lzy.okgo.OkGo;
import com.lzy.okgo.callback.StringCallback;
import com.lzy.okgo.model.Response;
import com.youth.banner.Banner;
import com.youth.banner.BannerConfig;
import com.youth.banner.loader.ImageLoader;

import java.util.ArrayList;
import java.util.List;

public class MainActivity extends AppCompatActivity {
    private List<String> picList, titleList;
    private Banner banner;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        initView();
        OkGo.<String>get("http://vueshop.glbuys.com/api/home/index/slide?token=1ec949a15fb709370f").execute(new StringCallback() {
            @Override
            public void onSuccess(Response<String> response) {
                PicBean picBean = JSON.parseObject(response.body(), PicBean.class);
                for (PicBean.DataBean dataBean : picBean.getData()) {
                    picList.add("http:" + dataBean.getImage());
                    titleList.add(dataBean.getTitle());
                }
                //设置图片资源
                banner.setImages(picList);
                //设置图片加载器
                banner.setImageLoader(new ImageLoader() {
                    @Override
                    public void displayImage(Context context, Object path, ImageView imageView) {
                        //使用Glide框架加载图片
                        Glide.with(context).load(path).into(imageView);
                    }
                });
                //设置图片标题
                banner.setBannerTitles(titleList);
                //设置轮播图样式 默认是小圆点它不需要标题
                banner.setBannerStyle(BannerConfig.CIRCLE_INDICATOR_TITLE);
                //设置轮播时间
                banner.setDelayTime(2000);
                //开始轮播
                banner.start();
            }
        });

    }

    private void initView() {
        banner = (Banner) findViewById(R.id.banner);
        picList = new ArrayList<>();
        titleList = new ArrayList<>();
    }
}

 

 

效果图

8917395-23b50f58269a2b50.gif

Banner效果图.gif

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值