这是你从未见过的组件库 -- Android 上的手绘风格组件

之前看到一位作者开源了一款手绘风格的图表库 Chart.xkcd,感觉很是喜欢。
当然仅仅图表是满足不了我滴,于是想看看 Android 上是否有类似的开源库,一番搜索之后,颗粒无收。
想想原理可能不是太难,于是花点时间动手写了一个。

Demo 展示

成果如下:

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

想快速体验一把,可以下载 Demo APK ~

仓库介绍

SketchyComponent,一款手绘风格的 Android 组件库。
仓库地址:github.com/m-zylab/Ske…

快速接入

  1. 添加 jcenter 仓库(AS 创建的项目默认已经添加)
repositories {
    jcenter()
}
复制代码
  1. 添加 sketchy 依赖
implementation 'com.zylab:sketchy:0.1.3'
复制代码
  1. 代码中使用组件
// 1\. 创建 Sketchy 图形
val skSquareDrawable = SkSquareDrawable().apply {
    // 2\. 设置属性
    fillColor = resources.getColor(android.R.color.holo_orange_dark)
}
// 3\. 给 View 设置背景
text.background = skSquareDrawable
复制代码

就是这么 easy ~

组件库介绍

目前 SketchyComponent 提供了基础图形的 Drawable,一部分 Icon,以及用来自定义图形的基础功能。
下面分别介绍一下~

基础 Drawable
SkSquareDrawable

绘制一个矩形,效果如下:

在这里插入图片描述

SkLineDrawable

绘制一个线形,效果如下:

在这里插入图片描述

SkCircleDrawable

绘制一个圆形,效果如下:

在这里插入图片描述

SkArcDrawable

绘制一个扇形,效果如下:

在这里插入图片描述

SkImgDrawable

绘制图片,效果如下:

在这里插入图片描述

部分 Icon
SkTimeIcon

在这里插入图片描述

SkSearchIcon

在这里插入图片描述

SkListIcon

在这里插入图片描述

SkArrowIcon

在这里插入图片描述在这里插入图片描述

自定义能力

我们提供了一些基础图形,方便用来自定义一些效果。下面是一些自定义的示例。

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

基础图形使用方法

我们提供的基础图形,均继承自 SkShape,其中提供了两个方法,SkShape#parseSkShape#draw(canvas: Canvas)
SkShape#parse 方法用来生成图形对应的路径
SkShape#draw 方法用来将图形绘制到 canvas,如果在绘制时路径还没有生成,即 parse 方法还未调用,默认会调用 parse 方法
以绘制直线为例:

// 创建 SkLine 
val line = SkLine()
// 设置属性
line.startPoint = SkPoint(0.0, 0.0)
line.endPoint = SkPoint(100.0, 100.0)
// 进行绘制
line.draw(canvas)
复制代码

具体的 SkShape 介绍如下:

SkSquare

绘制一个矩形

在这里插入图片描述

SkLine

绘制一条线

在这里插入图片描述

SkCircle

绘制一个圆

在这里插入图片描述

SkArc

绘制扇形

在这里插入图片描述

SkCircleImg

绘制一个圆形图片

在这里插入图片描述

SkSquareImg

绘制一个矩形图片

在这里插入图片描述
更多用法请参照 github.com/m-zylab/Ske… 以及 github.com/m-zylab/Ske…

服务推荐

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值