IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 移动开发 -> Android开发短视频源码时常用的页面切换指示器 -> 正文阅读

[移动开发]Android开发短视频源码时常用的页面切换指示器

在项目和产品的开发过程中,难免会遇到使用viewpager+指示器的UI实现,如果是通过自己手写实现,未免太过麻烦,且各个产品不同页面的风格不同,定制起来颇为复杂,今天,向大家推荐云豹短视频源码开发中正在使用的框架——MagicIndicator。

它使用起来非常简单,并且可以自定义实现多种样式,接下来就简单介绍下用法。

第一步首先就是引用这个框架,在build.gradle中添加引用:

compile'com.github.hackware1993:MagicIndicator:1.5.0'

第二步在使用的页面布局文件中添加代码:

<net.lucode.hackware.magicindicator.MagicIndicator
    android:id="@+id/magic_indicator"
    android:layout_width="match_parent"
    android:layout_height="45dp" />
<android.support.v4.view.ViewPager
    android:id="@+id/viewpager"
    android:layout_weight="1"
    android:layout_width="match_parent"
    android:layout_height="0dp">
</android.support.v4.view.ViewPager>

接下来,在短视频源码使用的页面中设置标题的指示器样式:

CommonNavigator commonNavigator = new CommonNavigator(getActivity())
 commonNavigator.setAdapter(new CommonNavigatorAdapter() {
        @Override
        public int getCount() {
            return titles.length;
        }
        @Override
        public IPagerTitleView getTitleView(Context context, final int index) {
            SimplePagerTitleView simplePagerTitleView = new 		ScaleTransitionPagerTitleView(context);
            simplePagerTitleView.setText(titles[index]);
/设置导航的文字大小

            simplePagerTitleView.setTextSize(20);/            
//正常状态下的标题颜色
simplePagerTitleView.setNormalColor(Color.GRAY);    
//选中的标题字体颜色        simplePagerTitleView.setSelectedColor(getResources().getColor(R.color.title_bar_bg));
            simplePagerTitleView.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                    viewPager.setCurrentItem(index);
                }
            });
            return simplePagerTitleView;
        }
        @Override
        public IPagerIndicator getIndicator(Context context) {
            return null;
        }
    });

    magicIndicator.setNavigator(commonNavigator);

如果标题数量少,可以设置指示器居中显示,按钮均分宽度:

commonNavigator.setAdjustMode(true);

当然,可以定制风格的地方比较多,这里举一个例子,实现短视频app源码中内容包裹的指示器样式:

 protected IPagerIndicator createIPagerIndicator(Context context) {

        WrapPagerIndicator indicator = new WrapPagerIndicator(context);
//设置背景颜色
        indicator.setFillColor(Color.parseColor("#c9f4f3"));
//设置行间距
        indicator.setHorizontalPadding(DpUtil.dp2px( 10));
//设置圆角弧度
        indicator.setRoundRadius(DpUtil.dp2px( 25));
//设置竖直间距
        indicator.setVerticalPadding(DpUtil.dp2px(2));
        return indicator;
    }

最后需要将viewpager与MagicIndicator 绑定到一起

ViewPagerHelper.bind(magicIndicator, viewPager);

以上就是云豹短视频源码中,简单使用MagicIndicator实现切换页面跟指示器的绑定教程。

  移动开发 最新文章
Vue3装载axios和element-ui
android adb cmd
【xcode】Xcode常用快捷键与技巧
Android开发中的线程池使用
Java 和 Android 的 Base64
Android 测试文字编码格式
微信小程序支付
安卓权限记录
知乎之自动养号
【Android Jetpack】DataStore
上一篇文章      下一篇文章      查看所有文章
加:2021-07-14 11:02:31  更:2021-07-14 11:04:41 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/2 6:42:51-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码