Hex Artifact Content
Not logged in

Artifact 7228665d7ca2b6c7190c31bc0eb45a71aa72f495:

Wiki page [dmtx command] by chw 2019-04-26 06:47:26.
0000: 44 20 32 30 31 39 2d 30 34 2d 32 36 54 30 36 3a  D 2019-04-26T06:
0010: 34 37 3a 32 36 2e 35 37 35 0a 4c 20 64 6d 74 78  47:26.575.L dmtx
0020: 5c 73 63 6f 6d 6d 61 6e 64 0a 50 20 35 37 38 36  \scommand.P 5786
0030: 30 31 31 30 31 63 31 39 31 30 34 35 66 30 63 35  01101c191045f0c5
0040: 33 38 30 62 39 63 38 32 62 38 30 65 61 63 63 63  380b9c82b80eaccc
0050: 35 39 30 63 0a 55 20 63 68 77 0a 57 20 32 37 31  590c.U chw.W 271
0060: 31 0a 3c 68 32 3e 64 6d 74 78 20 63 6f 6d 6d 61  1.<h2>dmtx comma
0070: 6e 64 3c 2f 68 32 3e 0d 0a 0d 0a 3c 68 33 3e 4e  nd</h2>....<h3>N
0080: 61 6d 65 3c 2f 68 33 3e 0d 0a 0d 0a 3c 62 3e 64  ame</h3>....<b>d
0090: 6d 74 78 3a 3a 2a 3c 2f 62 3e 20 2d 20 69 6e 74  mtx::*</b> - int
00a0: 65 72 66 61 63 65 20 74 6f 20 74 68 65 20 6c 69  erface to the li
00b0: 62 64 6d 74 78 2e 6f 72 67 20 44 61 74 61 20 4d  bdmtx.org Data M
00c0: 61 74 72 69 78 20 43 6f 64 65 20 73 63 61 6e 6e  atrix Code scann
00d0: 65 72 20 6c 69 62 72 61 72 79 2e 0d 0a 0d 0a 3c  er library.....<
00e0: 68 33 3e 53 79 6e 6f 70 73 69 73 3c 2f 68 33 3e  h3>Synopsis</h3>
00f0: 0d 0a 0d 0a 3c 74 74 3e 70 61 63 6b 61 67 65 20  ....<tt>package 
0100: 72 65 71 75 69 72 65 20 64 6d 74 78 3c 2f 74 74  require dmtx</tt
0110: 3e 3c 62 72 3e 0d 0a 3c 74 74 3e 64 6d 74 78 3a  ><br>..<tt>dmtx:
0120: 3a 64 65 63 6f 64 65 20 3f 6f 70 74 69 6f 6e 73  :decode ?options
0130: 3f 3c 2f 74 74 3e 3c 62 72 3e 0d 0a 3c 74 74 3e  ?</tt><br>..<tt>
0140: 64 6d 74 78 3a 3a 61 73 79 6e 63 5f 64 65 63 6f  dmtx::async_deco
0150: 64 65 20 3f 6f 70 74 69 6f 6e 73 3f 3c 2f 74 74  de ?options?</tt
0160: 3e 0d 0a 0d 0a 3c 68 33 3e 44 65 73 63 72 69 70  >....<h3>Descrip
0170: 74 69 6f 6e 3c 2f 68 33 3e 0d 0a 0d 0a 54 68 65  tion</h3>....The
0180: 73 65 20 63 6f 6d 6d 61 6e 64 73 20 61 72 65 20  se commands are 
0190: 75 73 65 64 20 74 6f 20 73 63 61 6e 20 44 61 74  used to scan Dat
01a0: 61 20 4d 61 74 72 69 78 20 43 6f 64 65 73 20 6f  a Matrix Codes o
01b0: 66 66 20 70 69 78 65 6c 20 69 6d 61 67 65 20 64  ff pixel image d
01c0: 61 74 61 2e 0d 0a 0d 0a 3c 74 74 3e 64 6d 74 78  ata.....<tt>dmtx
01d0: 3a 3a 64 65 63 6f 64 65 20 3c 69 3e 70 68 6f 74  ::decode <i>phot
01e0: 6f 45 74 63 3c 2f 69 3e 20 3f 3c 69 3e 73 63 61  oEtc</i> ?<i>sca
01f0: 6c 65 20 74 69 6d 65 6f 75 74 3c 2f 69 3e 3f 3c  le timeout</i>?<
0200: 2f 74 74 3e 0d 0a 0d 0a 20 20 20 20 53 63 61 6e  /tt>....    Scan
0210: 73 20 74 68 65 20 70 68 6f 74 6f 20 69 6d 61 67  s the photo imag
0220: 65 20 3c 74 74 3e 3c 69 3e 70 68 6f 74 6f 45 74  e <tt><i>photoEt
0230: 63 3c 2f 69 3e 3c 2f 74 74 3e 20 66 6f 72 20 44  c</i></tt> for D
0240: 61 74 61 20 4d 61 74 72 69 78 20 43 6f 64 65 20  ata Matrix Code 
0250: 69 6e 66 6f 72 6d 61 74 69 6f 6e 2e 20 41 6c 74  information. Alt
0260: 65 72 6e 61 74 69 76 65 6c 79 2c 20 3c 74 74 3e  ernatively, <tt>
0270: 3c 69 3e 70 68 6f 74 6f 45 74 63 3c 2f 69 3e 3c  <i>photoEtc</i><
0280: 2f 74 74 3e 20 63 61 6e 20 62 65 20 61 20 66 6f  /tt> can be a fo
0290: 75 72 20 65 6c 65 6d 65 6e 74 20 6c 69 73 74 20  ur element list 
02a0: 64 65 73 63 72 69 62 69 6e 67 20 61 20 67 72 65  describing a gre
02b0: 79 73 63 61 6c 65 20 6f 72 20 52 47 42 20 69 6d  yscale or RGB im
02c0: 61 67 65 20 61 73 20 61 20 62 79 74 65 20 61 72  age as a byte ar
02d0: 72 61 79 2e 20 54 68 65 20 65 6c 65 6d 65 6e 74  ray. The element
02e0: 73 20 6d 75 73 74 20 62 65 20 77 69 64 74 68 2c  s must be width,
02f0: 20 68 65 69 67 68 74 2c 20 64 65 70 74 68 20 61   height, depth a
0300: 6e 64 20 62 79 74 65 20 61 72 72 61 79 20 6f 66  nd byte array of
0310: 20 74 68 65 20 69 6d 61 67 65 20 69 6e 20 74 68   the image in th
0320: 69 73 20 6f 72 64 65 72 2e 20 54 68 65 20 6f 70  is order. The op
0330: 74 69 6f 6e 61 6c 20 69 6e 74 65 67 65 72 20 70  tional integer p
0340: 61 72 61 6d 65 74 65 72 20 3c 74 74 3e 3c 69 3e  arameter <tt><i>
0350: 73 63 61 6c 65 3c 2f 69 3e 3c 2f 74 74 3e 20 64  scale</i></tt> d
0360: 6f 77 6e 73 61 6d 70 6c 65 73 20 74 68 65 20 69  ownsamples the i
0370: 6d 61 67 65 20 62 65 66 6f 72 65 20 74 68 65 20  mage before the 
0380: 73 63 61 6e 20 74 61 6b 65 73 20 70 6c 61 63 65  scan takes place
0390: 2e 20 54 68 65 20 6f 70 74 69 6f 6e 61 6c 20 3c  . The optional <
03a0: 74 74 3e 3c 69 3e 74 69 6d 65 6f 75 74 3c 2f 69  tt><i>timeout</i
03b0: 3e 3c 2f 74 74 3e 20 6c 69 6d 69 74 73 20 74 68  ></tt> limits th
03c0: 65 20 73 63 61 6e 20 70 72 6f 63 65 73 73 20 74  e scan process t
03d0: 6f 20 74 68 61 74 20 6d 61 6e 79 20 6d 69 6c 6c  o that many mill
03e0: 69 73 65 63 6f 6e 64 73 2e 20 54 68 65 20 63 6f  iseconds. The co
03f0: 6d 6d 61 6e 64 20 72 65 74 75 72 6e 73 20 61 20  mmand returns a 
0400: 74 68 72 65 65 20 65 6c 65 6d 65 6e 74 20 6c 69  three element li
0410: 73 74 20 6d 61 64 65 20 75 70 20 6f 66 20 61 20  st made up of a 
0420: 66 6c 61 67 20 69 6e 64 69 63 61 74 69 6e 67 20  flag indicating 
0430: 73 75 63 63 65 73 73 20 28 3d 31 29 20 6f 72 20  success (=1) or 
0440: 66 61 69 6c 75 72 65 20 28 3d 30 29 20 6f 66 20  failure (=0) of 
0450: 74 68 65 20 73 63 61 6e 20 70 72 6f 63 65 73 73  the scan process
0460: 2c 20 74 68 65 20 61 6d 6f 75 6e 74 20 6f 66 20  , the amount of 
0470: 6d 69 6c 6c 69 73 65 63 6f 6e 64 73 20 73 70 65  milliseconds spe
0480: 6e 74 20 6f 6e 20 64 65 63 6f 64 69 6e 67 2c 20  nt on decoding, 
0490: 61 6e 64 20 74 68 65 20 73 63 61 6e 20 72 65 73  and the scan res
04a0: 75 6c 74 20 61 73 20 61 20 62 79 74 65 20 61 72  ult as a byte ar
04b0: 72 61 79 2e 0d 0a 0d 0a 3c 74 74 3e 64 6d 74 78  ray.....<tt>dmtx
04c0: 3a 3a 61 73 79 6e 63 5f 64 65 63 6f 64 65 20 3c  ::async_decode <
04d0: 69 3e 70 68 6f 74 6f 45 74 63 20 63 61 6c 6c 62  i>photoEtc callb
04e0: 61 63 6b 3c 2f 69 3e 20 3f 3c 69 3e 73 63 61 6c  ack</i> ?<i>scal
04f0: 65 20 74 69 6d 65 6f 75 74 3c 2f 69 3e 3f 3c 2f  e timeout</i>?</
0500: 74 74 3e 0d 0a 0d 0a 20 20 20 20 53 69 6d 69 6c  tt>....    Simil
0510: 61 72 20 74 6f 20 3c 74 74 3e 64 6d 74 78 3a 3a  ar to <tt>dmtx::
0520: 64 65 63 6f 64 65 3c 2f 74 74 3e 20 62 75 74 20  decode</tt> but 
0530: 74 68 65 20 64 65 63 6f 64 65 72 20 69 73 20 72  the decoder is r
0540: 75 6e 20 61 73 20 61 20 62 61 63 6b 67 72 6f 75  un as a backgrou
0550: 6e 64 20 74 68 72 65 61 64 20 61 6e 64 20 74 68  nd thread and th
0560: 65 20 72 65 73 75 6c 74 20 69 73 20 70 72 65 73  e result is pres
0570: 65 6e 74 65 64 20 74 6f 20 61 20 3c 74 74 3e 3c  ented to a <tt><
0580: 69 3e 63 61 6c 6c 62 61 63 6b 3c 2f 69 3e 3c 2f  i>callback</i></
0590: 74 74 3e 20 70 72 6f 63 65 64 75 72 65 2e 20 49  tt> procedure. I
05a0: 74 20 72 65 71 75 69 72 65 73 20 74 68 65 20 54  t requires the T
05b0: 63 6c 20 63 6f 72 65 20 62 65 69 6e 67 20 62 75  cl core being bu
05c0: 69 6c 74 20 77 69 74 68 20 74 68 72 65 61 64 20  ilt with thread 
05d0: 73 75 70 70 6f 72 74 2c 20 61 6e 64 20 61 20 72  support, and a r
05e0: 75 6e 6e 69 6e 67 20 65 76 65 6e 74 20 6c 6f 6f  unning event loo
05f0: 70 20 73 69 6e 63 65 20 74 68 65 20 63 61 6c 6c  p since the call
0600: 62 61 63 6b 20 69 73 20 69 6e 76 6f 6b 65 64 20  back is invoked 
0610: 61 73 20 61 6e 20 65 76 65 6e 74 20 6f 72 20 64  as an event or d
0620: 6f 2d 77 68 65 6e 2d 69 64 6c 65 20 68 61 6e 64  o-when-idle hand
0630: 6c 65 72 2e 20 54 68 72 65 65 20 61 64 64 69 74  ler. Three addit
0640: 69 6f 6e 61 6c 20 61 72 67 75 6d 65 6e 74 73 20  ional arguments 
0650: 61 72 65 20 70 61 73 73 65 64 20 74 6f 20 3c 74  are passed to <t
0660: 74 3e 3c 69 3e 63 61 6c 6c 62 61 63 6b 3c 2f 69  t><i>callback</i
0670: 3e 3c 2f 74 74 3e 3a 20 61 20 66 6c 61 67 20 69  ></tt>: a flag i
0680: 6e 64 69 63 61 74 69 6e 67 20 73 75 63 63 65 73  ndicating succes
0690: 73 20 28 3d 31 29 20 6f 72 20 66 61 69 6c 75 72  s (=1) or failur
06a0: 65 20 28 3d 30 29 20 6f 66 20 74 68 65 20 73 63  e (=0) of the sc
06b0: 61 6e 20 70 72 6f 63 65 73 73 2c 20 74 68 65 20  an process, the 
06c0: 6e 75 6d 62 65 72 20 6f 66 20 6d 69 6c 6c 69 73  number of millis
06d0: 65 63 6f 6e 64 73 20 66 6f 72 20 64 65 63 6f 64  econds for decod
06e0: 69 6e 67 2c 20 61 6e 64 20 74 68 65 20 73 63 61  ing, and the sca
06f0: 6e 20 72 65 73 75 6c 74 20 61 73 20 61 20 62 79  n result as a by
0700: 74 65 20 61 72 72 61 79 2e 20 54 68 65 20 6f 70  te array. The op
0710: 74 69 6f 6e 61 6c 20 70 61 72 61 6d 65 74 65 72  tional parameter
0720: 73 20 3c 74 74 3e 3c 69 3e 73 63 61 6c 65 3c 2f  s <tt><i>scale</
0730: 69 3e 3c 2f 74 74 3e 20 61 6e 64 20 3c 74 74 3e  i></tt> and <tt>
0740: 3c 69 3e 74 69 6d 65 6f 75 74 3c 2f 69 3e 3c 2f  <i>timeout</i></
0750: 74 74 3e 20 68 61 76 65 20 74 68 65 20 73 61 6d  tt> have the sam
0760: 65 20 6d 65 61 6e 69 6e 67 20 61 73 20 69 6e 20  e meaning as in 
0770: 74 68 65 20 3c 74 74 3e 64 6d 74 78 3a 3a 64 65  the <tt>dmtx::de
0780: 63 6f 64 65 3c 2f 74 74 3e 20 63 6f 6d 6d 61 6e  code</tt> comman
0790: 64 2e 20 54 68 65 20 64 65 66 61 75 6c 74 20 74  d. The default t
07a0: 69 6d 65 6f 75 74 20 76 61 6c 75 65 20 69 73 20  imeout value is 
07b0: 31 30 30 30 20 6d 69 6c 6c 69 73 65 63 6f 6e 64  1000 millisecond
07c0: 73 2e 20 43 61 75 74 69 6f 6e 3a 20 6f 6e 6c 79  s. Caution: only
07d0: 20 61 20 73 69 6e 67 6c 65 20 74 68 72 65 61 64   a single thread
07e0: 20 69 6e 73 74 61 6e 63 65 20 69 73 20 73 75 70   instance is sup
07f0: 70 6f 72 74 65 64 20 70 65 72 20 54 63 6c 20 69  ported per Tcl i
0800: 6e 74 65 72 70 72 65 74 65 72 2c 20 69 2e 65 2e  nterpreter, i.e.
0810: 20 61 6e 6f 74 68 65 72 20 61 73 79 6e 63 68 72   another asynchr
0820: 6f 6e 6f 75 73 20 64 65 63 6f 64 65 20 70 72 6f  onous decode pro
0830: 63 65 73 73 20 63 61 6e 20 6f 6e 6c 79 20 62 65  cess can only be
0840: 20 73 74 61 72 74 65 64 20 77 68 65 6e 20 61 20   started when a 
0850: 70 72 65 76 69 6f 75 73 20 64 65 63 6f 64 65 20  previous decode 
0860: 70 72 6f 63 65 73 73 20 68 61 73 20 66 69 6e 69  process has fini
0870: 73 68 65 64 2e 0d 0a 0d 0a 3c 74 74 3e 64 6d 74  shed.....<tt>dmt
0880: 78 3a 3a 61 73 79 6e 63 5f 64 65 63 6f 64 65 20  x::async_decode 
0890: 61 62 6f 72 74 3c 2f 74 74 3e 0d 0a 0d 0a 20 20  abort</tt>....  
08a0: 20 20 41 62 6f 72 74 73 20 61 20 72 75 6e 6e 69    Aborts a runni
08b0: 6e 67 20 61 73 79 6e 63 68 72 6f 6e 6f 75 73 20  ng asynchronous 
08c0: 64 65 63 6f 64 65 20 70 72 6f 63 65 73 73 2e 0d  decode process..
08d0: 0a 0d 0a 3c 74 74 3e 64 6d 74 78 3a 3a 61 73 79  ...<tt>dmtx::asy
08e0: 6e 63 5f 64 65 63 6f 64 65 20 73 74 61 74 75 73  nc_decode status
08f0: 3c 2f 74 74 3e 0d 0a 0d 0a 20 20 20 20 52 65 74  </tt>....    Ret
0900: 75 72 6e 73 20 74 68 65 20 63 75 72 72 65 6e 74  urns the current
0910: 20 73 74 61 74 65 20 6f 66 20 74 68 65 20 61 73   state of the as
0920: 79 6e 63 68 72 6f 6e 6f 75 73 20 64 65 63 6f 64  ynchronous decod
0930: 65 20 61 73 20 61 20 73 74 72 69 6e 67 3a 20 3c  e as a string: <
0940: 74 74 3e 3c 69 3e 73 74 6f 70 70 65 64 3c 2f 69  tt><i>stopped</i
0950: 3e 3c 2f 74 74 3e 20 77 68 65 6e 20 6e 6f 20 61  ></tt> when no a
0960: 73 79 6e 63 68 72 6f 6e 6f 75 73 20 64 65 63 6f  synchronous deco
0970: 64 65 20 74 68 72 65 61 64 20 68 61 73 20 62 65  de thread has be
0980: 65 6e 20 73 74 61 72 74 65 64 2c 20 3c 74 74 3e  en started, <tt>
0990: 3c 69 3e 72 75 6e 6e 69 6e 67 3c 2f 69 3e 3c 2f  <i>running</i></
09a0: 74 74 3e 20 77 68 65 6e 20 61 20 61 73 79 6e 63  tt> when a async
09b0: 68 72 6f 6e 6f 75 73 20 64 65 63 6f 64 65 20 69  hronous decode i
09c0: 73 20 69 6e 20 70 72 6f 67 72 65 73 73 2c 20 61  s in progress, a
09d0: 6e 64 20 3c 74 74 3e 3c 69 3e 72 65 61 64 79 3c  nd <tt><i>ready<
09e0: 2f 69 3e 3c 2f 74 74 3e 20 77 68 65 6e 20 74 68  /i></tt> when th
09f0: 65 20 6e 65 78 74 20 61 73 79 6e 63 68 72 6f 6e  e next asynchron
0a00: 6f 75 73 20 64 65 63 6f 64 65 20 63 61 6e 20 62  ous decode can b
0a10: 65 20 73 74 61 72 74 65 64 2e 0d 0a 0d 0a 3c 74  e started.....<t
0a20: 74 3e 64 6d 74 78 3a 3a 61 73 79 6e 63 5f 64 65  t>dmtx::async_de
0a30: 63 6f 64 65 20 73 74 6f 70 3c 2f 74 74 3e 0d 0a  code stop</tt>..
0a40: 0d 0a 20 20 20 20 53 74 6f 70 73 20 74 68 65 20  ..    Stops the 
0a50: 62 61 63 6b 67 72 6f 75 6e 64 20 74 68 72 65 61  background threa
0a60: 64 20 66 6f 72 20 61 73 79 6e 63 68 72 6f 6e 6f  d for asynchrono
0a70: 75 73 20 64 65 63 6f 64 69 6e 67 20 69 66 20 69  us decoding if i
0a80: 74 20 68 61 73 20 62 65 65 6e 20 69 6d 70 6c 69  t has been impli
0a90: 63 69 74 65 6c 79 20 73 74 61 72 74 65 64 20 62  citely started b
0aa0: 79 20 61 20 70 72 69 6f 72 20 3c 74 74 3e 64 6d  y a prior <tt>dm
0ab0: 74 78 3a 3a 61 73 79 6e 63 5f 64 65 63 6f 64 65  tx::async_decode
0ac0: 3c 2f 74 74 3e 2e 20 54 68 69 73 20 63 61 6e 20  </tt>. This can 
0ad0: 62 65 20 75 73 65 66 75 6c 20 74 6f 20 63 6f 6e  be useful to con
0ae0: 73 65 72 76 65 20 6d 65 6d 6f 72 79 20 72 65 73  serve memory res
0af0: 6f 75 72 63 65 73 2e 0d 0a 0a 5a 20 38 63 37 63  ources....Z 8c7c
0b00: 30 35 65 38 63 63 30 32 31 63 30 31 62 66 37 37  05e8cc021c01bf77
0b10: 63 62 65 39 31 64 34 38 37 38 64 33 0a           cbe91d4878d3.