自定义MagicIndicator指示器

文章介绍了如何在Android中对MagicIndicator的Item进行定制,通过创建一个CommonNavigatorAdapter并设置自定义的TextView,包括设置文字颜色、背景资源以及监听页面选择事件。
摘要由CSDN通过智能技术生成

MagicIndicator的Item默认是match_parent的。所以需要自定义CommonPagerTitleView

    var commonNavigator = CommonNavigator(this)
        commonNavigator.adapter = object : CommonNavigatorAdapter() {
            override fun getCount() = stringList.size

            override fun getTitleView(context: Context?, index: Int): IPagerTitleView {
                var commonTextView = CommonPagerTitleView(context)
                var bn_textView = LayoutInflater.from(context).inflate(R.layout.bn_up_textview,null) as TextView
                bn_textView.text = stringList[index]
                commonTextView.setContentView(bn_textView)
                var fp = FrameLayout.LayoutParams(FrameLayout.LayoutParams.WRAP_CONTENT,FrameLayout.LayoutParams.WRAP_CONTENT)
                fp.gravity = Gravity.CENTER_VERTICAL
                fp.setMargins(UIUtil.dip2px(context,5.0),0,0,0)
                bn_textView.layoutParams = fp
                commonTextView.onPagerTitleChangeListener = object:OnPagerTitleChangeListener{
                    override fun onSelected(index: Int, totalCount: Int) {
                       bn_textView.setTextColor(Color.parseColor("#FFFFFF"))
                        bn_textView.setBackgroundResource(R.drawable.bn_dowm_catetories_selected)
                    }

                    override fun onDeselected(index: Int, totalCount: Int) {
                        bn_textView.setTextColor(Color.parseColor("#66000000"))
                        bn_textView.setBackgroundResource(R.drawable.bn_dowm_catetories_unselected)
                    }

                    override fun onLeave(
                        index: Int,
                        totalCount: Int,
                        leavePercent: Float,
                        leftToRight: Boolean
                    ) {

                    }

                    override fun onEnter(
                        index: Int,
                        totalCount: Int,
                        enterPercent: Float,
                        leftToRight: Boolean
                    ) {

                    }
                }


                commonTextView.setOnClickListener {
                    mDataBind.miSelectUp.onPageSelected(index)
                    mDataBind.miSelectUp.onPageScrolled(index, 0f, 0)
                }
                return commonTextView
            }

            override fun getIndicator(context: Context?): IPagerIndicator? {
                return null
            }
        }
        mDataBind.miSelectUp.navigator = commonNavigator

看下效果
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值