CN102682262B - 条形码读取装置 - Google Patents

条形码读取装置 Download PDF

Info

Publication number
CN102682262B
CN102682262B CN201210024501.4A CN201210024501A CN102682262B CN 102682262 B CN102682262 B CN 102682262B CN 201210024501 A CN201210024501 A CN 201210024501A CN 102682262 B CN102682262 B CN 102682262B
Authority
CN
China
Prior art keywords
data
bar code
scope
variable
unstable
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Active
Application number
CN201210024501.4A
Other languages
English (en)
Other versions
CN102682262A (zh
Inventor
北川彻
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Casio Computer Co Ltd
Original Assignee
Casio Computer Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Casio Computer Co Ltd filed Critical Casio Computer Co Ltd
Publication of CN102682262A publication Critical patent/CN102682262A/zh
Application granted granted Critical
Publication of CN102682262B publication Critical patent/CN102682262B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06KGRAPHICAL DATA READING; PRESENTATION OF DATA; RECORD CARRIERS; HANDLING RECORD CARRIERS
    • G06K7/00Methods or arrangements for sensing record carriers, e.g. for reading patterns
    • G06K7/10Methods or arrangements for sensing record carriers, e.g. for reading patterns by electromagnetic radiation, e.g. optical sensing; by corpuscular radiation
    • G06K7/10544Methods or arrangements for sensing record carriers, e.g. for reading patterns by electromagnetic radiation, e.g. optical sensing; by corpuscular radiation by scanning of the records by radiation in the optical part of the electromagnetic spectrum
    • G06K7/10821Methods or arrangements for sensing record carriers, e.g. for reading patterns by electromagnetic radiation, e.g. optical sensing; by corpuscular radiation by scanning of the records by radiation in the optical part of the electromagnetic spectrum further details of bar or optical code scanning devices
    • G06K7/10851Circuits for pulse shaping, amplifying, eliminating noise signals, checking the function of the sensing device
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06KGRAPHICAL DATA READING; PRESENTATION OF DATA; RECORD CARRIERS; HANDLING RECORD CARRIERS
    • G06K7/00Methods or arrangements for sensing record carriers, e.g. for reading patterns
    • G06K7/10Methods or arrangements for sensing record carriers, e.g. for reading patterns by electromagnetic radiation, e.g. optical sensing; by corpuscular radiation
    • G06K7/10544Methods or arrangements for sensing record carriers, e.g. for reading patterns by electromagnetic radiation, e.g. optical sensing; by corpuscular radiation by scanning of the records by radiation in the optical part of the electromagnetic spectrum
    • G06K7/10554Moving beam scanning

Landscapes

  • Physics & Mathematics (AREA)
  • Electromagnetism (AREA)
  • Engineering & Computer Science (AREA)
  • Health & Medical Sciences (AREA)
  • General Health & Medical Sciences (AREA)
  • Toxicology (AREA)
  • Artificial Intelligence (AREA)
  • Computer Vision & Pattern Recognition (AREA)
  • General Physics & Mathematics (AREA)
  • Theoretical Computer Science (AREA)
  • Cash Registers Or Receiving Machines (AREA)
  • Character Input (AREA)

Abstract

本发明提供一种条形码读取装置,其具备:扫描部,其通过射出激光并接收反射光来扫描条形码,从而取得图像数据;判定部,其将由所述扫描部取得的图像数据中、所述激光的摆动宽度的端部分判定为数据不稳定范围,将不是该数据不稳定范围的部分判定为数据稳定范围;以及解码部,其对于由所述判定部判定出的数据不稳定范围,将图像数据相对于阈值的误差的允许度设定得较低,并使用该阈值和允许度来对该数据不稳定范围进行解码,对于由所述判定部判定出的数据稳定范围,将图像数据相对于所述阈值的误差的允许度设定得较高,并使用该阈值和允许度来对该数据稳定范围进行解码,其中,所述阈值用于判定所述条形码的黑条和白空的数据宽度。

Description

条形码读取装置
技术领域
本发明涉及条形码读取装置以及计算机程序制品。
背景技术
目前已知有使用激光来扫描一维条形码(bar code)的条形码读取装置。该条形码读取装置在横向方向摆动射出激光,接收由条形码反射的反射光得到图像数据,使用预定阈值对该图像数据进行解码,由此来扫描条形码。该图像数据具有将对应于条形码的图像得到的黑条(black bar)的数据宽度和白空(white space)的数据宽度顺次(交替)排列而得的数据结构。此外,所谓预定阈值是用于判定黑条和白空的数据宽度(粗细)的阈值。
根据条形码读取装置的种类、光学系统(透镜的倍率)、条的粗细等,预先设定在图像数据编码中使用的阈值。此外,还已知有通过来自外部的设定输入来使图像数据编码中使用的阈值可变的条形码读取装置(例如,参照日本特开平6-290294号公报)。
但是,在现有的条形码读取装置中,有时在激光的摆动宽度(照射宽度)的两端部分反射光不充足,得到的图像数据不稳定,因此存在有可能无法准确地取得黑条和白空的比率这样的特性。因此,若在激光的摆动宽度的两端部分扫描条形码,则有可能黑条和白空的比率看起来不准,解码这样的图像数据的结果是可能误读。
作为避免误读的方法,想到了在现有的条形码读取装置中严格调整阈值的方法。所谓严格调整阈值是指将图像数据相对于阈值的误差的允许度调整得较低。
但是,在单纯地严格调整阈值时,针对黑条和白空的比率正确的激光摆动宽度中央部分的扫描数据的读取也变得严格,因此,在相同宽度的黑条或白空的印刷比率即使略微存在误差时、或离开读取距离时等情况下,有可能无法读取。
发明内容
本发明的课题是提高条形码读取的正确性以及响应性。
本发明的条形码读取装置,其具备:扫描部,其通过射出激光并接收反射光来扫描条形码,从而取得图像数据;判定部,其将由所述扫描部取得的图像数据中、所述激光的摆动宽度的端部分判定为数据不稳定范围,将不是该数据不稳定范围的部分判定为数据稳定范围;以及解码部,其对于由所述判定部判定出的数据不稳定范围,将图像数据相对于阈值的误差的允许度设定得较低,并使用该阈值和允许度来对该数据不稳定范围进行解码,对于由所述判定部判定出的数据稳定范围,将图像数据相对于所述阈值的误差的允许度设定得较高,并使用该阈值和允许度来对该数据稳定范围进行解码,其中,所述阈值用于判定所述条形码的黑条和白空的数据宽度。
本发明的计算机程序产品,其可被用于条形码读取装置的计算机读取,该计算机程序产品对执行计算机处理的命令进行编码,其中,所述计算机处理包括以下步骤:扫描步骤,通过射出激光并接收反射光来扫描条形码,从而取得图像数据;判定步骤,将通过所述扫描步骤取得的图像数据中、所述激光的摆动宽度的端部分判定为数据不稳定范围,将不是该数据不稳定范围的部分判定为数据稳定范围;以及解码步骤,对于通过所述判定步骤判定出的数据不稳定范围,将图像数据相对于阈值的误差的允许度设定得较低,并使用该阈值和允许度来对该数据不稳定范围进行解码,对于通过所述判定部判定出的数据稳定范围,将图像数据相对于所述阈值的误差的允许度设定得较高,并使用该阈值和允许度来对该数据稳定范围进行解码,其中,所述阈值用于判定所述条形码的黑条和白空的数据宽度。
根据本发明,能够提高条形码读取的正确性以及响应性。
附图说明
图1是表示本发明实施方式的条形码读取装置的结构的框图。
图2是表示扫描部的结构的框图。
图3是表示扫描处理的流程图。
图4是表示扫描处理的初始化处理的流程图。
图5是表示关于条形码的全部图像数据宽度、左端的数据不稳定范围、数 据不稳定以及稳定范围、条形码开始位置的示意图。
图6是表示扫描处理的条形码开始位置解析处理的流程图。
图7是表示关于条形码的1字符的数据宽度、字符开始位置、从左端到字符开始位置为止的数据宽度的示意图。
图8是表示扫描处理的数据不稳定范围判定处理的流程图。
图9是表示扫描处理的4值化处理的流程图。
具体实施方式
以下,参照附图对本发明涉及的实施方式进行详细说明。此外,本发明并不局限于图示的例子。
首先,参照图1和图2对本实施方式的装置结构进行说明。
图1是表示本实施方式的条形码读取装置10的结构的框图。
图2是表示扫描部18的结构的框图。
如图1所示,本实施方式的条形码读取装置10是读取并管理作为读取对象物的一维条形码的手持终端。条形码读取装置10例如在仓库、小商店店铺等中使用。条形码例如是对摆放于仓库或店铺等的商品附加的条形码。
条形码读取装置10具备:CPU(中央处理器)11、操作部12、RAM(随机存取存储器)13、显示部14、ROM(只读存储器)15、无线通信部16、闪速存储器(Flash Memory)17、扫描部18、报知部19、电源部20。除电源部20的条形码读取装置10的各部分经总线21相互连接。
CPU11控制条形码读取装置10的各部分。CPU11从ROM15读出各种程序中指定的程序并在RAM13中展开,通过展开后的程序间的协作来执行各种处理。
CPU11按照扫描程序151将扫描部18取得到的图像数据中激光的摆动宽度的两端部分判定为数据不稳定范围,将不是该数据不稳定范围的中央部分判定为数据稳定范围。然后,CPU11对于所述判定出的数据不稳定范围,将图像数据相对于阈值的误差的允许度设定得较低,使用该阈值和允许度来对该数据不稳定范围进行解码,该阈值用于判定所述条形码的黑条和白空的数据宽度。然后,CPU11对于所述判定出的数据稳定范围,将图像数据相对于所述阈值的误差的允许度设定得较高,使用该阈值和允许度来对该数据稳定范围进 行解码。
操作部12具备由文字数据键等各种键构成的键群,向CPU11输出来自用户的各键的按下输入所对应的操作信息。操作部12至少具有使用扫描部18的条形码扫描触发键。
RAM13是易失性半导体存储器,具有用于存储各种数据和各种程序的工作区域。
显示部14是具备LCD(Liquid Crystal Display:液晶显示器)、EL(Electro Luminescent:场致发光)显示器等显示面板的显示部,根据从CPU11输入的显示信息在显示面板上进行各种显示。
ROM15是用于存储各种数据和各种程序的读出专用的半导体存储器。ROM15中存储扫描程序151。
无线通信部16是便携电话通信方式的无线通信部。无线通信部16具备天线、调制部、解调部、信号处理部等,与基站进行无线通信。无线通信部16通过信号处理部对要发送的信息的信号进行信号处理,通过调制部调制、从天线以无线电波形式发送到基站。该基站经通信网络与通信目标设备连接、此外,无线通信部16还通过解调部对通过天线从基站接收到的无线电波的接收信号进行解调,由信号处理部进行信号处理得到接收信息。这样,无线通信部16经由基站与通信目标设备进行通信。此外,无线通信部16还可以为无线LAN(Local Area Network:局域网)方式的无线通信部,经接入点与通信目标设备进行通信。
闪速存储器17是可读写地存储信息的非易失性半导体存储器。
扫描部18是按照CPU11的控制信号对一维条形码进行扫描来得到条形码的图像数据,并将该图像数据输出到CPU11的激光扫描部。如图2所示,扫描部18具备:发光部181、振动镜(vibration mirror)182、受光部183、增益电路184、二值化电路185。
发光部181发光射出激光L。振动镜182按照CPU11的控制信号通过马达(省略图示)等振动,由此对从发光部181射出的激光L进行反射从而扩展到左右。受光部183是接收由振动镜182反射后的激光L实际照到读取对象物(条形码)后的反射光并将其变换成电信号的模块。
增益电路184对由受光部183受光得到的反射光的电信号进行放大从而使波形最佳化。二值化电路185将由增益电路184最佳化后的电信号变换成作为条形码的图像数据的二值数据并将其输出到CPU11。CPU11对从二值化电路185输入的图像数据进行解码(decode)。
报知部19是根据CPU11的控制输出蜂鸣音的报知部。将报知部19控制成在条形码扫描成功时输出蜂鸣音。
电源部20是锂离子电池等二次电池,向条形码读取装置10的各部分进行电源供给。
接下来,参照图3~图9对条形码读取装置10的动作进行说明。
图3是表示扫描处理的流程图。图4是表示扫描处理的初始化处理的流程图。图5是表示关于条形码B的全部图像数据宽度T、数据不稳定范围T1、数据不稳定和稳定范围T2、条形码开始位置Pos1的示意图。图6是表示扫描处理的条形码开始位置解析处理的流程图。图7是表示关于条形码B的1字符(character)的数据宽度Char、字符开始位置Pos、从左端到字符开始位置Pos为止的数据宽度Sum的示意图。图8是表示扫描处理的数据不稳定范围判定处理的流程图。图9是表示扫描处理的4值化处理的流程图。
由条形码读取装置10执行的扫描处理是扫描读取对象条形码来读取信息的处理。预先由用户调整条形码读取装置10的位置以及姿态,使得读取对象条形码与扫描部18的激光出射方向对准。更具体来讲,使扫描部18的激光的摆动宽度方向与条形码长度方向对准。
这里,以读取Code128条形码为例进行说明,Code128条形码是由6个元素(element)(3个黑条和3个白空)构成在条形码中含有的各字符(character)的规格(standard)。但是,并不局限于此,还可以是读取由Code128以外的6个元素构成在条形码中含有的各字符的规格的条形码的结构、或者是由6以外的个数的元素构成各字符的规格的条形码的结构。
在条形码读取装置10中以用户按下操作部12的条形码扫描触发按钮为触发条件,CPU11通过从ROM15读出并在RAM13中适当展开后的扫描程序151之间的协作来执行扫描处理。CPU11在开始扫描处理的同时开始计时器的计数。
首先,CPU11根据计时器的计数值来判定从扫描处理开始是否经过预先设定的规定时间而超时(步骤S11)。该规定时间是用于结束扫描处理的超时时间。当超时时(步骤S11“是”),结束扫描处理。
当没有超时时(步骤S11“否”),CPU11完成从扫描部18取得条形码的图像数据(步骤S12)。设图像数据具有从条形码图像的左侧向右侧排列的黑条和白空的各数据宽度的数组(array)Dat[0]、Dat[1]、Dat[2]......。例如,条形码的左侧横向的白空的数据宽度为数组Dat[0],条形码的最左的黑条的数据宽度为数组Dat[1]。
然后,CPU11对在步骤S12取得的条形码的图像数据进行初始化处理(步骤S13)。这里,参照图4和图5对步骤S13的初始化处理进行说明。首先,CPU11对图像数据的数据宽度的变量T设定0,对循环计数器i设定0(步骤S131)。然后,CPU11判定循环计数器i是否小于在步骤S12取得的图像数据的黑条和白空的个数DatNum(步骤S132)。
当i<DatNum时(步骤S132;“是”),CPU11将数组Dat[i]与变量T相加算出新的变量T,并将循环计数器i增加1(步骤S133),转移到步骤S132。
当i≥DatNum时(步骤S132;“否”),CPU11将预先设定的常数a与变量T相乘,算出数据不稳定范围(的数据宽度)T1(步骤S134)。然后,CPU11将使用了预先设定的常数b的(1-b)与变量T相乘,算出数据不稳定和稳定范围(的数据宽度)T2(步骤S135),结束初始化处理。
如图5所示,在步骤S134的时刻,变量T为在步骤S12取得的图像数据的全部图像数据宽度T。设条形码B为步骤S12中的图像数据读取对象条形码。此外,激光的摆动宽度的轨迹L1是从扫描部18射出并照射到含有条形码B的纸上的激光的摆动宽度的轨迹。使轨迹L1横切条形码B的全部黑条。此外,在步骤S12中取得与轨迹L1对应长度的图像数据。
数据不稳定范围T1是在轨迹L1的左端部分解码不稳定的范围的数据宽度(data width)。数据不稳定和稳定范围T2是从全部图像数据长T中除去在轨迹L1的右端部分解码不稳定的范围而得的范围的数据宽度。即,数据不稳定和稳定范围T2是轨迹L1上的数据不稳定范围T1和数据稳定的数据稳定范围的长度。此外,轨迹L1的右端部分的数据不稳定范围为T×a的值。
常数a、b分别为表示数据不稳定范围相对于激光摆动宽度的轨迹L1整体的比例的值、为0~1.00之间的值。此外,常数a、b为根据扫描部18(条形码读取装置10)的光学特性和激光摆动的速度特性而决定的值、是预先存储(包含)在扫描程序151中的值。所谓激光摆动的速度特性,是在扫描部18的激光摆动宽度中条形码上的激光摆动的速度不为固定的特性。更具体地讲,例如激光从左向右摆动时,条形码上的激光摆动的速度以加速→稳定→减速的方式变化。因此,在激光摆动宽度的两端,图像数据的黑条和白空的数据宽度的比率误差有可能变大。
返回图3,在步骤S13的执行以后,CPU11执行条形码开始位置解析处理(步骤S14)。这里,参照图图6对步骤S14的条形码开始位置解析处理进行说明。
首先,CPU11将条形码开始位置的变量Pos1设定为1(步骤S141)。然后,CPU11对变量Sum设定数组Dat[0](步骤S142)。变量Sum是图像数据中从左端开始到变量Pos1的黑条或白空的一个左黑条或白空为止的宽度的值的变量。
然后,CPU11判定变量Pos1+1是否小于个数DatNum(步骤S143)。在步骤S143中,变量Pos1+1不超过图像数据条形码的右端则判定为正常,同样地超过图像数据条形码的右端则判定为异常。
当变量Pos1+1<DatNum时(步骤S143;“是”),为正常,CPU11判定数组Dat[Pos1+1]×10是否小于数组Dat[Pos1-1](步骤S144)。在步骤S144中,判断数组Dat[Pos1+1]的10倍的值是否小于与其相同颜色左侧相邻的数组Dat[Pos1-1],该相同颜色左侧相邻的数组Dat[Pos1-1]是否是图像数据条形码的左侧相邻的较大白空部分。
当Dat[Pos1+1]×10≥Dat[Pos1-1]时(步骤S144;“否”),数组Dat[Pos1-1]不是较大白空部分,CPU11将数组Dat[Pos1]与变量Sum相加计算出新的变量Sum(步骤S145)。然后,CPU11使变量Pos1增加1(步骤S146),转移到步骤S143。
当Dat[Pos1+1]×10<Dat[Pos1-1]时(步骤S144;“是”),数组Dat[Pos1-1]是较大白空部分,CPU11对字符开始位置的变量Pos设定作为条形码开始位置 的变量Pos1(步骤S147)。如图7所示,变量Pos为在后述的数据不稳定范围判定处理中使从条形码开始位置Pos1开始向右侧移动的字符开始位置的变量。然后,CPU11设定表示检测出条形码开始位置的旨意(步骤S148),结束条形码开始位置解析处理。
当Pos1+1≥DatNum时(步骤S143;“否”),为异常,CPU11设定表示未检测出条形码开始位置的旨意(步骤S149),结束条形码开始位置解析处理。
返回图3,在步骤S14的执行以后,CPU11根据步骤S14(步骤S148、S149)中的设定结果来判定是否检测出条形码开始位置(步骤S15)。当检测出条形码开始位置时(步骤S15;“是”),CPU11判定变量Pos+6的值是否小于个数DatNum(步骤S16)。在步骤S16中进行加法运算的6是条形码的1字符量的黑条和白空的数量。
当Pos+6<DatNum时(步骤S16;“是”),CPU11执行数据不稳定范围判定处理(步骤S17)。这里,参照图8来说明步骤S17的数据不稳定范围判定处理。
首先,CPU11将数组Dat[Pos]、Dat[Pos+1]、Dat[Pos+2]、Dat[Pos+3]、Dat[Pos+4]、Dat[Pos+5]相加,计算出1字符量的图像数据的数据宽度的变量Char(步骤S171)。然后,CPU11判定变量Sum是否小于数据不稳定范围T1(步骤S172)。如图7所示,变量Sum是图像数据中从左端开始到变量Pos的黑条或白空的左侧相邻的黑条或白空为止的数据宽度的变量。在步骤S172中,判定不包含变量Pos字符的数据宽度的变量Sum是否在轨迹L1左侧的数据不稳定范围T1内。
当Sum≥T1时(步骤S172;“否”),判定为变量Sum在数据不稳定范围T1外。
然后,CPU11将在步骤S171中计算出的变量Char与变量Sum相加计算出新的变量Sum(步骤S173)。然后,CPU11判定变量Sum是否大于数据不稳定和稳定范围T2(步骤S174)。在步骤S174中,判定包含变量Pos字符的数据宽度的变量Sum是否在轨迹L1右侧的数据不稳定范围内。
当T2≥Sum时(步骤S174;“否”),变量Sum在右侧的数据不稳定范围外,CPU11判定为当前的变量Pos的字符位置为数据不稳定范围外(数据稳定 范围内)(步骤S175),结束数据不稳定范围判定处理。
当Sum<T1时(步骤S172;“是”),变量Sum在数据不稳定范围T1内,CPU11将在步骤S171中计算出的变量Char与变量Sum相加计算出新的变量Sum(步骤S176)。进而,CPU11将当前的变量Pos的字符位置判定为数据不稳定范围内(步骤S177),结束数据不稳定范围判定处理。T2<Sum时(步骤S174;“是”),变量Sum在右侧的数据不稳定范围内,转移到步骤S177。
在数据不稳定范围判定处理中,如果变量Pos所对应的字符即使部分包含在数据不稳定范围T1或者右侧的数据不稳定范围中,也判定为该字符在数据不稳定范围内。
返回图3,在步骤S17的执行以后,CPU11根据步骤S17(步骤S175、S176)的判定结果,判定图像数据的1字符量(变量Pos所对应的变量Char的量的图像数据)是否在数据不稳定范围内(步骤S18)。
当图像数据的1字符量不在数据不稳定范围内时(步骤S18;“否”),1字符量在轨迹L1的中央部分的数据稳定范围,CPU11对变量c设定0(步骤S19)。当图像数据的1字符量在数据不稳定范围内时(步骤S18;“是”),CPU11对变量c设定0.25(步骤S20)。变量c是表示对于黑条和白空的比率误差允许到何种程度的参数。变量c越小越允许误差地进行图像数据的解析。即,变量c是与图像数据相对于阈值的误差的允许度相对应的变量,该阈值是用于判定图像数据的解码中黑条和白空的数据宽度的阈值。
然后,CPU11进行4值化判定处理(步骤S21)。这里,参照图9来说明步骤S21的4值化判定处理。在Code128的规格中,黑条和白空的数据宽度被设定4种值(粗细)。4值化判定处理是在1字符量的图像数据中使用阈值和变量c来判定3个黑条中各黑条和3个白空中各白空的数据宽度是4种值中哪一个的处理。
首先,CPU11将变量Char除以11而得的值设定为变量M(步骤S211)。在Code128的规格中,1字符量的图像数据的数据宽度为11模数(11modules)为固定。在步骤S211中通过将1字符量的变量Char除以11(模数),将1模数所对应的图像数据的数据宽度作为变量M计算出来。 
然后,CPU11将变量M的0.5倍的值设定为变量B05,将变量M的1.5 倍的值设定为变量B15,将变量M的2.5倍的值设定为变量B25,将变量M的3.5倍的值设定为变量B35,将变量M的4.5倍的值设定为变量B45(步骤S212)。变量B05、B15、B25、B35、B45依次是与1模数的0.5、1.5、2.5、3.5、4.5倍对应的图像数据的数据宽度的变量。在4值化判定处理中,将变量B05、B15、B25、B35、B45作为用于判定黑条和白空的数据宽度(4值化)的阈值来使用。
然后,CPU11对循环计数器i设定变量Pos(步骤S213)。然后,CPU11判定循环计数器i是否小于变量Pos+6(步骤S214)。当i<Pos+6时(步骤S214;“是”),CPU11判定数组Dat[i]是否小于变量B15(步骤S215)。
当Dat[i]<B15时(步骤S215;“是”),CPU11对循环计数器i所对应的黑条或白空的数据宽度的4值数组R[i]设定1(步骤S216)。然后,CPU11将从数组Dat[i]中减去变量B05而得的值设定为变量W1,将从变量B15中减去数组Dat[i]而得的值设定为变量W2(步骤S217)。变量W1是数组Dat[i]与数组Dat[i]左侧的阈值(变量B05、B15、B25或B35)之间的距离的变量。变量W2是数组Dat[i]右侧的阈值(变量B15、B25、B35或B45)与数组Dat[i]之间的距离的变量。
当Dat[i]≥B15时(步骤S215;“否”),CPU11判定Dat[i]是否小于变量B25(步骤S218)。当Dat[i]<B25时(步骤S218;“是”),CPU11对数组R[i]设定2(步骤S219)。然后,CPU11将从数组Dat[i]中减去变量B15而得的值设定为变量W1,将从变量B25中减去数组Dat[i]而得的值设定为变量W2(步骤S220)。
当Dat[i]≥B25时(步骤S218;“否”),CPU11判定数组Dat[i]是否小于变量B35(步骤S221)。当Dat[i]<B35时(步骤S221;“是”),CPU11对数组R[i]设定3(步骤S222)。然后,CPU11将从数组Dat[i]中减去变量B25而得的值设定为变量W1,将从变量B35中减去数组Dat[i]而得的值设定为变量W2(步骤S223)。
当Dat[i]≥B35时(步骤S221;“否”),CPU11对数组R[i]设定4(步骤S224)。然后,CPU11将从数组Dat[i]中减去变量B35而得的值设定为变量W1,将从变量B45中减去数组Dat[i]而得的值设定为W2(步骤S225)。
步骤S217、S220、S223、S225的执行以后,CPU11判定变量W1是否小于将变量c与变量M相乘而得的值(步骤S226)。当W1≥M×c时(步骤S226;“否”),变量W1(数组Dat[i])在允许误差内,CPU11判定变量W2是否小于将变量c与变量M相乘而得的值(步骤S227)。
当W2≥M×c时(步骤S227;“否”),变量W2(数组Dat[i])在允许误差内,CPU11使循环计数器i增加1(步骤S228),转移到步骤S214。当W1<M×c时(步骤S226;“是”),CPU11设定表示变量Pos所对应的1字符的黑条和白空的4值化失败的旨意(步骤S229),结束4值化处理。当W2<M×c时(步骤S227;“是”),转移到步骤S229。
当变量W1、W2较小时,1值与2值的差、2值与3值的差等,原本应该为不同级别的数据宽度的差异小,比率变得不准确,误读的危险性变高,因此在步骤S229中设定表示4值化失败的旨意。
当i≥Pos+6时(步骤S214;“否”),CPU11设定表示变量Pos所对应的1字符的黑条和白空的4值化成功的旨意(步骤S230),结束4值化处理。
返回图3,CPU11根据在步骤S21(步骤S229、S230)的4值化处理的结果,判别变量Pos所对应的1字符的黑条和白空的4值化是否成功(步骤S22)。当4值化成功时(步骤S22;“是”),CPU11将在步骤S21的4值化判定处理中得到的字符的数组R[i]变换成字符码(步骤S23)。然后,CPU11判定在步骤S23中变换后的字符码是否是表示条形码右端的停止码(步骤S24)。
当不是停止码时(步骤S24;“否”),CPU11使变量Pos增加6(步骤S25),转移到步骤S15。当是停止码时(步骤S24;“是”),CPU11使用在步骤S23中变换后的字符码进行校验数位(check digit)等校验处理,根据其校验结果最终判定解码是否成功(步骤S26)。步骤S18~S26为一系列的解码处理。
当解码失败时(步骤S26;“否”),CPU11等待从扫描部18输入下一图像数据(步骤S27),转移到步骤S11。当没有检测出条形码开始位置时(步骤S15;“否”),在Pos+6≥DatNum时(步骤S16;“否”),或者4值化失败时(步骤S22;“否”),转移到步骤S27。
当解码成功时(步骤S26;“是”),CPU11在显示部14中显示包含在步骤S23中得到的字符码的解码结果,并使报知部19输出蜂鸣音(步骤S28),结 束扫描处理。在步骤S28中,解码结果例如存储在闪速存储器17中。
以上,根据本实施方式,条形码读取装置10将由扫描部18取得的条形码图像数据中、激光摆动宽度的端部分判定为数据不稳定范围,将该数据不稳定范围以外的中央部分判定为数据稳定范围。然后,条形码读取装置10对于所述判定出的数据不稳定范围,将图像数据相对于阈值(变量B05、B15、B25、B35、B45)的误差的允许度设定得较低(使变量c升高),使用该阈值和允许度对该数据不稳定范围进行解码,所述阈值用于判定所述条形码的黑条和白空的粗细。另外,条形码读取装置10对于所述判定出的数据稳定范围,将图像数据相对于所述阈值的误差的允许度设定得(设定为通常级别)较高(使变量c降低),使用该阈值和允许度对该数据稳定范围进行解码。因此,能够提高条形码的数据不稳定范围的读取准确性,并且能够提高条形码的数据稳定范围的读取响应性。
另外,条形码读取装置10还将由扫描部18取得的图像数据中从左端开始预定的第一比例(变量a)的数据宽度、从右端开始预定的第二比例(变量b)的数据宽度判定为数据不稳定范围。因此,能够根据扫描部18的光学特定和激光摆动的速度特定来设定变量a、b,能够判定左端和右端的数据不稳定范围。此外,不仅可以设定为变量a=变量b,还可以设定为变量a≠变量b。
此外,条形码读取装置10对于由扫描部18取得的图像数据,将图像数据相对于条形码的1字符内的阈值的误差的允许度设定为相同值,将数据不稳定范围和数据稳定范围的边界上的字符的误差的允许度设定得较低。因此,即使在数据不稳定范围和数据稳定范围的边界上产生波动,也能够提高边界上的字符的读取准确性。
在以上的说明中,公开了使用ROM作为本发明涉及程序的计算机可读取介质的例子,但并不局限于该例子。
作为计算机可读取的其它介质,还可以应用闪速存储器等非易失性存储器、CD-ROM等可移动存储介质。
另外,作为经由通信线路来提供本发明涉及的程序数据的介质,载波(传输波)也适用于本发明。
此外,上述实施方式中的描述是本发明涉及的条形码读取装置和程序的一 个例子,并不局限于此。
在上述实施方式中,设为条形码读取装置10是手持终端的结构,但并不局限于此。
作为条形码读取装置10,还可以为使用与具有激光方式的扫描部的PDA(Personal Digital Assistant:个人数字助理)、ECR(Electronic Cash Register:电子现金收入记录机)相连接的条形码读取装置等其它条形码读取装置的结构。
此外,在上述实施方式中,将条形码的1字符内的误差的允许度设定为相同,将数据不稳定范围和数据稳定范围的边界上的字符的阈值所对应的误差的允许度设定得较低,但并不局限于此。例如,也可以为将数据不稳定范围和数据稳定范围的边界上的字符的阈值所对应的误差的允许度设定得较高的结构。此外,还可以为按条形码的元素(黑条和白空)来设定误差的允许度的结构。
此外,毋庸赘言,对于上述实施方式中的条形码读取装置10的各构成要素的细节结构和细节动作,在不脱离本发明精神的范围内可以进行适当变更。
对本发明实施方式进行了说明,但本发明的范围并不局限于上述的实施方式,本发明的范围包括在权利要求书中记载的发明范围和其同等的范围。

Claims (4)

1.一种条形码读取装置,其特征在于,具备:
扫描部,其通过射出激光并接收反射光来扫描条形码,从而取得图像数据;
判定部,其将由所述扫描部取得的图像数据中,所述激光的摆动宽度的端部分判定为数据不稳定范围,将不是该数据不稳定范围的部分判定为数据稳定范围;以及
解码部,其对于由所述判定部判定出的数据不稳定范围,将图像数据相对于阈值的误差的允许度设定得较低,并使用该阈值和允许度来对该数据不稳定范围进行解码,对于由所述判定部判定出的数据稳定范围,将图像数据相对于所述阈值的误差的允许度设定得较高,并使用该阈值和允许度来对该数据稳定范围进行解码,其中,所述阈值用于判定所述条形码的黑条和白空的数据宽度。
2.根据权利要求1所述的条形码读取装置,其特征在于,
所述判定部将由所述扫描部取得的图像数据中,从左端开始预定的第一比例的数据宽度、从右端开始预定的第二比例的数据宽度判定为所述数据不稳定范围。
3.根据权利要求1所述的条形码读取装置,其特征在于,
所述解码部对于由所述扫描部取得的图像数据,将所述条形码的1个字符内的所述误差的允许度设定为相同值,将所述数据不稳定范围和所述数据稳定范围的边界上的字符的所述误差的允许度设定得较低。
4.一种条形码读取方法,其特征在于,包括:
扫描步骤,通过射出激光并接收反射光来扫描条形码,从而取得图像数据;
判定步骤,将通过所述扫描步骤取得的图像数据中,所述激光的摆动宽度的端部分判定为数据不稳定范围,将不是该数据不稳定范围的部分判定为数据稳定范围;以及
解码步骤,对于通过所述判定步骤判定出的数据不稳定范围,将图像数据相对于阈值的误差的允许度设定得较低,并使用该阈值和允许度来对该数据不稳定范围进行解码,对于通过所述判定步骤判定出的数据稳定范围,将图像数据相对于所述阈值的误差的允许度设定得较高,并使用该阈值和允许度来对该数据稳定范围进行解码,其中,所述阈值用于判定所述条形码的黑条和白空的数据宽度。
CN201210024501.4A 2011-02-04 2012-02-03 条形码读取装置 Active CN102682262B (zh)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
JP2011-022690 2011-02-04
JP2011022690A JP5321610B2 (ja) 2011-02-04 2011-02-04 スキャナ装置及びプログラム

Publications (2)

Publication Number Publication Date
CN102682262A CN102682262A (zh) 2012-09-19
CN102682262B true CN102682262B (zh) 2015-04-22

Family

ID=46599990

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201210024501.4A Active CN102682262B (zh) 2011-02-04 2012-02-03 条形码读取装置

Country Status (3)

Country Link
US (1) US8746567B2 (zh)
JP (1) JP5321610B2 (zh)
CN (1) CN102682262B (zh)

Families Citing this family (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN103324972A (zh) * 2013-06-06 2013-09-25 北京印刷学院 一种三维码的标识及其实现方法

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6796503B1 (en) * 2003-12-04 2004-09-28 Ncr Corporation Methods and apparatus for dynamic adjustment of bar code reader parameters
CN1742279A (zh) * 2002-12-17 2006-03-01 夏普株式会社 条形码识别装置
EP1703446A1 (en) * 2005-03-18 2006-09-20 Casio Computer Co., Ltd. Apparatus and method for generating bar code, and apparatus and method for reading out bar code

Family Cites Families (22)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4782220A (en) * 1986-09-29 1988-11-01 Mars, Incorporated Method and apparatus for bar code data autodiscrimination
US5412198A (en) * 1989-10-30 1995-05-02 Symbol Technologies, Inc. High-speed scanning arrangement with high-frequency, low-stress scan element
US5589679A (en) * 1989-10-30 1996-12-31 Symbol Technologies, Inc. Parallelepiped-shaped optical scanning module
US5479000A (en) * 1989-10-30 1995-12-26 Symbol Technologies, Inc. Compact scanning module for reading bar codes
US5115121A (en) * 1990-01-05 1992-05-19 Control Module Inc. Variable-sweep bar code reader
JP2771309B2 (ja) * 1990-04-17 1998-07-02 アルプス電気株式会社 光学読取装置
JP2781120B2 (ja) 1993-04-06 1998-07-30 沖電気工業株式会社 バーコード読取回路
JP3265804B2 (ja) * 1994-03-18 2002-03-18 富士通株式会社 バーコード読取り装置
JP3814008B2 (ja) * 1996-02-20 2006-08-23 株式会社オプトエレクトロニクス 光学的パターン読取装置
JPH1153459A (ja) * 1997-08-06 1999-02-26 Sumitomo Electric Ind Ltd 二値化処理装置
US6419155B1 (en) * 1998-10-29 2002-07-16 Casio Computer Co., Ltd. Laser beam scan type barcode reader and program recording mediums
JP4163406B2 (ja) * 2001-09-28 2008-10-08 シャープ株式会社 バーコード認識装置
JP4364482B2 (ja) * 2002-04-23 2009-11-18 株式会社キーエンス 光学シンボル読取装置用光学ユニット
US7212682B2 (en) * 2003-03-06 2007-05-01 Sick Auto Ident, Inc. Method and system for enhancing measurement
JP2005250852A (ja) * 2004-03-04 2005-09-15 Matsushita Electric Ind Co Ltd バーコードリーダ
US7628331B2 (en) * 2005-09-29 2009-12-08 Symbol Technologies, Inc. Method and system for optimizing scanner performance
JP2008140255A (ja) * 2006-12-04 2008-06-19 Olympus Corp バーコード読取装置およびバーコード読取方法
JP5233276B2 (ja) * 2007-12-21 2013-07-10 カシオ計算機株式会社 バーコード読取装置及びプログラム
JP5140820B2 (ja) * 2008-03-31 2013-02-13 日本電産サンキョー株式会社 シンボル情報読取装置及びシンボル情報読取方法
JP5125961B2 (ja) * 2008-09-30 2013-01-23 富士通株式会社 二値化処理装置、情報処理装置、二値化処理方法および二値化処理プログラム
CN102034074B (zh) * 2009-09-25 2014-05-14 神基科技股份有限公司 在图像中定位并撷取条形码区域的图像处理方法及装置
TWI369637B (en) * 2010-06-17 2012-08-01 Mstar Semiconductor Inc Barcode image recognition system and associated method for hand-held device

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN1742279A (zh) * 2002-12-17 2006-03-01 夏普株式会社 条形码识别装置
US6796503B1 (en) * 2003-12-04 2004-09-28 Ncr Corporation Methods and apparatus for dynamic adjustment of bar code reader parameters
EP1703446A1 (en) * 2005-03-18 2006-09-20 Casio Computer Co., Ltd. Apparatus and method for generating bar code, and apparatus and method for reading out bar code

Also Published As

Publication number Publication date
JP5321610B2 (ja) 2013-10-23
US8746567B2 (en) 2014-06-10
CN102682262A (zh) 2012-09-19
JP2012164058A (ja) 2012-08-30
US20120199656A1 (en) 2012-08-09

Similar Documents

Publication Publication Date Title
CN204374974U (zh) 高动态范围的标记读取系统
CN107092849B (zh) 用于使用多个数据源来读取光学标记的方法和设备
EP0436072B1 (en) Method of decoding bar code symbols from partial scans
US10509933B2 (en) Method and apparatus for optically reading out information stored in a barcode
US10740820B1 (en) Systems and methods for price searching via a mobile device reading display screen graphics
CN101957923A (zh) 在射频识别系统中对标签数据进行读取的方法和读写器
CN101874250B (zh) 增强型虚拟扫描线处理
EP0943132B1 (en) Method and apparatus for decoding bar code symbols using ratio analysis of module size
US8172142B2 (en) System, method and apparatus for placing and updating information in a personal digital electronic device for communication to a bar code scanner
US5710419A (en) Record with removable two-dimensional code
CN102750506B (zh) 扫描仪装置以及扫描仪装置的使用方法
CN103377442A (zh) 一种数据处理方法和系统
US6102295A (en) Method and apparatus for decoding symbols by declaring erasures of element characteristics
US7778886B1 (en) Systems and methods for price searching via a mobile device reading display screen graphics
CN102682262B (zh) 条形码读取装置
CN112464679A (zh) 一种扫码方法和扫码设备
EP0575989A2 (en) Record with removable two-dimensional code
US20230359870A1 (en) Digital Information-Theoretic Code From Analog Scanning Technology Using Deep Networks
US6070801A (en) Bar code reader, bar code reading method and computer readable medium
US20040164155A1 (en) Bar-code reader and method of reading bar code
JP5768260B2 (ja) イメージ処理装置及びシンボル読取方法
US8313029B2 (en) Apparatus and methods for decoding images
JP5532163B2 (ja) イメージ処理装置及びプログラム
JP5115124B2 (ja) バーコード読取装置及びプログラム
CN109962979B (zh) 二维码扫描的方法、装置、存储介质及计算机设备

Legal Events

Date Code Title Description
C06 Publication
PB01 Publication
C10 Entry into substantive examination
SE01 Entry into force of request for substantive examination
C14 Grant of patent or utility model
GR01 Patent grant