资讯专栏INFORMATION COLUMN

图片转字符

shiguibiao / 2994人阅读

摘要:处理图片我比较熟悉,刚好有库可以处理图片,简直不要太合适对图片的处理也比较简单,读取图片,灰度处理,获取每个像素点的灰度值,将灰度值的深浅转换为字符。

引言

前几天看到一幅用字符(准确的说是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

相关文章

  • python 图片在线字符画预览

    摘要:文章链接关于图片转字符画,相信大家都不陌生,经常出现在个超有趣的项目中。今天我也来实践这个有趣的项目,更进一步的是把这个功能做成一个在线的网站,直接上传图片生成字符画,在线预览可以让更多的人来体验。至此,生成字符画的脚本完成了。 文章链接:https://mp.weixin.qq.com/s/yiFOmljhyalE8ssAgwo6Jw 关于python图片转字符画,相信大家都不陌生...

    CarterLi 评论0 收藏0
  • 图片ascii字符

    摘要:以上,我们完成了的初步认识扩展使用做反转图首先反转的意思是指,把每个像素点的每个值都与相减的值不改变,减完之后的值再次组成图片,此时得到的新图片就是我们的反转图片。第二步转灰度图或是,又称灰阶图。用灰度表示的图像称作灰度图。 效果图 showImg(https://segmentfault.com/img/remote/1460000008704923?w=1813&h=845); 基...

    SnaiLiu 评论0 收藏0
  • 图片ascii字符

    摘要:以上,我们完成了的初步认识扩展使用做反转图首先反转的意思是指,把每个像素点的每个值都与相减的值不改变,减完之后的值再次组成图片,此时得到的新图片就是我们的反转图片。第二步转灰度图或是,又称灰阶图。用灰度表示的图像称作灰度图。 效果图 showImg(https://segmentfault.com/img/remote/1460000008704923?w=1813&h=845); 基...

    wing324 评论0 收藏0
  • 图片ascii字符

    摘要:以上,我们完成了的初步认识扩展使用做反转图首先反转的意思是指,把每个像素点的每个值都与相减的值不改变,减完之后的值再次组成图片,此时得到的新图片就是我们的反转图片。第二步转灰度图或是,又称灰阶图。用灰度表示的图像称作灰度图。 效果图 showImg(https://segmentfault.com/img/remote/1460000008704923?w=1813&h=845); 基...

    0xE7A38A 评论0 收藏0
  • 用纯前端的方式来实现图片字符

    摘要:最近花了几天时间,做了一个图片转字符画的工具,一开始想做成用服务器来生成图像的形式,但是后来发现可以不依赖服务器生成图片,顺便还能把项目托管到上,因此就把项目做成了纯前端的形式。 最近花了几天时间,做了一个图片转字符画的工具,一开始想做成用服务器来生成图像的形式,但是后来发现可以不依赖服务器生成图片,顺便还能把项目托管到 Github Pages 上,因此就把项目做成了纯前端的形式。 ...

    NikoManiac 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<