摘要:处理图片我比较熟悉,刚好有库可以处理图片,简直不要太合适对图片的处理也比较简单,读取图片,灰度处理,获取每个像素点的灰度值,将灰度值的深浅转换为字符。
引言
前几天看到一幅用字符(准确的说是ascii码)绘制的doge图像,觉得挺有意思
</>复制代码
* @Date
* @Desc
*/
将他放到代码的注释部分,加上了Doge bless you! No bug!的字样,放在了代码的注释部分(新建脚本的时候自动添加),同事看到了觉得挺有意思,问我怎么搞得。
后来我仔细看了下这幅图,分析了下,都是用ascii字符绘制的,通过ascii字符的占用像素多少表现图片的深浅,想通了原理决定自己实现一个图片转字符的工具。
我比较熟悉php,刚好php有GD库可以处理图片,简直不要太合适~
对图片的处理也比较简单,读取图片,灰度处理,获取每个像素点的灰度值,将灰度值的深浅转换为ascii字符。
都去图片之前,首先要做的就是统一接口,实现读取多重类型的图片,php的GD库中,没有直接提供相关的函数,造个小轮子:
</>复制代码
class ImageCreate
{
// 要处理的目标,可能是文件
protected $target = "";
// 文件的类型
protected $type = 0;
protected $supportTypes = [
1 => "imagecreatefromgif", // gif
2 => "imagecreatefromjpeg", // jpg
3 => "imagecreatefrompng", // png
6 => "imagecreatefrombmp", // bmp
];
public function __construct($target, $type = 0)
{
$this->target = $target;
$this->type = $type;
}
public function create()
{
$type = $this->getType();
if (!isset($this->supportTypes[$type])) {
throw Exception("Type of image not support. Abstract[type[{$this->type}]]");
}
$func = $this->supportTypes[$type];
if (method_exists($this, $func)) {
$ret = $this->$func();
} else {
$ret = $func($this->target);
}
return $ret;
}
protected function getType()
{
if (!$this->type) {
$this->type = exif_imagetype($this->target);
}
return $this->type;
}
}
使用时候不用关心图片类型,类库内部帮你做了处理,(new ImageCreate($image))->create()就获取到了图片resource句柄,供下一步使用。
php读取像素点信息用下面的公式,其中$x,$y分别表示像素点的位置。
</>复制代码
$rgb = imagecolorat($this->resourceImage, $x, $y);
$r = ($rgb >> 16) & 0xFF;
$g = ($rgb >> 8) & 0xFF;
$b = $rgb & 0xFF;
像素灰度化,关于灰度化可以参考百度百科的解释
</>复制代码
灰度化,在RGB模型中,如果R=G=B时,则彩色表示一种灰度颜色,其中R=G=B的值叫灰度值,因此,灰度图像每个像素只需一个字节存放灰度值(又称强度值、亮度值),灰度范围为0-255。一般有以下四种方法对彩色图像进行灰度化。
一般有以下四种方法对彩色图像进行灰度化处理:分量法 最大值法平均值法加权平均法
这里使用了加权平均法
</>复制代码
根据重要性及其它指标,将三个分量以不同的权值进行加权平均。由于人眼对绿色的敏感最高,对蓝色敏感最低,因此,按下式对RGB三分量进行加权平均能得到较合理的灰度图像。
处理公式 intval($r 0.228 + $g 0.587 + $b * 0.114)
更详细的内容这里就不讨论了,有兴趣的可以自行查阅资料,这里主要使用了加权平均法求灰度值
这里插叙下,当我完成开发后,发现,稍微大点的图片,输出信息很容易就换行了,看起来一团糟,这里还要做一个比例缩放的功能,沿着宽高方向做不同的缩放,将多个像素点合并为1个,合并的时候简单的取加权平均值。
使用</>复制代码
gray = (gray0 + gray1 + ... + grayn)/n;
这里开发已经基本完成,已经放到github,发布到composer,想看看效果的只需要通过composer命令composer require aizuyan/img2ascii安装就可。
安装完成之后,会有vendor/bin/img2ascii可执行文件,向下面这样执行他就可以了,第一个命令是要处理的图片,-x是宽度方向像素缩小比例,-y是高度方向缩小比例(由于编辑器中ascii字符显示的时候一般高度是宽度的两倍,所以缩放的时候刚好反过来)
</>复制代码
➜ bin img2ascii ~/Desktop/abm.jpg -x 10 -y 20
::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::
::::::::::::::::::::::::::::::rrii: s:::::::::::::::::::::::
:::::::::::::::::::::::::::iisMN8B99r:::::::::::::::::::::::
:::::::::::::::::::::::::: iq0B8M0000r::::::::::::::::::::::
::::::::::::::::::::::::: @B8B09BB0@0B :::::::::::::::::::::
:::::::::::::::::::::::::r@BBNB08880B0v:::::::::::::::::::::
:::::::::::::::::::::::ir000B8NB888@B@Noi:::::::::::::::::::
::::::::::::::::::::::i00000BB8@B@@808BBsni:::::::::::::::::
:::::::::::::::::::::: 0B@B00no7vr7ii7rntipi::::::::::::::::
::::::::::::::::::::::tBB9mmoi;i i ii:;7s :i::::::::::::::::
:::::::::::::::::::::i000Nnsirvir i isi::::::::::::::::::
:::::::::::::::::::::i0B0nmmtii i rir:ip7::::::::::::::::::
::::::::::::::::::::7in8npstrpsrqpiisqtorr :::::::::::::::::
::::::::::::::::::::vvp9mtvppoqirs ;i7ovivi:::::::::::::::::
:::::::::::::::::::: orq0ttr irr7;ii :rvi:::::::::::::::::
:::::::::::::::::::::ivr9tmi;i7oitr iitqvi::::::::::::::::::
:::::::::::::::::::::: imnpsrt7soprri7isqr::::::::::::::::::
::::::::::::::::::::::: n9tsisqi :i :rvr7:::::::::::::::::::
::::::::::::::::::::::: qq9tr7iompvvoi7i::::::::::::::::::::
:::::::::::::::::::::::ioipmmqpiiiiri ::::::::::::::::::::::
::::::::::::::::::::i rrvrirsrnr7viir7ii::::::::::::::::::::
::::::::::: , ,. iv: ;riiiviirorrtrviirii ,,, :::::::::::::
::::::::::ii. iiii7iiiriri77r7ivri;i;:., . .r:::::::::::
::::::iri vv . .. :rr7;i :iiii:iiiviirir, . ..v;: i ::::::
:::i:iv;:rr . ... i i rr::;i r:r riiii: ... . :rr; i;: :::
:: v7v :::r. .. . :riiiiviiiiii:::iii. . . . r:ir:i ri::
::smtqiirr :. .......,iii;r; iiriii: . .. :iriv;irii::
:rmppir r;ri., ... .. . , , , . .. . . ,,7i;ir irr :
:instiv: r . i :, , ,, . . . .... , .rrvi:i vr:
:smNniv isp rq77i :::,,: :,::,,,, iipsr .viv;ii r7;:
下面是几张转换先后图片的效果。
</>复制代码
n00nnNM8@8M99@B8088B8B0NsnMMMmm00@8B8B@BB0M9MmmmN080Nn9MB00@@B08noonmmm
9snM90NM@B900089B08B@B8rtnn0NMnm99M9nN0N0NN0nNmmN@0B8N990@000sqtssooots
M8B9n889M@80M08npm0NMmttiiii:ii : , :i i i7mM08MM09MnpstpsspoqqnN
m00NN0pmnM0pttonmq7 : . .... . , ,,, :i iss90morttqoom9N9nr
tmnnsN7qoNBMmovi , . . . . ... , i:: ::: :: ,, :iirpopnMBN9Mnnnn
ms99p7iqNNnqr: . . ..... . . . ..... iir iiiii:i::: ,, ir7mmnrnnmmMM
9M000mmmnq: . .... . . ... .. , :smvii;iirrrviiiii :irrirm8B
0BB00@Bmr ....... .. . . . . . , :i7s:v7i7rrivri77ri;i , ,, iip
8B00B08s . . . . ... . . ,,,:ir7iivqpqqor7ivv7ir : ::::i
B8B8B0s . .. ... .. . . ... , ,,,: iiotistpttsrrqssii::i i i
0BBBBo ., .... . .... . , , , , i oooorstnsoprosoviivir7 :rv
8@8Mi,. .. .. . . , , , , , : iqsrtnqotppsmsoporpttrpqtq
MMm ..,. ... .. . . , , , , ii imnmnnmrrsmnnmmmmmmmmmmrnB
Mmr .., ..... ,,, ,, ,, .... iii7n9nmtnrnmnnm9M9909MNm90BB
mp:. ., .. ,, ,, , , : ,, , ,:ivtMM9nnnmnnm00000N09099888@
0p,. . , :,, , ,, , i i:::: :: :: ivtM00NNnmMM90N9N0N9NMB@B@00
Ns . , :: isri , , : rr7irriivi:irri iroM0MN9N0NN9000009N98@8@0B@
0mi :iii:ivr:, .. .. ivvi::istos7iri irq0088008088NMMMM9M8@80880@
MNpi:iri:i:: .. . . iii i i::: iis0000090@000M0nN08B0B0@808
09MN7: ;7 ,,. . ,,: :: ::: ::: rqn@B@80NN90nttq000B800080B
N0M0M7rri:..: i:ivir ,,,, ,,,::: ,, : :: irtnM8009ti7iiis0B8B@8BB0@B
NN0MN99mm: :nmnssnnnrr: , ,, :,, , :::i iivivi:;iririsNB@008B0BB
NMN0mmrtp i@B@8BB9Npr: , , , ::::: ii i :rr iiirr0nn@@B0@0M
9mmmpt7i: . p80B@Nnqi: ,,,,,: :::::::::ii ii ii:i; iiiirsmm00nmMMm0
09mmmnti , oN0@Nmsii: ::::, : ::::ii ii i i :iiiiririrtmmnnnnssnN
N9N0Mrqq:, rpmpopoi :: ::::::::: : :iiiiiii ::ir:ri irvv7tnnn09oq7i
0NMNn99rr :riqssrpsrr :: ::::: : iii ii r iir :;iri:iv7ipn99opsi
B@Mm9990mi:iiiiriiviii;ii iii:ii: irri r ir rr: :riri:ri: :iiiiioiii7
qssptrn9nnnnosir: iiiiii:: :ri rii r: ii: riii ii ir:iiirvvrirvi:;
: r; :i: ri r: i rii :r : iir ri :;iriri ii i rrr ;;: :riii
rvriivri7rviviviiiiiv; ir:i: :: :ir :rr i ii i ii:i;; ;i:;i
i;ii7iiiriiiviiiiii7ii ii : rir i iiiiii ii i ii iiiii r r:iv:i
iviiiiiiirrviiii t v;rr : i i i iiii iii i i iiir:;;iir
再来张美女图片(不知道有没有侵权,侵权删)
</>复制代码
: iiii:iiiiiqsmM9M@9qtossrntNMmnnM900B@BBB0@8BB@0@BMprpontpp
:i r :iirrrm0@8NMBnttptponm0Mnmmnn@B880@@888BB8BBB8nsqorpor
:ri:i r:iiiisqnmno9mopsqsqonnnnnnmN8088808B8B@B080B8svi7tsqs
iii ii ir:;7tmnMMmMmotr7rvrmM0B88Mn9B8B@88@8@B@8B@B8tppsnnmr
i iii:rirqspmrrmntqppptoNnM9ioqnN08B0888BBB08B0MNsiiiirr7
::::::i i:isnMM0n9nstipM0BMri , , rNB000B88@080B@ppsrorqo
::: ::: iii ittqrtnnstpBB8ni, ... ,, i9880800080nmmiriivrii
: i :vnn00mMnptM808i , .. ,: t9NMB0000BB80prvrv7sv
, ,, ,:i i irqsotqnps80Bq ,,,,:: ::iiM000088BN0mntv7i7vri
, ,,:::: imn0Mmmtsnrrn7, r , vii8NN8B88808NMiiivivrr
,, ,,,:::: iv7orqrNstr i , . , :09B000809MMNr77i7iii
,, , ::: 7nmn9rnmqoqi ,,, ... , : . i888@0@0B00mnri;rr;7i
, , , :: iiooqn0rm0Mii:,,,.. ,, : :t00@0N0080NMNpiivii v
, ,, : :vnmn9snmpm98Mmri,, . : iM00BBB88B0ntpv ir :r
,, , :::rrpsopmMpM0@08ri7;: .. vB9nm0BN808M0mmtvivivi
:::mnmntm9rsq0r;:: iii;rtB80B0npm88B8mrooi; : rr
, iiitpomNni . ... rv8000900B0N8000009svi:;ivr
, ,, , rmmmmqnmm0N: . .. ,: 008MmB8B0N88Mmrporv;r:rr;
, , , iiqtsppmt; : .... ,, iqnp008008800mmqi; ;vi
, , :qnii,.., ,,, ,,.... ,:rr9B00nimNnmrtsiiiii r
. .. ri ... .. ,,.. . ,, 7n08BMi Bmmprvrr :;i;
.. . , , p,,.. ..... , . . ..irinB0Bsio09Nmpii;;;ir
.. . .. , , mi, . ... . ,... ..:n9rvq@8pimtsrr r::::i
.. ...,, ,, tpi,,. .. . .. . ... ..i0, p@nn00Mntviirir
. .. . , ,in0ni ,, .. ... ,, .. ,. ii ::vm8nsrii r;:v
.. . . , rtmmi ,,..... . . . . ... ,7Bnmp7v: iir
. ... , , mMM9m i: .. .... ,.. ,.... . snoii r:r
....... , iimnmmq , .. ., . . . ..,rnrrii:::i:
. . . ,,, m00Mm0i::i:,, .. . . ,,... .,qmmt7i rri
.. . ,,, ip999n90i ,:,,,,. .. ... . .. . imqp7;ir:ir
. .. ... , iq990n99r,. .. : . . , .. 0imMmsirvit7
.... ., ,,ipN0M0900i .. ,i: , .. . 7v:iii rr rvi
... p0M9mMN09 . . , ,:: ,,,,, ,. . ii,rBMoq7ivtr
. ....., ,, s08009@0No,. .. . ,, ::: . ,i:,:rir :;ivi
.... , ,ipNMNn0M9N9 . ... . ,, . . . i :mviir:ir
... . ..,,, ir0NM9N@@88i . . . ... . .: 7iir ii:
... . , in99n9NN09v .. . . .. . .:i,, , pii rivr
.. , , ioBB80M0@BN,.. . .. . . . ,i, io7iiiiii
.. . , , iNNMnNMNN: . ... . ... . . , ,isrr ;iri
.... . , t088N08B;. .... . . ... . , :tmrq7iro7
... . ,, v9NNMMBn,.... .. . ...... , .. ,:oi: ;riv:
.. . . , ii000999 ,. .. . . .. ,.. immssvqvpi
.. .. ,,:i009N9M, .. .. .. .... , ,,rq7: irioi
. . . .,, :iN9NN9r. . . . .. .., , sm9priirri
... . , v80B0v . .. . .. .. .. , r7v:ririqi
. . .. ,,,, r0MM7 ,.... ... . ::::: , 7oprsviir
.. .. .,, , :00B . . . ... , ,. , ,iiir iirii
, .... ,,,,::09i,,. . . . . : , , ,, , ::irri ;r:
,, . . , qs .. . . . , :: ::: : : iivi7p7
, ,, . , Nr . .. . . , :: :: : : , ., vi:iir ii
, , , , ,,: 0i,.. . .. . , ::: ::: : ...,:t7v7irsp7
, , ,, :rmv .... . ., ,,, ,, .... . . po7rriior
,, ,, ::ir , .. . . . .. . rnppptspr
,, , , :::: i.,.... . . . ... .... . .. iiirivsq
是不是还挺有意思的,下面是
github地址 github-img2ascii
composer地址 composer-img2ascii
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/22133.html
摘要:文章链接关于图片转字符画,相信大家都不陌生,经常出现在个超有趣的项目中。今天我也来实践这个有趣的项目,更进一步的是把这个功能做成一个在线的网站,直接上传图片生成字符画,在线预览可以让更多的人来体验。至此,生成字符画的脚本完成了。 文章链接:https://mp.weixin.qq.com/s/yiFOmljhyalE8ssAgwo6Jw 关于python图片转字符画,相信大家都不陌生...
摘要:以上,我们完成了的初步认识扩展使用做反转图首先反转的意思是指,把每个像素点的每个值都与相减的值不改变,减完之后的值再次组成图片,此时得到的新图片就是我们的反转图片。第二步转灰度图或是,又称灰阶图。用灰度表示的图像称作灰度图。 效果图 showImg(https://segmentfault.com/img/remote/1460000008704923?w=1813&h=845); 基...
摘要:以上,我们完成了的初步认识扩展使用做反转图首先反转的意思是指,把每个像素点的每个值都与相减的值不改变,减完之后的值再次组成图片,此时得到的新图片就是我们的反转图片。第二步转灰度图或是,又称灰阶图。用灰度表示的图像称作灰度图。 效果图 showImg(https://segmentfault.com/img/remote/1460000008704923?w=1813&h=845); 基...
摘要:以上,我们完成了的初步认识扩展使用做反转图首先反转的意思是指,把每个像素点的每个值都与相减的值不改变,减完之后的值再次组成图片,此时得到的新图片就是我们的反转图片。第二步转灰度图或是,又称灰阶图。用灰度表示的图像称作灰度图。 效果图 showImg(https://segmentfault.com/img/remote/1460000008704923?w=1813&h=845); 基...
摘要:最近花了几天时间,做了一个图片转字符画的工具,一开始想做成用服务器来生成图像的形式,但是后来发现可以不依赖服务器生成图片,顺便还能把项目托管到上,因此就把项目做成了纯前端的形式。 最近花了几天时间,做了一个图片转字符画的工具,一开始想做成用服务器来生成图像的形式,但是后来发现可以不依赖服务器生成图片,顺便还能把项目托管到 Github Pages 上,因此就把项目做成了纯前端的形式。 ...
阅读 1656·2021-11-24 09:39
阅读 1211·2021-11-22 15:11
阅读 2321·2021-11-19 11:35
阅读 1698·2021-09-13 10:37
阅读 2659·2021-09-03 10:47
阅读 2263·2021-08-30 09:47
阅读 1722·2021-08-20 09:39
阅读 3025·2019-08-30 14:13