Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/nekocode/Badge
:octocat: Drawable of badge.
https://github.com/nekocode/Badge
android widget
Last synced: 3 months ago
JSON representation
:octocat: Drawable of badge.
- Host: GitHub
- URL: https://github.com/nekocode/Badge
- Owner: nekocode
- License: apache-2.0
- Created: 2016-05-29T07:50:46.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2023-11-15T21:32:16.000Z (over 1 year ago)
- Last Synced: 2024-10-29T18:24:02.674Z (4 months ago)
- Topics: android, widget
- Language: Java
- Homepage:
- Size: 964 KB
- Stars: 957
- Watchers: 30
- Forks: 126
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-github-android-ui - Badge - 一系列徽章图片 (徽章(Badge))
README
# Badge
[data:image/s3,"s3://crabby-images/72b99/72b992ef8396efd0e911c4770f7fbc2c04ef30de" alt="Apache 2.0 License"](http://www.apache.org/licenses/LICENSE-2.0.html) [data:image/s3,"s3://crabby-images/f4d0e/f4d0ee72b7bc5df008abc66cea7f339d2cad0aed" alt="Release"](https://jitpack.io/#nekocode/Badge)### Preview
data:image/s3,"s3://crabby-images/55e27/55e270ada64db7af2701917b382d1db35804b781" alt=""
## Integration
- Add the JitPack repository to your root build.gradle:
```gradle
repositories {
maven { url "https://jitpack.io" }
}
```- Add the dependency to your sub build.gradle:
```gradle
dependencies {
implementation "com.github.nekocode:Badge:${last-version}"
}
```## Badge Types
This library provides four types of badges with cliche customizations.
| Type | Badge | Type | Badge |
| :----- | :------ | :----- | :------ |
| **`TYPE_NUMBER`** | data:image/s3,"s3://crabby-images/8ae5b/8ae5b7153bece911b7b9be8f33557516a61bbeeb" alt="number" | **`TYPE_ONLY_ONE_TEXT`** | data:image/s3,"s3://crabby-images/61eff/61effc8be20446ee65902421ad6a9d89eaaeb9dd" alt="single" |
| **`TYPE_TWO_TEXT`** | data:image/s3,"s3://crabby-images/e61d3/e61d3719575f28d2b47c8865e6d7d901288ca07b" alt="two" | **`TYPE_TWO_TEXT_COMPLEMENTARY`** | data:image/s3,"s3://crabby-images/d7ad2/d7ad2849f2c9e608f5d37bb465337078ce43f18f" alt="complementary" |### Attributes
data:image/s3,"s3://crabby-images/cbf7a/cbf7af8b48b20f5fa3fb646f97f9c80ad0891b66" alt=""
## Usage
The above screenshot's example:
```java
final BadgeDrawable drawable =
new BadgeDrawable.Builder()
.type(BadgeDrawable.TYPE_NUMBER)
.number(9)
.build();final BadgeDrawable drawable2 =
new BadgeDrawable.Builder()
.type(BadgeDrawable.TYPE_ONLY_ONE_TEXT)
.badgeColor(0xff336699)
.text1("VIP")
.build();final BadgeDrawable drawable3 =
new BadgeDrawable.Builder()
.type(BadgeDrawable.TYPE_WITH_TWO_TEXT_COMPLEMENTARY)
.badgeColor(0xffCC9933)
.text1("LEVEL")
.text2("10")
.padding(dp2px(2), dp2px(2), dp2px(2), dp2px(2), dp2px(2))
.strokeWidth(dp2px(1))
.build();final BadgeDrawable drawable4 =
new BadgeDrawable.Builder()
.type(BadgeDrawable.TYPE_WITH_TWO_TEXT)
.badgeColor(0xffCC9999)
.text1("TEST")
.text2("Pass")
.build();final BadgeDrawable drawable5 =
new BadgeDrawable.Builder()
.type(BadgeDrawable.TYPE_NUMBER)
.number(999)
.badgeColor(0xff336699)
.build();
```The above `drawable4` BadgeDrawable has set a number that too large to show, in this case, it will be replaced with **"..."** for showing. And then you can use `toSpannable()` for converting the drawable to SpannableString without setting its drawing bounds. It has already took internal measure.
```java
SpannableString spannableString =
new SpannableString(TextUtils.concat(
"TextView ",
drawable.toSpannable(),
" ",
drawable2.toSpannable(),
" ",
drawable3.toSpannable(),
" ",
drawable4.toSpannable(),
" ",
drawable5.toSpannable()
));textView.setText(spannableString);
```If the drawable's bounds was setted by manual or content view. It will auto cut the text to adjust the bounds' width. Look like:
data:image/s3,"s3://crabby-images/d3ab9/d3ab91d9105a131b47370ff3e72788c9cbd750d3" alt=""
You can also use the badge drawable for ImageView and other more view.