最新kotlin android 轮播图的实现,超简单 - android banner

写在前面

本人android小白,刚学kotlin android ,所以这篇文章是给小白看的

由于项目中需要使用到轮播图,自己造轮子不太可能所以肯定是要用到第三方库的

但是我发现网上大部分都是java android的,或者又有一些都是太老旧

正文

此次采用的是youth5201314的banner库 ,这个项目在github上也是拥有超多的star

第一步

在gradle中添加banner 和 glide 依赖  (这里用到glide是需要用到他的图片加载,也可以不用具体请参考 https://github.com/youth5201314/banner  )本文章只将最简单的使用方式

implementation 'com.youth.banner:banner:2.1.0'
implementation 'com.github.bumptech.glide:glide:4.11.0'

第二步

在AndroidManifest.xml中添加网络权限

<uses-permission android:name="android.permission.INTERNET" />

第三步

布局xml中加入banner标签

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

 第四步

创建DataBean  (放数据的)

class DataBean {
    var imageRes: Int? = null
    var imageUrl: String? = null
    var title: String?
    var viewType: Int

    constructor(imageRes: Int?, title: String?, viewType: Int) {
        this.imageRes = imageRes
        this.title = title
        this.viewType = viewType
    }

    constructor(imageUrl: String?, title: String?, viewType: Int) {
        this.imageUrl = imageUrl
        this.title = title
        this.viewType = viewType
    }

    companion object {

        //测试数据,如果图片链接失效请更换
        val testData3: List<DataBean>
            get() {
                val list: MutableList<DataBean> = ArrayList()
                list.add(
                    DataBean(
                        "https://img.zcool.cn/community/013de756fb63036ac7257948747896.jpg",
                        null,
                        1
                    )
                )
                list.add(
                    DataBean(
                        "https://img.zcool.cn/community/01639a56fb62ff6ac725794891960d.jpg",
                        null,
                        1
                    )
                )
                list.add(
                    DataBean(
                        "https://img.zcool.cn/community/01270156fb62fd6ac72579485aa893.jpg",
                        null,
                        1
                    )
                )
                list.add(
                    DataBean(
                        "https://img.zcool.cn/community/01233056fb62fe32f875a9447400e1.jpg",
                        null,
                        1
                    )
                )
                list.add(
                    DataBean(
                        "https://img.zcool.cn/community/016a2256fb63006ac7257948f83349.jpg",
                        null,
                        1
                    )
                )
                return list
            }
    }
}

第五步

在activity代码中调用

var banner:Banner<DataBean,BannerImageAdapter<DataBean>> = findViewById(R.id.banner)
        
        banner.setAdapter(object : BannerImageAdapter<DataBean>(DataBean.testData3) {
            override fun onBindView(holder: BannerImageHolder, data: DataBean, position: Int, size: Int) {
                //图片加载自己实现
                Glide.with(holder.itemView)
                    .load(data.imageUrl)
                    .apply(RequestOptions.bitmapTransform(RoundedCorners(30)))
                    .into(holder.imageView) } 
        }).addBannerLifecycleObserver(this).setIndicator(CircleIndicator(this))

大功告成

上图

  • 6
    点赞
  • 46
    收藏
    觉得还不错? 一键收藏
  • 15
    评论
根据提供的引用内容,没有直接涉及到Android Studio轮Kotlin的内容。不过,我们可以通过以下步骤实现Android Studio中使用Kotlin实现: 1.在项目的build.gradle文件中添加以下依赖项: ```gradle implementation 'com.github.bumptech.glide:glide:4.12.0' implementation 'com.github.smarteist:autoimageslider:1.4.0' ``` 2.在布局文件中添加AutoImageSlider: ```xml <com.smarteist.autoimageslider.SliderView android:id="@+id/imageSlider" android:layout_width="match_parent" android:layout_height="200dp" app:sliderAnimationDuration="600" app:sliderAutoCycleDirection="back_and_forth" app:sliderAutoCycleEnabled="true" app:sliderCircularHandlerEnabled="true" app:sliderIndicatorAnimationDuration="600" app:sliderIndicatorGravity="center_horizontal|bottom" app:sliderIndicatorMargin="10dp" app:sliderIndicatorOrientation="horizontal" app:sliderIndicatorPadding="3dp" app:sliderIndicatorRadius="3dp" app:sliderIndicatorSelectedColor="#5A5A5A" app:sliderIndicatorUnselectedColor="#FFF" app:sliderScrollTimeInSec="1" app:sliderStartAutoCycle="true" /> ``` 3.在Kotlin代码中,为AutoImageSlider设置Adapter: ```kotlin val imageSlider = findViewById<SliderView>(R.id.imageSlider) val sliderAdapter = SliderAdapter(this) imageSlider.setSliderAdapter(sliderAdapter) ``` 4.创建SliderAdapter类,并在其中实现的逻辑: ```kotlin class SliderAdapter(private val context: Context) : SliderViewAdapter<SliderAdapter.SliderAdapterVH>() { private val images = arrayOf( "https://www.example.com/image1.jpg", "https://www.example.com/image2.jpg", "https://www.example.com/image3.jpg" ) override fun onCreateViewHolder(parent: ViewGroup?): SliderAdapterVH { val inflate = LayoutInflater.from(parent?.context).inflate(R.layout.slider_item, null) return SliderAdapterVH(inflate) } override fun onBindViewHolder(viewHolder: SliderAdapterVH?, position: Int) { Glide.with(viewHolder!!.itemView) .load(images[position]) .into(viewHolder.imageViewBackground) } override fun getCount(): Int { return images.size } inner class SliderAdapterVH(itemView: View) : ViewHolder(itemView) { var imageViewBackground: ImageView = itemView.findViewById(R.id.iv_auto_image_slider) } } ``` 以上就是使用KotlinAndroid Studio中实现的步骤。如果您需要更多细节或代码示例,请参考以下链接: https://github.com/smarteist/Android-Image-Slider

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值