图片转字符原理

图片转字符通常分以下几种:

  1. 黑白算法
  2. 灰度算法
  3. 边际追踪/界定算法

黑白算法

黑白算法最简单

低保真度解法:

  1. ##### #### ## #####
  2. # # # #
  3. # ## # #
  4. # # # #
  5. # #### ## #

高保真度解法:

  1. 88888 8888 d8b 88888
  2. 8 8 ]b 8
  3. 8 88 Yb 8
  4. 8 8 o d8 8
  5. 8 8888 YP 8

低保真度解法仅仅简单地通过字符 # 和空白符表示图形区域地颜色,
高保真算法则使用 12 个字符对应一个 2*2 的区域,对照表如下:
































Pattern:
  1. ..
    ..
  1. .X
    ..
  1. X.
    ..
  1. ..
    X.
  1. ..
    .X
  1. XX
    ..
  1. ..
    XX
  1. X.
    X.
  1. .X
    .X
  1. .X
    XX
  1. XX
    .X
  1. XX
    X.
  1. XX
    XX
Character:
  1. `
  1. .
  1. ,
  1. _
  1. (
  1. )
  1. J
  1. L
  1. 7
  1. P
  1. 8

灰度算法

灰度算法的基本目标是追求转换后的每个字符亮度都尽可能接近该区域原始图像的亮度,
因此在文字渐渐缩小或者与人眼的距离越来越远时,看起来越发接近图片。
边缘、边框以及其它高对比度的地方应该使用更加契合其结构的字符。

灰度算法需要使用实现亮度-字符的转换,大多数具体实现都采用 1 个像素对 1 个字符的转换,
“state of the art”算法使用 4 个像素对应一个字符,并且能够提供更清晰的结果。

边际追踪/界定算法

边际界定算法看起更加复杂,但其实不然!

全文主要翻译自 java.de