SegmentedControl
自定义View实现的分段选择控件
Install / Use
/learn @danledian/SegmentedControlREADME
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
项目源码地址https://github.com/danledian/SegmentedControl,欢迎Star
Related Skills
node-connect
341.8kDiagnose OpenClaw node connection and pairing failures for Android, iOS, and macOS companion apps
frontend-design
84.6kCreate distinctive, production-grade frontend interfaces with high design quality. Use this skill when the user asks to build web components, pages, or applications. Generates creative, polished code that avoids generic AI aesthetics.
openai-whisper-api
341.8kTranscribe audio via OpenAI Audio Transcriptions API (Whisper).
commit-push-pr
84.6kCommit, push, and open a PR
