吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 3396|回复: 13
收起左侧

[其他原创] 控制台(包括cmd,node,c,shell,console控制台之类的)特殊输出

  [复制链接]
涛之雨 发表于 2022-11-5 09:55
本帖最后由 涛之雨 于 2022-11-5 10:08 编辑

效果:

demo.png

注:

  1. 图中所使用的分别为:

    最上方为浏览器控制台(chrome)

    下方田字格按z字形分别为c语言控制台, bat, nodejs, Ubuntu-shell(wsl)

  2. 此外理论上支持的包括且不限于python, Perl, go, java 等语言。

  3. 图上方控制台除了ansi还支持style,非本文重点,不多赘述,可以查看【为控制台定义样式

    注:上方链接似乎有bug,不会自动跳转到锚点,请点击后手动到在地址栏里删除最后的1回车跳转

    小声逼逼,网上控制台放图片的办法好像都失效了,我在gist写了一个其他方式实现的。。。

    console.png

原理:

说白了就是一句话,标准ANSI 转义码(维基(不存在的网站))(百度百科

(即使是不存在的维基百科, 中文的内容也没有英文的多, 下图左为英文(谷歌机译), 右为中文站点)

wiki.png

我之前的帖子:多人成行(双人成行-存档切换工具)也用到过这种输出。

当时是手动计算的,现在通过库进行输出。

实现代码

核心代码来自:ansi-styles

为了使用方便,给String添加了colorful函数。

源码

源码见:gist

这里贴上使用uglify压缩后的版本:(gist也有该文件

String.prototype.colorful=function(...e){const r=["color","bgColor"],{styles:o,colorNames:t,modifierNames:n}=function(){const e=10,r=(e=0)=>r=>`\x1b[${r+e}m`,o=(e=0)=>r=>`\x1b[${38+e};5;${r}m`,t=(e=0)=>(r,o,t)=>`\x1b[${38+e};2;${r};${o};${t}m`,n={modifier:{reset:[0,0],bold:[1,22],dim:[2,22],italic:[3,23],underline:[4,24],overline:[53,55],inverse:[7,27],hidden:[8,28],strikethrough:[9,29]},color:{black:[30,39],red:[31,39],green:[32,39],yellow:[33,39],blue:[34,39],magenta:[35,39],cyan:[36,39],white:[37,39],blackBright:[90,39],gray:[90,39],grey:[90,39],redBright:[91,39],greenBright:[92,39],yellowBright:[93,39],blueBright:[94,39],magentaBright:[95,39],cyanBright:[96,39],whiteBright:[97,39]},bgColor:{bgBlack:[40,49],bgRed:[41,49],bgGreen:[42,49],bgYellow:[43,49],bgBlue:[44,49],bgMagenta:[45,49],bgCyan:[46,49],bgWhite:[47,49],bgBlackBright:[100,49],bgGray:[100,49],bgGrey:[100,49],bgRedBright:[101,49],bgGreenBright:[102,49],bgYellowBright:[103,49],bgBlueBright:[104,49],bgMagentaBright:[105,49],bgCyanBright:[106,49],bgWhiteBright:[107,49]}},i=Object.keys(n.modifier),l=[...Object.keys(n.color),...Object.keys(n.bgColor)];return{styles:function(){const i=new Map;for(const[e,r]of Object.entries(n)){for(const[e,o]of Object.entries(r))n[e]={open:`\x1b[${o[0]}m`,close:`\x1b[${o[1]}m`},r[e]=n[e],i.set(o[0],o[1]);Object.defineProperty(n,e,{value:r,enumerable:!1})}return Object.defineProperty(n,"codes",{value:i,enumerable:!1}),n.color.close="\x1b[39m",n.bgColor.close="\x1b[49m",n.color.ansi=r(),n.color.ansi256=o(),n.color.ansi16m=t(),n.bgColor.ansi=r(e),n.bgColor.ansi256=o(e),n.bgColor.ansi16m=t(e),Object.defineProperties(n,{rgbToAnsi256:{value:(e,r,o)=>e===r&&r===o?e<8?16:e>248?231:Math.round((e-8)/247*24)+232:16+36*Math.round(e/255*5)+6*Math.round(r/255*5)+Math.round(o/255*5),enumerable:!1},hexToRgb:{value:e=>{const r=/[a-f\d]{6}|[a-f\d]{3}/i.exec(e.toString(16));if(!r)return[0,0,0];let[o]=r;3===o.length&&(o=[...o].map(e=>e+e).join(""));const t=Number.parseInt(o,16);return[t>>16&255,t>>8&255,255&t]},enumerable:!1},hexToAnsi256:{value:e=>n.rgbToAnsi256(...n.hexToRgb(e)),enumerable:!1},ansi256ToAnsi:{value:e=>{if(e<8)return 30+e;if(e<16)return e-8+90;let r,o,t;if(e>=232)o=r=(10*(e-232)+8)/255,t=r;else{const n=(e-=16)%36;r=Math.floor(e/36)/5,o=Math.floor(n/6)/5,t=n%6/5}const n=2*Math.max(r,o,t);if(0===n)return 30;let i=30+(Math.round(t)<<2|Math.round(o)<<1|Math.round(r));return 2===n&&(i+=60),i},enumerable:!1},rgbToAnsi:{value:(e,r,o)=>n.ansi256ToAnsi(n.rgbToAnsi256(e,r,o)),enumerable:!1},hexToAnsi:{value:e=>n.ansi256ToAnsi(n.hexToAnsi256(e)),enumerable:!1}}),n}(),colorNames:l,modifierNames:i}}();if(e.find(e=>"[object String]"!==Object.prototype.toString.call(e)))throw new Error("Invalid color");let i=this;return e.forEach((e,l)=>{[...t,...n].includes(e)?i=o[e].open+i+o[e].close:e.startsWith("#")&&(i=o[r[+!!l]].ansi(o.hexToAnsi(e))+i+o[r[+!!l]].close)}),i};

使用

'字符串'.colorful(参数1, 参数2, ...)

其中,参数支持

  1. #开头的16进制RGB字符串
  2. 下方列出的关键词

其中,允许RGB字符串和关键词允许混编,但是由于代码中的骚操作

16进制输入时,只有作为第一个参数才作为前景色,否则均作为背景色处理(没错,特性)

因此.colorful('bold','#123456','abcdef')的最后一个参数是无意义的,

等价于.colorful('bold','#123456'),不过可以.colorful('bold','#123456','redBright'),其中redBright作为前景色

演示

String.prototype.colorful=function(){xxxxxx(上面的一堆)xxxxxx}
console.log([...'吾爱破解论坛官网是𝕎𝕨𝕎.𝟝𝟚ℙ𝕠𝕁𝕚𝕖.ℂ𝕟\n'.repeat(40)].map(a=>a.colorful("#"+Math.random().toString(16).slice(2,8),"#"+Math.random().toString(16).slice(2,8))).join(""))

会生成40行强烈精神污染的随机颜色文本。。。就不放截图了=_=自己脑补吧

可以通过控制台执行copy("这里是要复制的文本")复制到剪贴板到外面使用(注:存在控制字符\x1b,有些编辑器可以显示,但是有些编辑器会显示,请确保使用支持显示不可见控制字符的编辑器)

copy.png

支持参数

RGB(hex)

#开头的6位16进制颜色

非要说就是符合下方正则表达式的字符串

/#[\da-f]{6}/

关键词

特殊 文本颜色 背景颜色
reset black bgBlack
bold red bgRed
dim green bgGreen
italic (未得到广泛支持) yellow bgYellow
underline blue bgBlue
overline 在基于VTE的终端、GNOME终端、mintty和Git Bash上支持。 magenta bgMagenta
inverse cyan bgCyan
hidden white bgWhite
strikethrough (未得到广泛支持) blackBright (别名: gray, grey) bgBlackBright (别名: bgGray, bgGrey)
redBright bgRedBright
greenBright bgGreenBright
yellowBright bgYellowBright
blueBright bgBlueBright
magentaBright bgMagentaBright
cyanBright bgCyanBright
whiteBright bgWhiteBright

好像也没什么意思。。。做个记录。。。

免费评分

参与人数 13吾爱币 +29 热心值 +12 收起 理由
junjia215 + 1 + 1 用心讨论,共获提升!
TengA + 1 + 1 我很赞同!
yueshaojie + 1 我很赞同!
allenzhu + 1 用心讨论,共获提升!
timeni + 1 + 1 用心讨论,共获提升!
溜玩音乐 + 3 + 1 谢谢@Thanks!
bin2163239 + 2 + 1 我很赞同!
luliucheng + 1 + 1 用心讨论,共获提升!
苏紫方璇 + 10 + 1 涛哥哥好棒!
冥界3大法王 + 4 + 1 进来看看国际友人。
cv130 + 1 用心讨论,共获提升!
正己 + 4 + 1 涛哥哥好棒!
知心 + 1 + 1 我很赞同!

查看全部评分

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

 楼主| 涛之雨 发表于 2022-11-5 17:50
luliucheng 发表于 2022-11-5 14:23
曾经我的oh-my-cmd关键部分就是特殊颜色输出,我自己还整理了一份完整点的bat:https://pan.baidu.com/s/1a ...

对的,原理都是一样的,不过连console控制台都支持我是没想到的。。。(虽然使用%c进行格式化输出更香。。。)
luliucheng 发表于 2022-11-5 14:23
本帖最后由 luliucheng 于 2022-11-5 14:25 编辑

曾经我的oh-my-cmd关键部分就是特殊颜色输出,我自己还整理了一份完整点的bat:https://pan.baidu.com/s/1aYfK_yDqa8ahFVv85p8dgA?pwd=52pj (网盘里直接看是乱码,因为bat使用ANSI编码而浏览器使用UTF-8编码,下载运行就没问题了)

点评

对的,原理都是一样的,不过连console控制台都支持我是没想到的。。。(虽然使用%c进行格式化输出更香。。。)  详情 回复 发表于 2022-11-5 17:50
rhci 发表于 2022-11-5 10:34
冥界3大法王 发表于 2022-11-5 10:35
进来看看国际友人。
正己 发表于 2022-11-5 10:46
看不懂,但是我大受震撼
modesty88 发表于 2022-11-5 10:51
似懂非懂
vip1639253946 发表于 2022-11-5 11:46
这个还真没看明白
cowmaxs 发表于 2022-11-5 17:42
看着有点屌啊,,, 似懂非懂
ljili2003 发表于 2022-11-5 22:22
看似大为震撼,实则一脸懵逼

您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2025-1-12 01:45

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表