1s制作开源项目中启动图案

简介: 运维系列

通过我们在启动spring项目或者其他中间件和小工具的时候,会遇到输出一些有意思的图案,于是也挺好奇这些是如何制作的,于是在网上找到了以下几种实现的工具以及网站可以直接制作,然后在程序启动的时候打印出来这些字符。整理一下分享给大家。

字符图案

我们在使用一些开源软件的时候,启动打开的字符图形很好看,例如下面的字符。于是搜索到了一些网站和工具来实现:

"""
 _              _   _                        
| |            | | ( )                       
| |       ___  | |_|/   ___    __ _    ___   
| |      / _ \ | __|   / __|  / _` |  / _ \  
| |____ |  __/ | |_    \__ \ | (_| | | (_) | 
\_____/  \___|  \__|   |___/  \__, |  \___/  
                               __/ |         
                              |___/                                                                                                                                                                                         
"""

网站taag

CloudNative

可以随意输入内容,调节字体、宽、高。

Ascii图像生成器

同时作者还有另外一个ascii图像生成器

ascii图形生成器

如果想要在python中输出,只需要把上面的字符串赋值然后使用print函数打印即可,需要用多行注释来包含这些字符:

命令行工具figlet

所以首先来安装一下figlet

brew install figlet

figlet输出的图形随着使用的字体的变化而变化,所以可以参考figlet官网找到合适的字体,下载后存放在/usr/local/Cellar/figlet/2.x.x/share/figlet/fonts路径下即可

#输出斜体
figlet -f slant CloudNative
   ________                ___   __      __  _
  / ____/ /___  __  ______/ / | / /___ _/ /_(_)   _____
 / /   / / __ \/ / / / __  /  |/ / __ `/ __/ / | / / _ \
/ /___/ / /_/ / /_/ / /_/ / /|  / /_/ / /_/ /| |/ /  __/
\____/_/\____/\__,_/\__,_/_/ |_/\__,_/\__/_/ |___/\___/

图片图案

在python中显示字符串图片

这种方法的主要原理是利用一组视觉密度不同的字符,按照灰度去替换每一个像素:

  1. 可以将图像的灰度定义为不同的级别来显示:
  • gscale1 = "$@B%8&WM#*oahkbdpqwmZO0QLCJUYXzcvunxrjft/\|()1{}[]?-_+~i!lI;:,\"^.
  • `gscale2 = "@%#*+=-:. "这种灰度级别少一些
  1. 然后读入图像,将图像映射为长宽等比的矩阵
  2. 然后将颜色灰度值映射到定义的灰度级别上来
import sys
import cv2

grays = "@%#*+=-:. "   #由于控制台是白色背景,所以先密后疏/黑色背景要转置一下
gs = 10                #10级灰度
#grays2 = "$@B%8&WM#*oahkbdpqwmZO0QLCJUYXzcvunxrjft/\|()1{}[]?-_+~i!lI;:,\"^.` "
#gs2 = 67

img = cv2.imread('demo.png',0)  #读入灰度图

#宽(列)和高(行数)
w = img.shape[1]
h = img.shape[0]
ratio = float(w)/h  #调整长宽比 (**注:此比例为win cmd,ratio需要根据不同终端的字符长宽调整)   

scale = w // 50    #缩放尺度,向下取整,每50个像素取一个 值越小图越小(scale 越大)

for y in range(0, h, int(scale*ratio)):  #根据缩放长度 遍历高度 y对于h,x对应w
    for x in range(0, w, scale):  #根据缩放长度 遍历宽度
        idx=img[y][x] * gs // 255  #获取每个点的灰度  根据不同的灰度填写相应的 替换字符
        if idx==gs:
            idx=gs-1
        sys.stdout.write(grays[idx])  #写入控制台
    sys.stdout.write('\n')
    sys.stdout.flush()

执行以上代码之前,你需要先安装一下pip install opencv-python

找一个图片,修改图片的路径为脚本所在的目录,命名为demo.png,图片如下:

然后执行完Python脚本后,看到处理后的结果为:

看起来还不错哦,哈哈

输出彩色的图像

这里可以在微信公众号后台回复彩蛋即可获取输出彩色图像的Python脚本,这里不再详细展开描述。效果图如下:

相关文章
|
2月前
|
前端开发
业余时间开发了个海报编辑器
为了满足撰写博客或录制教程视频时对高质量海报的需求,我利用业余时间开发了一款海报编辑器。第一版功能简单,支持固定尺寸、黑底白字的标题。后来经过优化,增加了背景图、模糊效果、文字样式调整等功能,使海报更具吸引力。目前该编辑器已上线,欢迎大家试用并反馈。[访问海报编辑器](https://tool.share888.top/#/poster)
81 6
业余时间开发了个海报编辑器
|
5月前
|
移动开发 JavaScript 前端开发
【绝技揭秘】从零到英雄:解锁UniApp H5项目中的二维码生成与扫描秘籍,让你的应用瞬间变身扫码达人!
【8月更文挑战第20天】二维码在移动应用中无处不在。本文详述了在UniApp H5项目中实现二维码生成与扫描的方法。通过对比插件`uni-app-qrcode`和JavaScript库`qrcode-generator`生成二维码的方式,以及使用插件`@juggle/resize-observer`和HTML5的MediaDevices API进行扫描的技术方案,帮助开发者挑选最佳实践。无论是插件的便捷性还是原生JavaScript的灵活性,都能满足不同项目需求。
167 0
|
8月前
|
前端开发
前端知识笔记(二十)———简易弹窗制作
前端知识笔记(二十)———简易弹窗制作
84 0
|
安全 iOS开发 MacOS
酷炫的IDEA启动图黑客主题来了
酷炫的IDEA启动图黑客主题来了
188 0
|
搜索推荐 Windows
超好用的5款软件,每一款都让你爱不释手
分享爱,分享时光,分享精彩瞬间,大家好,我是互联网的搬运工,今天继续给大家带来几款好用的软件。
104 0
|
小程序 API Android开发
小程序开发-第三章第四节点击查看大图,保存壁纸-全栈工程师之路-中级篇
小程序开发-第三章第四节点击查看大图,保存壁纸-全栈工程师之路-中级篇
178 0
小程序开发-第三章第四节点击查看大图,保存壁纸-全栈工程师之路-中级篇
|
编解码 移动开发 数据可视化
自研开源项目正式动工,顺便分享 10个酷炫后台模板
自研开源项目正式动工,顺便分享 10个酷炫后台模板
334 0
自研开源项目正式动工,顺便分享 10个酷炫后台模板
给typecho添加社会主义核心价值观24字特效,鼠标点击出现富强,民主,文明等等12组词
给typecho添加社会主义核心价值观24字特效,鼠标点击出现富强,民主,文明等等12组词
306 0