thresholds.xml 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334
  1. <?xml version="1.0" encoding="ISO-8859-1"?>
  2. <!DOCTYPE thresholds [
  3. <!ELEMENT thresholds (threshold)+>
  4. <!ELEMENT threshold (description , levels)>
  5. <!ELEMENT description (CDATA)>
  6. <!ELEMENT levels (CDATA)>
  7. <!ATTLIST threshold map ID #REQUIRED>
  8. <!ATTLIST levels width CDATA #REQUIRED>
  9. <!ATTLIST levels height CDATA #REQUIRED>
  10. <!ATTLIST levels divisor CDATA #REQUIRED>
  11. ]>
  12. <!--
  13. Threshold Maps for Ordered Posterized Dither
  14. Each "<threshold>" element defines the map name, description, and an array
  15. of "levels" used to provide the threshold map for ordered dithering and
  16. digital halftoning.
  17. The "alias" attribute provides a backward compatible name for this threshold
  18. map (pre-dating IM v6.2.9-6), and are deprecated.
  19. The description is a english description of what the threshold map achieves
  20. and is only used for 'listing' the maps.
  21. The map itself is a rectangular array of integers or threshold "levels"
  22. of the given "width" and "height" declared within the enclosing <levels>
  23. element. That is "width*height" integers or "levels" *must* be provided
  24. within each map.
  25. Each of the "levels" integer values (each value representing the threshold
  26. intensity "level/divisor" at which that pixel is turned on. The "levels"
  27. integers given can be any postive integers between "0" and the "divisor",
  28. excluding those limits.
  29. The "divisor" not only defines the upper limit and threshold divisor for each
  30. "level" but also the total number of pseudo-levels the threshold mapping
  31. creates and fills with a dither pattern. That is a ordered bitmap dither
  32. of a pure greyscale gradient will use a maximum of "divisor" ordered bitmap
  33. patterns, including the patterns with all the pixels 'on' and all the pixel
  34. 'off'. It may define less patterns than that, but the color channels will
  35. be thresholded in units based on "divisor".
  36. Alternatively for a multi-level posterization, ImageMagick inserts
  37. "divisor-2" dither patterns (as defined by the threshold map) between each of
  38. channel color level produced.
  39. For example the map "o2x2" has a divisor of 5, which will define 3 bitmap
  40. patterns plus the patterns with all pixels 'on' and 'off'. A greyscale
  41. gradient will thus have 5 distinct areas.
  42. -->
  43. <thresholds>
  44. <!-- - - - - - - - - - - - - - - - - - - - - - - - - - - - -
  45. Minimal Dither and Non-Dither Threshold Maps
  46. -->
  47. <threshold map="threshold" alias="1x1">
  48. <description>Threshold 1x1 (non-dither)</description>
  49. <levels width="1" height="1" divisor="2">
  50. 1
  51. </levels>
  52. </threshold>
  53. <threshold map="checks" alias="2x1">
  54. <description>Checkerboard 2x1 (dither)</description>
  55. <levels width="2" height="2" divisor="3">
  56. 1 2
  57. 2 1
  58. </levels>
  59. </threshold>
  60. <!-- - - - - - - - - - - - - - - - - - - - - - - - - - - - -
  61. (dispersed) Ordered Dither Patterns
  62. -->
  63. <threshold map="o2x2" alias="2x2">
  64. <description>Ordered 2x2 (dispersed)</description>
  65. <levels width="2" height="2" divisor="5">
  66. 1 3
  67. 4 2
  68. </levels>
  69. </threshold>
  70. <threshold map="o3x3" alias="3x3">
  71. <description>Ordered 3x3 (dispersed)</description>
  72. <levels width="3" height="3" divisor="10">
  73. 3 7 4
  74. 6 1 9
  75. 2 8 5
  76. </levels>
  77. </threshold>
  78. <threshold map="o4x4" alias="4x4">
  79. <!--
  80. From "Dithering Algorithms"
  81. http://www.efg2.com/Lab/Library/ImageProcessing/DHALF.TXT
  82. -->
  83. <description>Ordered 4x4 (dispersed)</description>
  84. <levels width="4" height="4" divisor="17">
  85. 1 9 3 11
  86. 13 5 15 7
  87. 4 12 2 10
  88. 16 8 14 6
  89. </levels>
  90. </threshold>
  91. <threshold map="o8x8" alias="8x8">
  92. <!-- Extracted from original 'OrderedDither()' Function -->
  93. <description>Ordered 8x8 (dispersed)</description>
  94. <levels width="8" height="8" divisor="65">
  95. 1 49 13 61 4 52 16 64
  96. 33 17 45 29 36 20 48 32
  97. 9 57 5 53 12 60 8 56
  98. 41 25 37 21 44 28 40 24
  99. 3 51 15 63 2 50 14 62
  100. 35 19 47 31 34 18 46 30
  101. 11 59 7 55 10 58 6 54
  102. 43 27 39 23 42 26 38 22
  103. </levels>
  104. </threshold>
  105. <!-- - - - - - - - - - - - - - - - - - - - - - - - - - - - -
  106. Halftones - Angled 45 degrees
  107. Initially added to ImageMagick by Glenn Randers-Pehrson, IM v6.2.8-6,
  108. modified to be more symmetrical with intensity by Anthony, IM v6.2.9-7
  109. These patterns initially start as circles, but then form diamonds
  110. pattern at the 50% threshold level, before forming negated circles,
  111. as it approached the other threshold extereme.
  112. -->
  113. <threshold map="h4x4a" alias="4x1">
  114. <description>Halftone 4x4 (angled)</description>
  115. <levels width="4" height="4" divisor="9">
  116. 4 2 7 5
  117. 3 1 8 6
  118. 7 5 4 2
  119. 8 6 3 1
  120. </levels>
  121. </threshold>
  122. <threshold map="h6x6a" alias="6x1">
  123. <description>Halftone 6x6 (angled)</description>
  124. <levels width="6" height="6" divisor="19">
  125. 14 13 10 8 2 3
  126. 16 18 12 7 1 4
  127. 15 17 11 9 6 5
  128. 8 2 3 14 13 10
  129. 7 1 4 16 18 12
  130. 9 6 5 15 17 11
  131. </levels>
  132. </threshold>
  133. <threshold map="h8x8a" alias="8x1">
  134. <description>Halftone 8x8 (angled)</description>
  135. <levels width="8" height="8" divisor="33">
  136. 13 7 8 14 17 21 22 18
  137. 6 1 3 9 28 31 29 23
  138. 5 2 4 10 27 32 30 24
  139. 16 12 11 15 20 26 25 19
  140. 17 21 22 18 13 7 8 14
  141. 28 31 29 23 6 1 3 9
  142. 27 32 30 24 5 2 4 10
  143. 20 26 25 19 16 12 11 15
  144. </levels>
  145. </threshold>
  146. <!-- - - - - - - - - - - - - - - - - - - - - - - - - - - - -
  147. Halftones - Orthogonally Aligned, or Un-angled
  148. Initially added by Anthony Thyssen, IM v6.2.9-5 using techniques from
  149. "Dithering & Halftoning" by Gernot Haffmann
  150. http://www.fho-emden.de/~hoffmann/hilb010101.pdf
  151. These patterns initially start as circles, but then form square
  152. pattern at the 50% threshold level, before forming negated circles,
  153. as it approached the other threshold extereme.
  154. -->
  155. <threshold map="h4x4o">
  156. <description>Halftone 4x4 (orthogonal)</description>
  157. <levels width="4" height="4" divisor="17">
  158. 7 13 11 4
  159. 12 16 14 8
  160. 10 15 6 2
  161. 5 9 3 1
  162. </levels>
  163. </threshold>
  164. <threshold map="h6x6o">
  165. <description>Halftone 6x6 (orthogonal)</description>
  166. <levels width="6" height="6" divisor="37">
  167. 7 17 27 14 9 4
  168. 21 29 33 31 18 11
  169. 24 32 36 34 25 22
  170. 19 30 35 28 20 10
  171. 8 15 26 16 6 2
  172. 5 13 23 12 3 1
  173. </levels>
  174. </threshold>
  175. <threshold map="h8x8o">
  176. <description>Halftone 8x8 (orthogonal)</description>
  177. <levels width="8" height="8" divisor="65">
  178. 7 21 33 43 36 19 9 4
  179. 16 27 51 55 49 29 14 11
  180. 31 47 57 61 59 45 35 23
  181. 41 53 60 64 62 52 40 38
  182. 37 44 58 63 56 46 30 22
  183. 15 28 48 54 50 26 17 10
  184. 8 18 34 42 32 20 6 2
  185. 5 13 25 39 24 12 3 1
  186. </levels>
  187. </threshold>
  188. <threshold map="h16x16o">
  189. <!--
  190. Direct extract from "Dithering & Halftoning" by Gernot Haffmann.
  191. This may need some fine tuning for symmetry of the halftone dots,
  192. as it was a mathematically formulated pattern.
  193. -->
  194. <description>Halftone 16x16 (orthogonal)</description>
  195. <levels width="16" height="16" divisor="257">
  196. 4 12 24 44 72 100 136 152 150 134 98 70 42 23 11 3
  197. 7 16 32 52 76 104 144 160 158 142 102 74 50 31 15 6
  198. 19 27 40 60 92 132 168 180 178 166 130 90 58 39 26 18
  199. 36 48 56 80 124 176 188 204 203 187 175 122 79 55 47 35
  200. 64 68 84 116 164 200 212 224 223 211 199 162 114 83 67 63
  201. 88 96 112 156 192 216 232 240 239 231 214 190 154 111 95 87
  202. 108 120 148 184 208 228 244 252 251 243 226 206 182 147 119 107
  203. 128 140 172 196 219 235 247 256 255 246 234 218 194 171 139 127
  204. 126 138 170 195 220 236 248 253 254 245 233 217 193 169 137 125
  205. 106 118 146 183 207 227 242 249 250 241 225 205 181 145 117 105
  206. 86 94 110 155 191 215 229 238 237 230 213 189 153 109 93 85
  207. 62 66 82 115 163 198 210 221 222 209 197 161 113 81 65 61
  208. 34 46 54 78 123 174 186 202 201 185 173 121 77 53 45 33
  209. 20 28 37 59 91 131 167 179 177 165 129 89 57 38 25 17
  210. 8 13 29 51 75 103 143 159 157 141 101 73 49 30 14 5
  211. 1 9 21 43 71 99 135 151 149 133 97 69 41 22 10 2
  212. </levels>
  213. </threshold>
  214. <!-- - - - - - - - - - - - - - - - - - - - - - - - - - - - -
  215. Halftones - Orthogonally Expanding Circle Patterns
  216. Added by Glenn Randers-Pehrson, 4 Nov 2010, ImageMagick 6.6.5-6
  217. Rather than producing a diamond 50% threshold pattern, these
  218. continue to generate larger (overlapping) circles. They are
  219. more like a true halftone pattern formed by covering a surface
  220. with either pure white or pure black circular dots.
  221. WARNING: true halftone patterns only use true circles even in
  222. areas of highly varying intensity. Threshold dither patterns
  223. can generate distorted circles in such areas.
  224. -->
  225. <threshold map="c5x5b" alias="c5x5">
  226. <description>Circles 5x5 (black)</description>
  227. <levels width="5" height="5" divisor="26">
  228. 1 21 16 15 4
  229. 5 17 20 19 14
  230. 6 21 25 24 12
  231. 7 18 22 23 11
  232. 2 8 9 10 3
  233. </levels>
  234. </threshold>
  235. <threshold map="c5x5w">
  236. <description>Circles 5x5 (white)</description>
  237. <levels width="5" height="5" divisor="26">
  238. 25 21 10 11 22
  239. 20 9 6 7 12
  240. 19 5 1 2 13
  241. 18 8 4 3 14
  242. 24 17 16 15 23
  243. </levels>
  244. </threshold>
  245. <threshold map="c6x6b" alias="c6x6">
  246. <description>Circles 6x6 (black)</description>
  247. <levels width="6" height="6" divisor="37">
  248. 1 5 14 13 12 4
  249. 6 22 28 27 21 11
  250. 15 29 35 34 26 20
  251. 16 30 36 33 25 19
  252. 7 23 31 32 24 10
  253. 2 8 17 18 9 3
  254. </levels>
  255. </threshold>
  256. <threshold map="c6x6w">
  257. <description>Circles 6x6 (white)</description>
  258. <levels width="6" height="6" divisor="37">
  259. 36 32 23 24 25 33
  260. 31 15 9 10 16 26
  261. 22 8 2 3 11 17
  262. 21 7 1 4 12 18
  263. 30 14 6 5 13 27
  264. 35 29 20 19 28 34
  265. </levels>
  266. </threshold>
  267. <threshold map="c7x7b" alias="c7x7">
  268. <description>Circles 7x7 (black)</description>
  269. <levels width="7" height="7" divisor="50">
  270. 3 9 18 28 17 8 2
  271. 10 24 33 39 32 23 7
  272. 19 34 44 48 43 31 16
  273. 25 40 45 49 47 38 27
  274. 20 35 41 46 42 29 15
  275. 11 21 36 37 28 22 6
  276. 4 12 13 26 14 5 1
  277. </levels>
  278. </threshold>
  279. <threshold map="c7x7w">
  280. <description>Circles 7x7 (white)</description>
  281. <levels width="7" height="7" divisor="50">
  282. 47 41 32 22 33 42 48
  283. 40 26 17 11 18 27 43
  284. 31 16 6 2 7 19 34
  285. 25 10 5 1 3 12 23
  286. 30 15 9 4 8 20 35
  287. 39 29 14 13 21 28 44
  288. 46 38 37 24 36 45 49
  289. </levels>
  290. </threshold>
  291. <!-- - - - - - - - - - - - - - - - - - - - - - - - - - - - -
  292. Special Purpose Dithers
  293. -->
  294. </thresholds>