安卓轮播图banner的使用和详解

轮播图banner的基本使用

1.首先要导入依赖

	//Banner图依赖
    implementation 'com.youth.banner:banner:1.4.10'
	//glide依赖
    implementation 'com.github.bumptech.glide:glide:4.0.0-RC1'

2.如果是网络解析图片,这里得在Manifest中添加权限

<!--网络-->
 <uses-permission android:name="android.permission.INTERNET"/>
 <!--读取外置存储卡-->
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />

3…xml中

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

4…Java代码中

import android.content.Context;
import android.graphics.Paint;
import android.media.Image;
import android.os.Bundle;
import android.view.View;
import android.view.animation.Animation;
import android.widget.ImageView;
import android.widget.Toast;

import com.bumptech.glide.Glide;
import com.youth.banner.Banner;
import com.youth.banner.BannerConfig;
import com.youth.banner.BannerScroller;
import com.youth.banner.Transformer;
import com.youth.banner.listener.OnBannerListener;
import com.youth.banner.loader.ImageLoader;

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

import androidx.appcompat.app.AppCompatActivity;
import butterknife.BindView;
import butterknife.ButterKnife;

public class SecondActivity extends AppCompatActivity implements OnBannerListener {

    @BindView(R.id.banner)
    Banner banner;
    private List<String> mImage = new ArrayList<>();//存放图片地址集合
    private List<String> mTitles = new ArrayList<>();//存放标题集合

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_second);
        ButterKnife.bind(this);
        initView();
    }

    private void initView() {

   		mImage.add("https://gimg2.baidu.com/image_search/src=http%3A%2F%2Ftupian.qqjay.com%2Fu%2F2017%2F1215%2F14_1657_8.jpg&refer=http%3A%2F%2Ftupian.qqjay.com&app=2002&size=f9999,10000&q=a80&n=0&g=0n&fmt=jpeg?sec=1636795598&t=bf0ccfb77e34cccf79597fcb289b1099");
        mImage.add("https://img1.baidu.com/it/u=2641362231,3822011310&fm=26&fmt=auto");
        mImage.add("https://img1.baidu.com/it/u=238771295,4007404481&fm=26&fmt=auto");
        mImage.add("https://gimg2.baidu.com/image_search/src=http%3A%2F%2Fup.enterdesk.com%2Fedpic%2Fed%2Fd1%2Faa%2Fedd1aa6f05ceaee8bb8c67f4d45c51c7.jpg&refer=http%3A%2F%2Fup.enterdesk.com&app=2002&size=f9999,10000&q=a80&n=0&g=0n&fmt=jpeg?sec=1636796623&t=43bcbc12a5dd5900cf970692d4c0881b");
        mTitles.add("好好学习");
        mTitles.add("天天向上");
        mTitles.add("内卷卷死");
        mTitles.add("也不闲死");

		//设置轮播图样式 共有6种 可以点进去更换查看不同样式
        banner.setBannerStyle(BannerConfig.CIRCLE_INDICATOR_TITLE_INSIDE)
               //加载图片  图片加载器
                .setImageLoader(new MyLoader())
                //添加图片集合
                .setImages(mImage)
                //设置图片轮播的不同显示效果  可以点进去跟换样式
                .setBannerAnimation(Transformer.Default)
                //添加图片标题
                .setBannerTitles(mTitles)
                //设置每张图片显示的时间
                .setDelayTime(2000)
                //是否自动轮播,true则为自动轮播,默认为true
                .isAutoPlay(true)
                //设置指示器的位置  左中右三种
                .setIndicatorGravity(BannerConfig.CENTER)
                //轮播图的监听
                .setOnBannerListener(this)
                //启动轮播图 不要忘记
                .start();

    }
//轮播图的监听方法
    @Override
    public void OnBannerClick(int position) {
        Toast.makeText(this, "点中第"+position+"个", Toast.LENGTH_SHORT).show();
    }
//轮播图加载器
    private class MyLoader extends ImageLoader{
        @Override
        public void displayImage(Context context, Object path, ImageView imageView) {
            Glide.with(context).load((String)path).into(imageView);
        }
    }

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值