Awesome
SegmentedControlButton
自定义View实现的分段选择控件
- 支持拖动和点击手势
- 支持松手动画
- 支持自定义样式
- 支持字体颜色过渡
使用
- Step 1. 在项目根目录build.gradle里面添加
allprojects {
repositories {
...
maven { url 'https://www.jitpack.io' }
}
}
- Step 2. 添加依赖
dependencies {
implementation 'com.github.danledian:SegmentedControl:1.0.5'
}
示例
- XML代码
<com.dld.view.SegmentedControlView
android:layout_width="300dp"
android:layout_height="40dp"
app:segItemHorizontalMargin="3dp"
app:segItemVerticalMargin="3dp"
app:segCornersMode="Circle"
app:segSelectedItem="1"
android:id="@+id/scv"/>
- 添加数据
List<SegmentedControlItem> items = new ArrayList<>();
items.add(new SegmentedControlItem("Yesterday"));
items.add(new SegmentedControlItem("Today"));
items.add(new SegmentedControlItem("Tomorrow"));
mScv1.addItems(items);
Attributes属性
Attributes | format | describe |
---|---|---|
segCornersRadius | dimension | 内外边框的弧度 |
segBackgroundColor | color | 背景颜色 |
segSelectedItemBackgroundColor | color | 移动Item的颜色 |
segTextColor | color | 背景中字体颜色 |
segSelectedItemTextColor | color | 移动Item的字体颜色 |
segItemHorizontalMargin | dimension | 移动Item距离边框的左外间距 |
segItemVerticalMargin | dimension | 移动Item距离边框的上外间距 |
segItemPadding | dimension | 设置Item左右内边距 |
segSelectedItem | integer | 设置选中位置 |
segTextSize | reference | 设置字体大小 |
segScrollSelectEnabled | boolean | 设置是否支持滑动选择 |
segCornersMode | enum | 设置模式 |
License
MIT