MaterialProgressBar:和Material Design效果外观一致的进度条

materialprogressbar

MaterialProgressBar是一款针对Android 4.0以上的Material Desgin风格的进度条。

为什么是MaterialProgressBar?

  • 和Android 4.0以上一致的外观。
  • 真正的兼容所有版本。
  • 能够去除框架进度条的内在填充。
  • 能够隐藏框架水平条进度的轨迹。

预览

Android 4.4.4

三星手机 Android 5.0.1(原生实现未着色)

Android 5.1.1

示例应用

整合

Gradle:

使用

你可以简单的使用 MaterialProgressBar 控件,

使用控件

MaterialProgressBar 可以很方便的替换到常规的进度条,并且使用常规进度条的所有的样式和属性。 例如,创建一个不确定的水平MaterialProgressBar:

为了让你的进度条在所有的版本采取正确和一致的尺寸,你可以使用这个库的一种样式。里面的诀窍是使用使用最大最小的宽高来控制尺寸。

  • Widget.MaterialProgressBar.ProgressBar
  • Widget.MaterialProgressBar.ProgressBar.Horizontal
  • 更多的尺寸和无填充样式可以参考style.xml

可用的自定义属性:

  • app:mpb_progressStyle:进度条的样式:circular (圆形)horizontal(水平) 默认是 circular (圆形)
  • app:mpb_setBothDrawables:设置进度条是确定和不确定或者都可以 ,暂时还不支持确定的圆形进度条,默认是false
  • app:mpb_useIntrinsicPadding:设置是否需要内部边距,默认是true
  • app:mpb_showTrack: 设置进度条是否有轨迹,默认为true的是水平进度条,其他的都是false

支持android:tintapp:mpb_tintMode 来着色进度条。默认的颜色是?colorControlActivated,默认的着色模式是src_in

详细的例子,你可以参考简单的布局,在那里,你可以找到例子,如删除进度条填充或轨迹。

使用Drawable

材料设计是向后兼容Android 4.0 (API 14),所以你可以直接创建和设置你的进度条

例如:给进度条设置IndeterminateHorizontalProgressDrawable属性

这个库还可以直接在xml中设置一个样式

例如:定义一个不确定的水平进度条

别忘了创建和设置drawable

你也可以通过setshowtrack()setuseintrinsicpadding()来自定义 色彩的相关方法setTint(),setTintList()setTintMode()你也可以直接使用它们。但要记得让这些图片作为他们的实际类型或TintableDrawable因为虚拟机在传统的平台可能找不到Drawable的相关方法。

如果你想兼容 API level < 18,在这里你需要解决一个画布局限,使用这种自动的materialprogressbar

详细示例,你可以参考onCreate()方法在 MainActivity和他的布局main_activity.xml

混淆

这个库的AAR已经包括混淆器配置文件,ObjectAnimator可以正常使用

旧版本

ICS以前的版本,既不支持Support v4也不支持AppCompat v7的动画,并且NineOldAndroids这个库已经过时了,人们现在使用minSdkVersion="14",所以不支持比ICS更老的版本。

协议

Apache OpenNLP遵循Apache 2.0开源协议发布。

开源地址:https://github.com/DreaminginCodeZH/MaterialProgressBar

1 4 收藏

资源整理者简介:晓峰残月

笨鸟先飞,勤定补拙 个人主页 · 贡献了7个资源 · 1


直接登录
最新评论

推荐关注

按分类快速查找

关于资源导航
  • 伯乐在线资源导航收录优秀的工具资源。内容覆盖开发、设计、产品和管理等IT互联网行业相关的领域。目前已经收录 1438 项工具资源。
    推送伯乐头条热点内容微信号:jobbole 分享干货的技术类微信号:iProgrammer