首页 > 解决方案 > 具有动态颜色的自定义 GitHub 徽章

问题描述

我很难创建一个动态改变颜色的shields.io徽章。

我可以使用 JSON 响应将文本解析为徽章并将颜色设置为橙色:

https://img.shields.io/badge/dynamic/json.svg?label=custom&url=https://jsonplaceholder.typicode.com/posts&query=$[1].id&colorB=orange

在此处输入图像描述

效果很好...


但是,我想根据规则更改颜色。我也可能会返回 JSON 中的 HEX 颜色以解析为徽章。我尝试了公共API来获得随机颜色并测试行为:

http://www.colr.org/json/color/random

我使用 JsonPath 获得第一个随机获取颜色$.colors[0].hex并将其作为动态值和颜色放置在徽章 URL 上:

https://img.shields.io/badge/dynamic/json.svg?label=custom&url=http://www.colr.org/json/color/random&query=$.colors[0].hex&colorB=$.colors[0].hex

不管随机选择的颜色如何,结果总是以某种方式绿色(最后生成的结果是#D0BB79

在此处输入图像描述

我希望这样的东西与#D0BB79颜色正确匹配:

在此处输入图像描述

如何使颜色也动态?Coveralls.ioCodecov.ioSonarCloud.io提供了示例动态彩色徽章。

标签: jsongithubcolorsbadgeshields.io

解决方案


我遇到了类似的麻烦,最终使用了一个名为anybadge的命令行工具,它以阈值作为参数。这允许您在一个命令中生成具有动态颜色的徽章:

anybadge -l pylint -v 2.22 -f pylint.svg 2=red 4=orange 8=yellow 10=green

颜色可以通过十六进制颜色代码或一组预定义的颜色名称来定义。

这里的主要区别在于这不是通过引用 URL 来完成的,因此不能以相同的方式嵌入。我在我的 CI 管道中使用它来生成各种徽章,然后将它们存储为项目工件并在我的项目中引用它们README.md


推荐阅读