KR900004949B1 - Output controller of interpolation dot pattern - Google Patents

Output controller of interpolation dot pattern Download PDF

Info

Publication number
KR900004949B1
KR900004949B1 KR1019850000083A KR850000083A KR900004949B1 KR 900004949 B1 KR900004949 B1 KR 900004949B1 KR 1019850000083 A KR1019850000083 A KR 1019850000083A KR 850000083 A KR850000083 A KR 850000083A KR 900004949 B1 KR900004949 B1 KR 900004949B1
Authority
KR
South Korea
Prior art keywords
dot
interpolation
register
character
pattern
Prior art date
Application number
KR1019850000083A
Other languages
Korean (ko)
Other versions
KR850007711A (en
Inventor
히로유끼 아오끼
Original Assignee
가부시기가이샤 도시바
사바 쇼오이찌
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 가부시기가이샤 도시바, 사바 쇼오이찌 filed Critical 가부시기가이샤 도시바
Publication of KR850007711A publication Critical patent/KR850007711A/en
Application granted granted Critical
Publication of KR900004949B1 publication Critical patent/KR900004949B1/en

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06KGRAPHICAL DATA READING; PRESENTATION OF DATA; RECORD CARRIERS; HANDLING RECORD CARRIERS
    • G06K17/00Methods or arrangements for effecting co-operative working between equipments covered by two or more of main groups G06K1/00 - G06K15/00, e.g. automatic card files incorporating conveying and reading operations
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T3/00Geometric image transformations in the plane of the image
    • G06T3/40Scaling of whole images or parts thereof, e.g. expanding or contracting
    • G06T3/4007Scaling of whole images or parts thereof, e.g. expanding or contracting based on interpolation, e.g. bilinear interpolation
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F17/00Digital computing or data processing equipment or methods, specially adapted for specific functions
    • G06F17/10Complex mathematical operations
    • G06F17/17Function evaluation by approximation methods, e.g. inter- or extrapolation, smoothing, least mean square method
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06KGRAPHICAL DATA READING; PRESENTATION OF DATA; RECORD CARRIERS; HANDLING RECORD CARRIERS
    • G06K15/00Arrangements for producing a permanent visual presentation of the output data, e.g. computer output printers
    • G06K15/02Arrangements for producing a permanent visual presentation of the output data, e.g. computer output printers using printers
    • G06K15/10Arrangements for producing a permanent visual presentation of the output data, e.g. computer output printers using printers by matrix printers

Landscapes

  • Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Theoretical Computer Science (AREA)
  • Mathematical Physics (AREA)
  • Data Mining & Analysis (AREA)
  • Pure & Applied Mathematics (AREA)
  • Mathematical Optimization (AREA)
  • Mathematical Analysis (AREA)
  • General Engineering & Computer Science (AREA)
  • Computational Mathematics (AREA)
  • Algebra (AREA)
  • Databases & Information Systems (AREA)
  • Software Systems (AREA)
  • Controls And Circuits For Display Device (AREA)
  • Dot-Matrix Printers And Others (AREA)
  • Image Processing (AREA)

Abstract

A dot interpolation control system for dot-interpolating a character pattern in a predetermined dot matrix form expressed by x and y coordinates at an y designated angle along at least the main scanning or subscanning direction so as to obtain a modified character pattern which is rotated or inclined, comprises a means for calculating an area of a rectangle along the x and y lines which circumscribe a frame of the character pattern converted at the designated angle, and a means for controlling the character interval in units of the rectangular areas.

Description

보간 도트패턴의 출력제어장치Output control device of interpolation dot pattern

제1a도 내지 제1c도는 각각 종래의 도트보간 처리수단을 설명하기 위한 도면.1A to 1C are diagrams for explaining conventional dot interpolation processing means, respectively.

제2도는 본 발명의 일 실시예에 있어서의 요부의 구성을 도시한 블록도.2 is a block diagram showing the configuration of main parts in an embodiment of the present invention.

제3도 내지 제11도는 각각 상기 실시예의 동작을 설명하는 것으로,3 to 11 illustrate the operation of the embodiment, respectively.

제3a도 내지 (f)는 각각 도트보간 처리에 의하여 생성되는 새로운 도트를 둘러싸는 1격자 4점의 도트정보(도트패턴)와, 보간테이블 ROM에 설정된 보간치의 레벨구분과, 테이블 형태와의 관계를 도시한 도면.3A to 3F show the relationship between the dot information (dot pattern) of one grid and four points surrounding each new dot generated by the dot interpolation process, the level classification of the interpolation value set in the interpolation table ROM, and the table form. Figure.

제4도는 테이블 형태의 선택절환 동작을 설명하기 위한 도면.4 is a diagram for explaining a selection switching operation in the form of a table.

제5a도 내지 (b)는 각각 패턴 변환예를 도시한 도면.5A to 5B show examples of pattern conversion, respectively.

제6a도 및 (b)는 CRT 표시부로 표시할 때에 주·부 주사방향과 프린트 아웃시의 주·부 주사방향을 대비해서 도시한 도면.6A and 6B are diagrams showing the main and sub scanning directions in contrast to the main and sub scanning directions when printed out and displayed in the CRT display.

제7도의 각종 설정데이터의 관계를 도시한 도면.Fig. 7 shows the relationship between the various setting data in Fig. 7;

제8도는 도트보간처리에 의하여 패턴변환된 문자와 그 문자에 외접하는 직사각형의 관계를 도시한 도면.8 is a diagram showing a relationship between a character pattern-converted by dot interpolation processing and a rectangle circumscribed to the character.

제9도는 각종 변형문자에 대한 문자피치 및 행피치의 설정예를 도시한 도면.9 is a diagram showing an example of setting the character pitch and the row pitch for various modified characters.

제10도는 각종 변형문자에 대한 하선의 전개예를 도시한 도면.FIG. 10 is a diagram showing an example of development of an underline for various deformed characters. FIG.

제11도는 구역구분수단을 설명하는 도면.11 is a view for explaining zone dividing means.

* 도면의 주요부분에 대한 부호의 설명* Explanation of symbols for main parts of the drawings

10 : CPU 11 : 주메모리(MM)10: CPU 11: Main Memory (MM)

12 : CPU 버스 13 : 표시제어회로(CRT-C°)12: CPU bus 13: display control circuit (CRT-C °)

14 : 프레임 메모리(FM) 15 : 병렬-직렬 변환회로(PS)14 frame memory (FM) 15 parallel-to-serial conversion circuit (PS)

16 : CRT 표시부 17 : 인자 제어부16: CRT display unit 17: print control unit

18 : 라인 버퍼 19 : 직렬 도트프린터18: line buffer 19: serial dot printer

21,22,25,26,27,28,31,32,33,34,35,36,42,44,46,48,50,54,56 : 레지스터21,22,25,26,27,28,31,32,33,34,35,36,42,44,46,48,50,54,56: register

23 : 하선/방선 제어부 24 : 3각 함수테이블23: underline / radiation control unit 24: triangular function table

29 : 오프셋 데이터 생성부29: offset data generation unit

37,38,39,40 : 가산회로(ADD-A, ADD-B, ADD-C, ADD-D)37,38,39,40: Addition circuit (ADD-A, ADD-B, ADD-C, ADD-D)

41,43,45,47 : 데이터 선택기 49 : 선택제어회로(SC)41, 43, 45, 47: Data selector 49: Selection control circuit (SC)

51 : 한자패턴 메모리(KPM) 52 : 1문자 버퍼51 Kanji pattern memory (KPM) 52: 1 character buffer

53 : 비트선택회로 55 : 판별제어회로53: bit select circuit 55: discrimination control circuit

57 : 도트판별회로 58 : 보간테이블57: dot discrimination circuit 58: interpolation table

59 : 비교기 60 : 시프트 레지스터59: comparator 60: shift register

본 발명은 도트매트릭스구조의 문자자체(font) 정보를 취급하는 문서작성장치 및 문자출력장치 등에 사용되는 보간도트 패턴의 출력제어장치에 관한것이다.BACKGROUND OF THE INVENTION 1. Field of the Invention The present invention relates to an output control apparatus for an interpolation dot pattern used for a document producing apparatus and a character output apparatus for handling font information of a dot matrix structure.

문서작성장치등, 규정된 도트매트릭스 구성의 문자자체를 취급하는 장치에 있어서 규정된 도트매트릭스 구성의 문자자체를 어떤 배율로 확대·축소할 수 있는 기능을 부여할 때, 종래에 있어서는 제1a도 내지 (b)에서 도시한 바와 같이 원문자 패턴도트 SD……로부터 단순히 도트를 증가 또는 삭제 하는 이른바 단순확대 축소방식이 채용되고 있었다.In the apparatus which handles the character itself having a prescribed dot matrix structure, such as a document producing apparatus, in the conventional art, when giving a function capable of enlarging / reducing the character itself having a prescribed dot matrix structure at a certain magnification, FIGS. As shown in (b), the original character pattern dot SD... … The so-called simple zoom reduction method was used to simply increase or delete dots.

이와 같은 종래의 확대·축소수단은 비교적 간단하고 또 값싸게 실현할 수 있었으나 예를 들면 경사선 부분에 있어서의 계단상의 형성부가 두드러지게 나타나는 등 출력되는 패턴형상이 본래의 표현하고자 하는 문자형태에서 벗어나 식별하기 어려운 부자연스러운 문자표현이 되고마는 결함이 있었다. 또 상기와 같은 종래의 도트보간 수단에 있어서의 원문자패턴 또는 임의의 확대·축소배율을 가지는 문자패턴을 임의의 각도를 가지고 경사형화, 또는 회전시킨 변형문자체를 얻고자 할 때 이것을 쉽게 얻을 수가 없고, 또 그 변형범위를 대폭적으로 제약하드라도 변환된 문자패턴이 찌그러져서 변환 정밀도가 대폭적으로 저하하여 충실성이 높은 패턴 변환을 할 수 없었다.Such a conventional enlargement / reduction means can be realized relatively simply and inexpensively, but the pattern of the output pattern is distinguished from the original form of the character to be expressed, for example, the formation of the steps on the inclined line is prominent. There was a flaw in the unnatural character expression that was difficult to do. When the original character pattern in the conventional dot interpolation means as described above or a character pattern having an arbitrary magnification / reduction ratio is inclined or rotated at an arbitrary angle, it cannot be easily obtained. In addition, even if the deformation range is greatly limited, the converted character pattern is distorted, and the conversion accuracy is greatly reduced, and a pattern conversion with high fidelity cannot be performed.

또, 상기와 같은 회전문자, 경사형문자 등의 변형문자에 대해서는 그 도트보간된 문자의 문자폭 또는 문자높이, 또는 그 어느 한쪽이 언제나 바이트(byte)단위로 한 도트구성이 된다고는 한정할 수 없고 이로 인해 바이트 단위로 기입을 하는 이미지 메모리와의 사이에 있어서 도트보간으로 새로 생성된 문자패턴의 주사개시위치가 상기 메모리측의 바이트 경계와 일치되지 않고 문자단위의 이미지 데이터의 취급에 결함이 생긴다. 또 종래에서는 도트보간후의 문자의 이미지가 그 주사에 따른 위치상에 고정적으로 전개되므로 예를 들면 인자출력되는 루비문자(원래의 글자보다 작은 글자)반각문자 등을 수도트분 상하방향으로 이동시키고자 원할때 그것을 할 수 없는 결함이 있었다.In addition, for the above-described modified characters such as the rotation character and the oblique type character, the character width or the height of the interpolated character, or any one of them can always be defined as a dot structure in byte units. In this case, the scanning start position of the newly generated character pattern by dot interpolation does not coincide with the byte boundary on the memory side, and there is a defect in the handling of image data in character units. . In addition, since the image of the character after dot interpolation is fixedly developed on the position according to the scanning in the related art, for example, a ruby character (character smaller than the original character) that is printed out is to be moved in the vertical direction of the doot. There was a flaw that could not do it when desired.

본 발명은 상기의 설정을 고려하여 연구된 것으로 원문자자체를 고정밀도의 도트보간을 가지고 임의의 확대 및 축소 배율, 각도 등에 따라 변형했을 때 도트보간에 의하여 생기는 문자패턴 도트의 기입개시위치와 상기 이미지 메모리의 메모리 경계와의 대응을 항시 취할 수 있도록하여 변형문자 단위의 이미지 데이터의 취급을 용이하게 하고, 또 임의의 문자를 이미지 메모리의 기입폭의 범위내에서 이동할 수 있도록 한 보간도트패턴의 출력제어장치를 제공하는 것을 목적으로 한다.The present invention has been studied in consideration of the above-described setting, and the writing start position of the character pattern dots generated by dot interpolation when the original character itself has high precision dot interpolation and is transformed according to arbitrary enlargement and reduction magnification, angle, etc. Output of an interpolation dot pattern that facilitates handling of image data in units of deformed characters by allowing correspondence with memory boundaries of the image memory at all times, and that arbitrary characters can be moved within the write width of the image memory. It is an object to provide a control device.

본 발명은 x성분과 y성분으로 표시되는 주.주사 방향의 도트보간어드레스 및 동일하게 x성분과 y성분으로 표시되는 부.주사 방향의 도트보간 어드레스를 기초로 생성된 보간도트 정보를 그 도트보간 처리된 문자패턴으로 전개되는 이미지 메모리의 기입폭에 대응하는 비트길이를 가지고 시프트레지스터에 저장하고 이 시프트레지스터에 대하여 주.주사마다의 보간도트의 기입에 앞서서 상기 이미지 메모리의 기입폭에 상당하는 비트범위내의 오프셋 값을 선택적으로 생성하고 상기 시프트레지스터에 기입하는 오프셋데이터 생성수단을 가지고 도트보간에 의하여 발생하는 문자패턴 도트의 기입개시 위치와 상기 이미지 메모리의 기입 경계와의 대응을 취할 수 있도록 한 것으로, 이것에 의하여 원문자 자체를 고정밀도의 도트보간을 가지고 임의의 확대 및 축소 배율, 각도 등에 따라 변형 했을 때 도트보간에 의하여 생기는 문자패턴도트의 기입개시 위치와 상기 이미지 메모리의 메모리 경계와의 대응을 항시 취할 수 있고 변형문자마다의 이미지 데이터의 취급이 용이해지고, 또 임의의 문자를 이미지 메모리의 기입폭의 범위내에서 이동이 가능함으로 도트보간된 문자패턴의 출력기능을 확충할 수 있다.The present invention provides interpolation dot information generated based on dot interpolation addresses in the main and scanning directions represented by the x and y components, and dot interpolation addresses in the sub and scan directions represented by the x and y components. The bit length corresponding to the write width of the image memory developed into the processed character pattern is stored in the shift register, and the bit corresponding to the write width of the image memory prior to the writing of interpolation dots for each note and scan for the shift register. A offset data generation means for selectively generating an offset value within a range and writing to the shift register so that a correspondence can be made between a write start position of a character pattern dot generated by dot interpolation and a write boundary of the image memory; By doing this, the original character itself has a high accuracy dot interpolation. Correspondence between the writing start position of the character pattern dot caused by dot interpolation and the memory boundary of the image memory when transformed according to the large, reduced magnification, angle, etc. can be easily handled and the image data for each modified character can be easily handled. In addition, since arbitrary characters can be moved within the range of the write width of the image memory, the output function of the dot interpolated character pattern can be expanded.

이하, 도면을 참조하여 본 발명의 일실시예를 설명한다.Hereinafter, an embodiment of the present invention will be described with reference to the drawings.

제2도는 본 발명의 일실시예를 도시한 회로 블록도이다. 도면중, 참조번호(10)는 시스템 전체의 제어를 관장하는 CPU, 참조번호(11)는 메인메모리(MM), 참조번호(12)는 CPU 버스이다. 참조번호(13)는 표시제어회로(CRT-C), 참조번호(14)는 프레임메모리(FM), 참조번호(15)는 직·병렬변환회로, 참조번호(16)는 CRT 표시부, 참조번호(17)는 인자제어부, 참조번호(18)는 라인버퍼, 참조번호(19)는 직렬도트프린터이다. 참조번호(21)는 패턴변환시에 있어서의 변환후의 부.주사방향의 폭(주.주사의 간격×회수)에 상당하는 크기(V size)를 표시하는 레지스터, 참조번호(22)는 동일 주.주사방향의 폭에 상당하는 크기(H size)를 표시하는 레지스터이다. 참조번호(23)는 상기 레지스터(21)의 내용에 따르는 길이를 가지고 하선, 방선의 도트패턴을 발생하여 라인버퍼(18)에 기입하는 하선/방선제어부이다. 참조번호(24)는 문자의 경사형 회전시등에 있어서의 지정각도에 따른 각도정보(3각 함수데이터)를 저장하는 3각 함수테이블이다. 참조번호(25)는 패턴변환시에 있어서 기준문자높이를 초과한 변환처리후의 문자패턴을 상기 기준문자높이를 단위로 구역을 구분하기 위한 구역지정용 레지스터이다. 참조번호(26) 및 (27)는 문자의 확대·축소배율에 따르는 도트새김폭(dx,dy)을 저장하는 레지스터, 참조번호(28)는 패턴 변환된 문자에 대해 0 내지 7도트 범위에서 선택적으로 오프셋(offset)을 주기 위한 오프셋 레지스터, 참조번호(29)는 오프셋 레지스터(28)의 오프셋치에 따르는 도트수를 가지고 오프셋 데이터(비표시를 나타내는 "0")를 생성하는 오프셋 데이터 생성부이다.2 is a circuit block diagram showing an embodiment of the present invention. In the figure, reference numeral 10 denotes a CPU which controls the entire system, reference numeral 11 denotes a main memory MM, and reference numeral 12 denotes a CPU bus. Reference numeral 13 denotes a display control circuit (CRT-C), reference numeral 14 denotes a frame memory FM, reference numeral 15 denotes a serial / parallel conversion circuit, reference numeral 16 denotes a CRT display, and reference numeral Reference numeral 17 denotes a printing control unit, reference numeral 18 denotes a line buffer, and reference numeral 19 denotes a serial dot printer. Reference numeral 21 denotes a register indicating the size (V size) corresponding to the width in the sub-scanning direction (interval / scan interval x number of times) after conversion in pattern conversion, and reference numeral 22 denotes the same note. This register indicates the size (H size) corresponding to the width of the scanning direction. Reference numeral 23 denotes an underline / radiation control unit which has a length in accordance with the contents of the register 21 and generates an underline and a ray dot pattern and writes it to the line buffer 18. Reference numeral 24 denotes a trigonometric function table for storing angular information (triangle function data) corresponding to the designated angle in the case of the oblique rotation of characters. Reference numeral 25 is an area designation register for dividing the area of the character pattern after the conversion process exceeding the reference character height in units of the reference character height during pattern conversion. Reference numerals 26 and 27 denote registers for storing dot notation widths (dx, dy) according to the magnification and reduction ratio of characters, and reference numeral 28 is optional in the range of 0 to 7 dots for pattern converted characters. Offset register for giving an offset, reference numeral 29 is an offset data generator for generating offset data ("0" representing non-display) with the number of dots in accordance with the offset value of the offset register 28. .

참조번호(31) 내지 (49)는 각각 도트보간어드레스를 생성하기 위한 구성요소를 이루는 것으로, 참조번호(31)는 x성분을 포함하는 부.주사방향의 도트새김폭(DX1)을 저장하는 레지스터, 참조번호(32)는 x성분을 포함하는 주.주사방향의 도트새김폭(DX2)을 저장하는 레지스터, 참조번호(33)는 x성분을 포함하는 주.주사방향의 초기치(초기어드레스:X1 init)를 저장하는 레지스터, 참조번호(34)는 y성분을 포함하는 부.주사방향의 도트새김폭(DY1)을 저장하는 레지스터, 참조번호(36)는 y성분을 포함하는 주.주사방향의 도트새김폭(DY2)을 저장하는 레지스터, 참조번호(36)는 y성분을 포함하는 부.주사방향의 초기치(초기 어드레스:Y1 init)를 저장하는 레지스터이다. 상기의 각 레지스터(31)-(36)에 저장되는 도트보간어드레스는 각각 정수부의 데이터와 소수부의 데이터로 구성된다.Reference numerals 31 to 49 each constitute a component for generating a dot interpolation address, and reference numeral 31 denotes a register for storing dot writing width DX1 in the sub-scanning direction including an x component. , Reference numeral 32 denotes a register for storing dot engraving width DX2 in the scanning and scanning direction including x components, and reference numeral 33 denotes an initial value of the scanning and scanning direction including x components (initial address: X1). init), the reference numeral 34 denotes a register for storing the dot-indentation width DY1 in the sub-scanning direction containing the y component, and the reference numeral 36 denotes a register for the main / scanning direction containing the y component. A register for storing dot indentation width DY2, and reference numeral 36 are registers for storing an initial value (initial address: Y1 init) in the sub-scanning direction including the y component. The dot interpolation addresses stored in the above registers 31 to 36 are each composed of data of the integer part and data of the fractional part.

참조번호(37)는 상기의 레지스터(31)의 내용과 x성분을 포함하는 부.주사방향의 도트위치를 표시하는 레지스터(42)의 내용을 가산하는 가산회로(ADD-A), 참조번호(38)는 상기 레지스터(32)의 내용과 x성분을 포함하는 주.주사방향의 도트위치를 표시하는 레지스터(44)의 내용을 가산하는 가산회로(ADD-B), 참조번호(39)는 상기 레지스터(34)의 내용과 y성분을 포함하는 부.주사방향의 도트위치를 표시하는 레지스터(46)의 내용을 가산하는 가산회로(ADD-C), 참조번호(40)는 상기 레지스터(35)의 내용과 y성분을 포함하는 주.주사방향의 도트위치를 표시하는 레지스터(48)의 내용을 가산하는 가산회로(ADD-D)이다.Reference numeral 37 denotes an addition circuit ADD-A for adding the contents of the register 31 and the contents of the register 42 indicating the dot position in the sub-scanning direction including the x component, and the reference number ( 38 is an addition circuit ADD-B which adds the contents of the register 32 and the contents of the register 44 indicating the dot position in the scanning and scanning direction including the x component, and reference numeral 39 denotes the above. An addition circuit (ADD-C) for adding the contents of the register 46 indicating the dot position in the sub-scanning direction including the contents of the register 34 and the y component, and reference numeral 40 denotes the register 35. An addition circuit (ADD-D) that adds the contents of the register 48 indicating the dot position in the main and scanning directions including the contents of and the y component.

참조번호(41)는 1문자분의 도트보간처리를 개시할 때에 상기 레지스터(33)의 내용을 선택하고, 이후 1회의 주.주사가 실행될 때마다 가산회로(37)의 출력을 선택하는 데이터 셀렉터, 참조번호(42)는 데이터 셀렉터(41)에서 선택된 x성분을 포함하는 정수부와 소수부로 표시되는 도트보간시의 새로운 도트어드레스를 저장하는 레지스터, 참조번호(43)는 주.주사를 개시할 때에 상기 레지스터(42)의 내용을 선택하고, 이후 1도트분의 보간처리마다 가산히로(38)의 출력을 선택하는 데이터 셀렉터, 참조번호(44)는 데이터 셀렉터(43)에서 선택된 x성분을 포함하는 도트보간시의 새로운 도트어드레스를 저장하는 레지스터이다. 참조번호(45)는 1문자분의 도트보간처리를 개시할 때에 상기 레지스터(36)의 내용을 선택하고, 이후 1회의 주.주사가 실행될때마다 가산회로(39)의 출력을 선택하는 데이터 셀렉터, 참조번호(46)는 데이터 셀렉터(45)에서 선택된 y성분을 포함하는 정수부와 소수부로 표시되는 도트보간시의 새로운 도트어드레스를 저장하는 레지스터, 참조번호(47)는 주.주사를 개시할때에 상기 레지스터(46)의 내용을 선택하고, 이후 1도트분의 보간처리를 할 때마다 가산회로(40)의 출력을 선택하는 데이터 셀렉터, 참조번호(48)는 데이터 셀렉터(47)에서 선택된 y성분을 포함하는 도트보간시의 새로운 도트어드레스를 저장하는 레지스터이다. 참조번호(49)는 상기 각 데이터 셀렉터(41),(43),(45),(47)를 제어하는 선택제어회로(SC)이다.Reference numeral 41 selects the contents of the register 33 when starting the dot interpolation process for one character, and then selects the output of the addition circuit 37 each time one main / scan is executed. Denotes an integer part containing the x component selected by the data selector 41 and a register for storing a new dot address at the time of dot interpolation represented by the decimal part. A data selector which selects the contents of the register 42, and then selects the output of the addition Hi 38 for every one-dot interpolation process; reference numeral 44 contains the x component selected by the data selector 43; This register stores the new dot address for dot interpolation. Reference numeral 45 selects the contents of the register 36 at the start of the dot interpolation process for one character, and then selects the output of the addition circuit 39 each time a main scan or scan is executed. And reference numeral 46 denotes a register for storing a new dot address at the time of dot interpolation represented by an integer part and a fractional part including the y component selected by the data selector 45, and reference numeral 47 denotes when starting an order scan. Selects the contents of the register 46 and selects the output of the addition circuit 40 each time the interpolation process is performed for one dot, and reference numeral 48 denotes the y selected by the data selector 47. This register is used to store a new dot address for dot interpolation that contains a component. Reference numeral 49 denotes a selection control circuit SC for controlling the respective data selectors 41, 43, 45, 47.

참조번호(50)는 후술하는 보간치와의 비교를 실행하기 위한 비교치, 즉 임계치(th)를 저장하는 레지스터이다.Reference numeral 50 is a register for storing a comparison value for performing comparison with an interpolation value described later, that is, a threshold value th.

참조번호(51)는 한자를 포함하는 소정의 도트매트릭스단위(16×16도트)의 문자패턴데이터가 격납된 한자패턴메모리(KPM)이다. 참조번호(52)는 한자 패턴메모리(51)에서 판독된 1문자분의 도트패턴을 저장하는 고속 RAM에 의하여 구성된 1문자 버퍼이다. 여기에서는 1문자분의 도트패턴을 그 주위를 오프도트"0"의 비트패턴으로 채운 상태로 기억한다. 참조번호(53)는 1문자버퍼(52)에 저장된 문자패턴데이터중 레지스터(44),(48)의 각 정수부의 치에 따라 새로운 도트를 둘러싸는 1격자 4점의 도트정보를 선택적으로 출력하는 비트선택회로이다. 참조번호(54)는 비트선택회로(53)에서 출력되는 4비트의 정보를 저장하는 레지스터이다.Reference numeral 51 denotes a Chinese character pattern memory KPM in which character pattern data of a predetermined dot matrix unit (16 x 16 dots) containing Chinese characters is stored. Reference numeral 52 is a one-character buffer constructed by a high speed RAM that stores a dot pattern for one character read from the Chinese character pattern memory 51. Here, the dot pattern for one character is stored in the state filled with the bit pattern of the dot " 0 ". Reference numeral 53 selectively outputs dot information of four grids of one grid surrounding new dots according to the values of the respective integer portions of the registers 44 and 48 of the character pattern data stored in the one-character buffer 52. Bit selection circuit. Reference numeral 54 is a register that stores four bits of information output from the bit select circuit 53.

참조번호(55) 내지 (57)는 비트선택회로(53)에서 출력되는 도트정보의 패턴을 인식하고, 4점의 도트로 둘러싸이는 새 도트의 보간치를 선택적으로 절환제어하는 도트패턴인식부(DSP)의 구성요소를 이루는 것으로, 참조번호(55)는 레지스터(54)의 비트 내용에서 4점의 도트패턴 상태를 인식하고, 후술하는 특정의 도트패턴 상태시에 다시 그 주위의 특정한 2격자분의 도트정보를 차례로 선택하기 위하여 비트선택회로(53)를 제어하는 판별제어회로이다. 참조번호(56)는 이 판별제어회로(55)의 제어로 판독된 4비트의 정보를 저장하는 레지스터이다. 참조번호(57)는 판별제어회로(55)의 제어로 판독된 2격자분의 도트정보와 레지스터(54)의 도트정보와의 도트패턴 상태에 따른 1비트의 보간치절환 선택신호를 출력하는 도트판별회로이다.Reference numerals 55 to 57 recognize a pattern of dot information output from the bit select circuit 53, and a dot pattern recognition unit (DSP) for selectively switching and controlling the interpolation value of a new dot surrounded by four dots. Reference numeral 55 recognizes the dot pattern state of four points in the bit contents of the register 54, and at the time of the specific dot pattern state described later, It is a discrimination control circuit that controls the bit selection circuit 53 to sequentially select dot information. Reference numeral 56 is a register that stores 4-bit information read by the control of the discrimination control circuit 55. Reference numeral 57 denotes a dot for outputting a 1-bit interpolation value switching selection signal according to the dot pattern state between the two grid dot information read out under the control of the discrimination control circuit 55 and the dot information of the register 54. Discrimination circuit.

참조번호(58)는 레지스터(44)에 저장된 소수부의 치(5비트의 x성분을 포함하는 주.주사방향 오프셋치)와 레지스터(54)에 저장된 4점의 도트정보와 도트판별회로(57)에서 출력되는 1비트의 보간치절환 선택신호를 입력정보로하여 상기 4점의 도트정보로 둘러싸인 영역내에 있어서의 새로운 도트의 보간치(Qxy)를 출력하는 보간 테이블 ROM이다. 여기에서는 256K 비트(32K×8비트)의 마스크 ROM를 사용하여 15비트의 판독어드레스에 따라 8비트(0-255레벨)의 보간치를 출력한다.Reference numeral 58 denotes the value of the fractional part stored in the register 44 (the main / scan direction offset value including the 5-bit x component) and the dot information and the dot discrimination circuit 57 of the four points stored in the register 54. The interpolation table ROM outputs the interpolation value Qxy of a new dot in an area surrounded by the four points of dot information by using the 1-bit interpolation value switching selection signal output from the input information. Here, a mask ROM of 256K bits (32K x 8 bits) is used to output an 8-bit (0-255 level) interpolation value according to a 15-bit read address.

참조번호(59)는 보간테이블 ROM(58)에서 출력되는 보간치와 레지스터(50)에 저장된 임계치와의 비교를 취하는 비교기이고, 보간치가 비교치, 즉 임계치를 초과 했을때에 온 도트(휘점)를 표시하는 "1"레벨의 신호를 출력한다.Reference numeral 59 is a comparator for comparing the interpolation value output from interpolation table ROM 58 with the threshold stored in register 50, and the dot (brightness point) on when the interpolation value exceeds the comparison value, that is, the threshold value. Outputs a signal of "1" level indicating.

참조번호(60)는 비교기(59)에서 출력된 도트정보를 차례로 저장하고, 문자패턴이 전개되는 메모리의 기입비트단위(여기에서는 8비트 단위로 한다)마다 CPU 버스(12)에 출력하는 시프트레지스터이다.Reference numeral 60 sequentially stores the dot information output from the comparator 59, and outputs it to the CPU bus 12 for each write bit unit (here, 8 bit units) of the memory in which the character pattern is developed. to be.

제3도 내지 제11도는 각각 상기 일실시예의 동작을 설명하기 위한 도면이다.3 to 11 are diagrams for explaining the operation of the above embodiment, respectively.

제3a도 내지 (f)는 각각 보간처리에 의하여 생성되는 새로운 도트를 둘러싸는 1격자 4점의 도트정보(도트패턴)와, 보간테이블 ROM(58)에 설정된 보간치의 레벨구분과, 테이블 형태와의 관계를 도시하는 도면이다. 여기에서는 보간치를 0 내지 255계단의 휘도(명암레벨)로 표시하고, 그 구분된 일부의 영역을 등고선으로 나타내고 있다.3A to 3F show dot information (dot pattern) of one grid and four points surrounding each new dot generated by interpolation processing, the level classification of the interpolation value set in the interpolation table ROM 58, the table form and It is a figure which shows the relationship of. Here, the interpolation value is expressed by the luminance (contrast level) of 0 to 255 steps, and a part of the divided area is shown by the contour line.

제4도는 상기 1격자 4점의 도트패턴중 1도트만이 온("1") 또는 오프("0")시의 테이블 형태의 선택절환예를 설명하기 위한 것으로, 도트패턴인식부(DSP)는 예를 들면 위 4점의 도트(D0,D1,D2,D3)중 1점만이 오프 즉 "0"(도면에서는 흰동그라미로 표시한 D0)일때에, 또 그 주위의 격자의 특정도트(Da,Db)의 온.오프상태를 인식하여 Da,Db="0"일때에 제3d도의 도시와 같은 코오너 형태의 테이블(T1)을 선택하고, 또, Da,Db의 적어도 어느 한 쪽이 "0"이면 제3f도의 도시와 같은 경사형태의 테이블(T0)을 선택한다. 이와 같이 4점의 도트영역내에 위치하는 새로운 도트의 보간치는 그 4점의 도트가 상기한 특정의 패턴을 형성할때 다시 그 주위의 도트상태에 의하여 정해진다.4 is a view for explaining a table-type selection switching example when only one dot of one dot pattern of four grids is on ("1") or off ("0"), and the dot pattern recognition unit (DSP) For example, when only one of the above four dots D0, D1, D2, and D3 is off, that is, "0" (D0 denoted by a white circle in the drawing), and the dot (Da) of the surrounding grid is specified. Recognizes the on / off state of Db) and selects the co-owner type table T1 as shown in FIG. 3d when Da, Db = "0 ", and at least one of Da, Db is " 0 ", the inclined table T0 as shown in FIG. 3f is selected. In this way, the interpolation value of the new dot located in the dot region of four points is determined by the dot state around the dots when the four dots form the above-described specific pattern.

제5a도 내지 (b)는 각종의 패턴변환예를 도시한 것으로, 도면중 Sm는 주·주사방향, Ss는 부·주사방향을 각각 나타내고, 도면(a)는 정체(正體)(또는 장체, 평체), 도면(b)는 경사체, 도면(c)는 하부정돈형경사체, 도면 (d)는 회전체를 각각 나타낸다.5A to 5B show various pattern conversion examples, in which Sm represents the main and scanning directions, Ss represents the sub and scanning directions, respectively, and FIG. Plane), drawing (b) shows an inclined body, drawing (c) shows a lower trimmed inclined body, and drawing (d) shows a rotating body, respectively.

제6a,b도는 도트보간처리의 출력대상 즉 이미지 출력대상과 그때의 도트보간시에 있어서의 주.주사방향(Sm) 및 부.주사방향(Ss)과의 관계를 설명하는 도면이다. 도면(a)는 CRT 표시시의 도트보간시에 있어서의 주.주사 및 부.주사의 방향을 나타내고, 도면(b)는 프린트 아우트시의 도트보간시에 있어서의 주.주사 및 부.주사의 방향을 각각 나타내고 있다. 이와같이 CRT 표시출력시의 도트보간처리와 프린트아우트시의 도트보간처리에 있어서는 주.주사방향과 부.주사방향이 서로 뒤바뀐 상태가 된다.6A and 6B are diagrams for explaining the relationship between the output object of the dot interpolation process, that is, the image output object and the main / scan direction Sm and the sub-scan direction Ss at the time of dot interpolation. (A) shows the directions of main, scanning and sub scanning at the time of dot interpolation at the time of CRT display, and (b) shows the main, scanning and sub scanning at the time of dot interpolation at the time of printing out. Each direction is shown. In this way, in the dot interpolation process at the time of CRT display output and the dot interpolation process at the time of printout, the main scanning direction and the sub scanning direction are inverted.

제7도는 각종 설정데이터의 대응관계를 도시한 도면이다.7 is a diagram showing a correspondence relationship between various types of setting data.

제8도는 도트보간처리에 의하여 패턴변환된 문자와 그 문자에 외접(外接)하는 직사각형(정사각형을 포함)과의 관계를 도시한 도면이다.FIG. 8 is a diagram showing a relationship between a character pattern-transformed by dot interpolation processing and a rectangle (including a square) circumscribed to the character.

제9도는 각종 변형문자에 대한 문자피치(CP) 및 행피치(LP)의 설정예를 도시한 도면이다.9 is a diagram showing an example of setting of the character pitch CP and the row pitch LP for various modified characters.

제10도는 각 종류의 변형문자에 대한 하선의 전개예를 도시한 도면이다.FIG. 10 is a diagram showing an example of development of underline for each type of deformed character.

제11도는 구역지정동작을 설명하는 도면이다.11 is a diagram for explaining the zoning operation.

이제부터 본 발명의 일실시예의 동작을 설명한다. 도트보간시에 있어서 CPU(10)는 외부로부터 입력된 도트보간지정 정보에 따라 각종 레지스터의 초기 설정을 실시한다. 즉, CPU(10)는 보간테이블 ROM(58)에서 생성되는 보간치와의 비교를 하기 위한 비교치, 즉 임계치(th)를 레지스터(50)에 세트한 후 지정된 확대·축소 배율에 따라 기준이 되는 도트 새김폭(dx,dy:확대·축소배율의 역수치)을 산출하여 이것을 레지스터(26),(27)에 세트하고, 다시 회전 또는 경사체일때는 그 지정 각도에 따르는 3각 함수데이터(sin,cos,tan)를 3각 함수테이블(24)에 세트한다.The operation of one embodiment of the present invention will now be described. At the time of dot interpolation, the CPU 10 performs initial setting of various registers in accordance with dot interpolation specification information input from the outside. That is, the CPU 10 sets the comparison value for comparison with the interpolation value generated in the interpolation table ROM 58, that is, the threshold value th in the register 50, and then sets the reference value according to the designated magnification. Calculate the dot indentation width (dx, dy: inverse of magnification / reduced magnification) and set it in the registers 26 and 27, and when it is rotated or inclined again, the trigonometric function data according to the designated angle ( sin, cos, tan) are set in the trigonometric function table 24.

그후 이들 레지스터(26),(27) 및 3각 함수테이블(24)의 설정데이터(sin,cos,tan)에 따라 도트보간어드레스를 생성하기 위한 초기치(초기치 어드레스:X1 init, Y1 init) 및 도트새김폭(DX1,DY1,DX2,DY2)을 산출하고, 이들의 데이터를 레지스터(31)∼(36)에 세트하는 동시에 확대 회전 등의 패턴변환에 의하여 발생하는 문자높이, 문자폭의 변동에 따르는 V크기 및 H크기의 각 데이터를 산출하여 이것을 레지스터(21),(22)에 세트하고, 또 구역구분이 생길때는 그 구역수를 산출하여 이 데이터를 레지스터(25)에 세트한다. 또, 도트보간된 문자를 그 출력시에 1 내지 7도트 범위내에서 이동시키는 경우(예를 들면, 도트보간된 루우비문자(작은 활자의 문자) 및 반각문자 등을 프린트 아우트할때에, 1 내지 7도트의 범위를 가지고 상하 이동시키는 경우등), 또는 패턴변환된 문자의 주·주사방향 도트수가 그 출력대상이 되는 이미지 메모리의 기입폭(8도트)의 배수가 되지 않고 이미지 메모리측의 바이크경계(기입폭)와 맞출 필요가 있을 경우 등에 있어서는 오프셋 레지스터(28)에 1 내지 7도트 범위내에서 오프셋치가 세트된다.Then, initial values (initial value addresses: X1 init, Y1 init) and dots for generating the dot interpolation address according to the setting data (sin, cos, tan) of these registers 26, 27 and the trigonometric function table 24. Indentation widths DX1, DY1, DX2, and DY2 are calculated, and their data are set in the registers 31 to 36, and at the same time, variations in character height and character width caused by pattern conversion such as enlargement and rotation are performed. The data of the V size and the H size is calculated and set in the registers 21 and 22, and when the zones are divided, the number of zones is calculated and this data is set in the register 25. Also, when the dot interpolated character is shifted within the range of 1 to 7 dots at the time of its output (for example, when printing out the interpolated ruby ruby character (small letter) and half-width character, etc., 1). The number of dots in the main / scanning direction of the pattern-converted character is not a multiple of the write width (8 dots) of the image memory to be outputted, and the bike on the image memory side When it is necessary to match the boundary (write width) or the like, an offset value is set in the offset register 28 within a range of 1 to 7 dots.

상기와 같은 각 레지스터의 초기 설정을 끝낸 후, CPU(10)는 이하와 같은 보트보간 어드레스의 생성처리를 개시한다.After finishing the initial setting of each register as described above, the CPU 10 starts the generation process of the boat interpolation address as follows.

우선, 도트보간이 제5a도의 도시와 같은 정체(또는 장체,평체)를 출력대상으로하여 실시되는 경우(예를 들면, 단순한 확대·축소)를 예로 들어 전체의 동작을 설명한다. 이 도트보간시에 있어서는 레지스터(31)에 『0』레지스터(32)에 도트새김폭『dx』, 레지스터(33)에 주·주사방향(sm)의 초기치『sx』, 레지스터(34)에 도트새김폭『dy』, 레지스터(35)에『0』, 레지스터(36)에 부·주사방향(Ss)의 초기치『sy』가 각각 세트된다.First, the whole operation will be described taking the case where dot interpolation is performed with a stagnation (or a long body or a flat body) as shown in FIG. 5A as an output object (for example, simple enlargement / reduction). In this dot interpolation, the register 31 has a dot writing width "dx" in the "0" register 32, the initial value "sx" in the main / scanning direction sm in the register 33, and a dot in the register 34. FIG. The engraving width "dy", "0" in the register 35, and the initial value "sy" in the sub-scanning direction Ss are set in the register 36, respectively.

여기에서 상기 레지스터(32,34)에 세트되는 도트새김폭(dx,dy)은 확대·축소배율의 역수치로서 주어진다. 또, 레지스터(33)에는 [Ix=(dx-1)/2]로 되는 Ix가 초기치(Sx)로 주어지고, 레지스터(36)에는 [Iy=(dy-1)/2]로 되는 Iy가 초기치(Sy)로 주어진다. 여기서 dx 또는 dy가『1』이하일때(즉,확대시)는 Ix 또는 Iy가 부(負)가 되어 1문자버퍼(52)의 원문자패턴 격납영역외의 어드레스를 표시하고, dx 또는 dy가 『1』이상일때(즉,축소시)는 Ix 또는 Iy가 정(正)이 되어 1문자버퍼(52)의 원문자패턴 격납영역내의 어드레스를 표시한다. 또, 레지스터(50)에는 보간테이블 ROM(58)에서 출력되는 보간치와 비교를 하고, 새로운 도트의 어느쪽 레벨 이상의 것을 의미있는 도트로 하느냐를 결정하기 위한 임의의 레벨(0-255레벨)의 비교치, 즉 임계치(th)가 세트된다.The dot notation widths dx and dy set in the registers 32 and 34 are given as inverse values of the enlargement / reduction ratio. In the register 33, Ix having [Ix = (dx-1) / 2] is given as an initial value Sx, and the register 36 has Iy having [Iy = (dy-1) / 2]. It is given by the initial value Sy. When dx or dy is less than or equal to "1" (that is, when enlarged), Ix or Iy becomes negative to display an address outside the original character pattern storage area of the one-character buffer 52, and dx or dy is " 1 'or more (i.e., at the time of reduction), Ix or Iy is positive to display the address in the original character pattern storage area of the one-character buffer 52. In addition, the register 50 is compared with the interpolation value output from the interpolation table ROM 58, and an arbitrary level (0-255 level) for determining which level or more of the new dot is a meaningful dot. The comparison value, i.e. threshold th, is set.

그리고, CPU(10)는 한자패턴 메모리(51)에서 도트보간대상이 되는 1문자분의 도트패턴 데이터를 판독하여, 이 문자패턴 데이터를 1문자버퍼(52)에 기입된다. 이때, 1문자버퍼(52)에는 상기와 같이 도트보간대상이 되는 1문자분의 도트패턴 데이터가 그 주의를 의미없는 "0"이 도트로 둘러싸인 상태로 기억된다.The CPU 10 reads the dot pattern data for one character to be interpolated from the Chinese character pattern memory 51 and writes the character pattern data into the one character buffer 52. At this time, the one-character buffer 52 stores the dot pattern data for one character to be the dot interpolation object as described above in a state where " 0 " which is meaningless is surrounded by dots.

상기 레지스터(31∼36)로의 데이터 및 1문자버퍼(52)로의 보간대상 문자패턴의 취출이 끝난 후, 선택제어회로(49)의 제어하에 레지스터(33,36)에 저장된 초기 어드레스가 되는 데이터(Sx,Sy)가 데이터 셀렉터(41,45)에 의하여 선택되어 각각 대응하는 레지스터(42,46)에 저장된다. 또, 주·주사를 개시할때에 있어서는 상기 레지스터(42,46)에 저장된 데이터(Sx,Sy)가 데이터 셀렉터(43,47)에 의하여 선택되어 각각 대응하는 레지스터(44,48)에 저장된다.After taking out the data to the registers 31 to 36 and the interpolation target character pattern to the one-character buffer 52, the data to be the initial address stored in the registers 33 and 36 under the control of the selection control circuit 49 ( Sx and Sy are selected by the data selectors 41 and 45 and stored in the corresponding registers 42 and 46, respectively. In addition, when starting scanning and scanning, the data Sx and Sy stored in the registers 42 and 46 are selected by the data selectors 43 and 47 and stored in the corresponding registers 44 and 48, respectively. .

이 레지스터(44,48)에 저장된 데이터(Sx,Sy)는 그 정수부의 치가 비트선택회로(53)에 주어지고, 소수부의 치가 보간테이블 ROM(58)에 주어진다.The data Sx and Sy stored in these registers 44 and 48 are given the value of the integer part to the bit selection circuit 53, and the value of the fractional part is given to the interpolation table ROM 58.

비트선택회로(53)는 상기 입력된 정수부의 치에 따라 1문자버퍼(52)로부터 1격자 4점의 도트정보를 선택하여 보간테이블 ROM(58)에 공급한다. 이때, 확대시(dx,dy<1)에 있어서는 비트선택회로(53)에 1문자버퍼(52)의 원문자패턴 격납영역외의 어드레스를 표시하는 부(負)의 치가 주어지므로 원문자패턴 격납영역외의 도트를 포함하는 1격자 4점의 도트정보에서 도트선택을 개시한다. 또 축소시(dx,dy>1)에 있어서는 비트선택회로(53)에, 1문자버퍼(52)의 원문자패턴 격납영역내의 어드레스를 표시하는 정(正)의 치가 주어지므로 원문자패턴 격납영역내의 1격자 4점의 도트정보에서 도트선택을 개시한다.The bit select circuit 53 selects the dot information of one grid and four points from the one-character buffer 52 according to the input value of the integer part, and supplies it to the interpolation table ROM 58. At this time, in magnification (dx, dy <1), since the bit selection circuit 53 is given a negative value indicating an address other than the original character pattern storage area of the one-character buffer 52, the original character pattern storage area Dot selection is started from dot information of one grid and four points including other dots. At the time of reduction (dx, dy> 1), since the bit selection circuit 53 is given a positive value indicating an address in the original character pattern storage area of the one-character buffer 52, the original character pattern storage area Dot selection is started from dot information of four points in one grid.

보간테이블 ROM(58)은 상기 레지스터(44,48)로부터의 각 오프셋(계 10비트)와, 비트선택회로(53)로부터의 주위 4점의 도트정보와, 도트패턴인식부(DSP)로부터의 1비트의 보간치 절환선택신호를 입력정보로하여 그 내용에 따르는 8비트의 보간치(Qxy)를 출력한다. 이때, 비트선택회로(53)에서 출력된 1격자 4점의 도트패턴이 도트패턴인식부(DSP)에 의하여 인식되어 제4도의 도시와 같이 특정의 도트패턴일때는 다시 그 주위의 격자의 특정도트의 온·오프상태를 인식하여, 그 도트상태에 따른 1비트의 보간치 절환선택신호를 출력한다. 즉, 예를 들면 제4도의 도시와 같이 주위 4점의 도트(D0,D1,D2,D3)중 1점만이 오프 즉 "0"(도면에서는 흰동그라미로 표시한 D0)일때는 다시 그 주위의 격자의 특정도트(Da,Db)의 온·오프상태를 인식하고, Da,Db="1"이면 제3d도의 도시와 같은 코오너형태의 테이블(T1)을 선택하고, 또 Da,Db의 적어도 어느 한쪽이 "0"이면 제3f도의 도시와 같은 경사형 형태의 테이블(T0)을 선택하도록 보간치 절환선택신호를 출력한다. 또, 주위 4점의 도트(D0,D1,D2,D3)중 1점만이 온 즉 "1"(도면에서 흰동그라미에 사선을 그은 동그라미로 도시한 D0)일때는 다시 그 주위의 격자의 특정도트(Da,Db)의 온·오프상태를 인식하고, Da,Db="0"이면 제3a도의 도시와 같은 코오너형태의 테이블(T1)을 선택하고, 또 Da,Db의 적어도 어느 한쪽이 "1"이면 제3e도의 도시와 같은 경사형 형태의 테이블(T0)을 선택하기 위한 보간치 절환선택신호를 출력한다. 이와 같이 4점의 도트영역내에 위치하는 새로운 도트의 보간치는 그 4점의 도트가 상기와 같은 특정의 패턴을 형성할때 다시 그 주위의 도트상태에 의하여 정해진다. 그리고 상기 보간테이블 ROM(58)에서 출력된 8비트(0-255레벨)의 보간치는 비교기(59)에 입력되어 레지스터(36)에 저장된 비교치 즉 임계치와 비교되는 보간치가 임계치를 초과하고 있으면 의미있는 도트인 것을 나타내는 "1"레벨의 신호를 출력하고, 또 보간치가 임계치를 초과하고 있지 않으면 의미가 없는 도트인 것을 표시하는 "0"레벨의 신호를 출력한다.The interpolation table ROM 58 stores each offset (10 bits in total) from the registers 44 and 48, dot information of four points of surroundings from the bit selection circuit 53, and the dot pattern recognition unit DSP. The 1-bit interpolation value switching selection signal is used as input information, and an 8-bit interpolation value Qxy corresponding to the content is output. At this time, when the dot pattern of one grid and four points output from the bit selection circuit 53 is recognized by the dot pattern recognition unit DSP and is a specific dot pattern as shown in FIG. Recognizes the on / off state and outputs a 1-bit interpolation value switching selection signal corresponding to the dot state. That is, for example, as shown in FIG. 4, when only one point of the four surrounding dots D0, D1, D2, and D3 is off, that is, "0" (D0 indicated by white circles in the drawing), Recognizes the on / off state of the specific dots Da and Db of the lattice, and if Da, Db = " 1 ", selects the co-owner type table T1 as shown in FIG. 3d, and at least Da, Db If either is "0", the interpolation value switching selection signal is output so as to select the inclined table T0 as shown in FIG. 3F. In addition, when only one point among four surrounding dots D0, D1, D2, and D3 is on, that is, "1" (D0 shown as a circle drawn with a white circle in the drawing), a specific dot of the surrounding grid is again. Recognizing the on / off state of (Da, Db), and Da, Db = " 0 " selects a co-owner type table T1 as shown in FIG. 3a, and at least one of Da, Db is " 1 ", an interpolation value switching selection signal for selecting the inclined table T0 as shown in FIG. 3E is output. In this way, the interpolation value of the new dot located in the dot area of four points is determined by the dot state around it again when the four dots form a specific pattern as described above. The interpolation value of 8 bits (0 to 255 level) output from the interpolation table ROM 58 is input to the comparator 59, meaning that the interpolation value compared to the threshold stored in the register 36 exceeds the threshold. A signal of level "1" indicating that the dot is present is output, and a signal of level "0" indicating that the dot is meaningless if the interpolation value does not exceed the threshold.

한편, 보간테이블 ROM(58)에서 1도트의 보간치가 출력된 후에는 레지스터(44)의 내용과 레지스터(32)의 내용이 가산회로(38)에 의하여 가산되는 동시에 레지스터(48)의 내용과 레지스터(35)의 내용이 가산회로(40)에 의하여 가산되고 그 각 가산결과의 데이터가 선택제어회로(49)의 제어하에 각각 대응되는 데이터 셀렉터(43,47)에 의하여 선택되어서 레지스터(44,48)에 저장된다. 이때, 주·주사방향의 도트새김폭을 도시하는 레지스터(32,35)중 레지스터(32)에는 지정된 확대·축소배율에 따르는 도트새김폭(dx)이 설정되어 있고, 레지스터(35)에는 정체(또는 장체,평체)의 도트보간이므로 상기와 같이 『0』이 설정됨으로, 레지스터(44)의 내용(도트어드레스)은 1도트의 보간처리마다 지정된 확대·축소배율에 따르는 도트새김폭(dx)을 가지고 차례로 갱신되나, 레지스터(48)의 내용은 결과적으로 갱신되지 않고 초기 설정시의 데이터가 그대로 유지된다. 또, 1회의 주·주사가 끝날때마다, 레지스터(42)의 내용과 레지스터(31)의 내용이 가산회로(37)에 의하여 가산되는 동시에 레지스터(46)의 내용과 레지스터(34)의 내용이 가산회로(39)에 의하여 가산되고, 그 각 가산결과의 데이터가 선택제어회로(49)의 제어하에 각각 대응되는 데이터 셀렉터(41,45)에 의하여 선택되어서 레지스터(42,46)에 각각 저장된다. 이때, 부·주사방향의 도트새김폭을 표시하는 레지스터(31,34)중 레지스터(34)에는 지정된 확대·축소배율에 따르는 도트새김폭(dy)이 설정되어 있고, 레지스터(31)에는 정체(또는 장체,평체)의 도트보간이므로 상기와 같이 『0』이 설정됨으로, 레지스터(46)의 내용(도트어드레스)은 1회의 주·주사가 실행될때마다 지정된 확대·축소배율에 따르는 도트새김폭(dy)을 가지고 갱신되나, 레지스터(42)의 내용은 결과적으로 갱신되지 않고 초기 설정시의 데이터가 그대로 유지된다.On the other hand, after the interpolation value of one dot is output from the interpolation table ROM 58, the contents of the register 44 and the contents of the register 32 are added by the addition circuit 38, and at the same time, the contents of the register 48 and the register. The contents of (35) are added by the addition circuit 40, and the data of each addition result is selected by the corresponding data selectors 43 and 47 under the control of the selection control circuit 49, and the registers 44 and 48 ) At this time, among the registers 32 and 35 showing the dot engraving widths in the main and scanning directions, the dot writing width dx corresponding to the designated magnification / reduction ratio is set in the register 32, and the register 35 has a stagnation ( Or "0" is set as described above since the dot interpolation of the long body and the flat body, the contents (dot address) of the register 44 is the dot notation width (dx) in accordance with the enlargement and reduction ratio specified for each interpolation process of 1 dot. The contents of the register 48 are not updated as a result, but the data at the initial setting is maintained as it is. In addition, the contents of the register 42 and the contents of the register 31 are added by the addition circuit 37 at the end of one main scan / injection, and the contents of the register 46 and the contents of the register 34 are added. Is added by the addition circuit 39, and the data of each addition result is selected by the corresponding data selectors 41 and 45 under the control of the selection control circuit 49 and stored in the registers 42 and 46, respectively. . At this time, among the registers 31 and 34 indicating the dot-indentation widths in the sub-scanning direction, the dot-indentation width dy in accordance with the designated magnification / reduction ratio is set in the register 34, and the register 31 has a stagnation ( Or "0" is set as described above since the dot interpolation of the long body and the flat body, and the content (dot address) of the register 46 is the dot indentation width (depending on the designated magnification / reduction ratio each time one scanning or scanning is executed). dy), but the contents of the register 42 are not updated as a result and the data at the initial setting is retained.

이와 같이 하여 차례로 보간테이블 ROM(58)로부터 새로운 도트어드레스에 대한 보간치가 출력되고 이 보간치가 비교기(59)에 의하여 레지스터(50)의 임계치(th)와 비교되어 새로운 도트정보가 생성된다.In this way, interpolation values for the new dot addresses are sequentially output from the interpolation table ROM 58, and the interpolation values are compared with the threshold value th of the register 50 by the comparator 59 to generate new dot information.

그리고 상기 비교기(59)에서 출력된 보간처리후의 새로운 도트정보는 차례로 시프트 레지스터(60)에 저장되어 1바이트 단위로 CPU 버스(12)에 송출된다.The new dot information after interpolation processing output from the comparator 59 is stored in the shift register 60 in turn and sent to the CPU bus 12 in units of 1 byte.

이때, CPU 버스(12)에 송출되는 도트보간처리된 문자패턴 데이터가, 예를 들면 프린트아우트용으로서 인자제어부(17)의 라인버퍼(18)에 기입되는 경우, 또 오프셋 레지스터(28)에 1 내지 7도트 범위내의 오프셋치가 세트되고 있는 경우(예를 들면, 도트보간된 루우비문자를 프린트아우트시에 i(i=1,2,…,7)도트 하방으로 이동시키는 경우), 또는, 패턴변환된 문자의 주·주사방향 도트수가 출력대상이되는 이미지 메모리의 기입폭(8도트)의 배수가 되지 않고 이미지 메모리측의 바이트경계(기입폭)와 합칠 필요가 있어 오프셋 레지스터(28)에 그 오프셋치(i)가 설정되어 있는 경우 등에 있어서는, 그 오프셋 레지스터(28)의 오프셋치(i)에 따라 오프셋 데이터 생성부(29)에서 오프셋 데이터(i개의 "0")가 생성되어, 이 데이터가 주·주사의 개시에 앞서서 시프트 레지스터(60)에 세트되고, 그후에 계속해서 도트보간된 데이터 즉, 변환처리된 문자패턴도트가 기입된다.At this time, in the case where the dot interpolated character pattern data sent to the CPU bus 12 is written into the line buffer 18 of the printing control unit 17, for example, for printout, it is set to 1 in the offset register 28. When an offset value within the range of 7 to 7 dots is set (for example, when the dot interpolated ruby letter is moved below i (i = 1, 2, ..., 7) dots at the time of printout), or a pattern The number of dots in the main / scanning direction of the converted characters does not need to be a multiple of the write width (8 dots) of the image memory to be output, and must be combined with the byte boundary (write width) on the image memory side. In the case where the offset value i is set or the like, the offset data generation unit 29 generates offset data (i " 0 " s) in accordance with the offset value i of the offset register 28. Before the start of the injection 60), and subsequently dot interpolated data, i.e., converted character pattern dots, is written.

상기 동작은 정체(또는 장체,평체)를 출력대상으로 한 경우였으나, 예를 들면 회전체를 출력대상으로 한 경우의 도트보간 어드레스의 생성처리시에 있어서는 레지스터(31) 내지 (36)의 각각에 대하여 지정회전각에 따르는 3각함수 테이블(24)내의 소정 3각함수 데이터가 한 요소로서 포함되는 데이터가 세트된다.The above operation was performed when stagnant (or long or flat) output targets were used. For example, when the dot interpolation address is generated when the rotating body is output target, each of the registers 31 to 36 is used. With respect to the predetermined rotation angle, data in which the predetermined trigonometric function data in the trigonometric function table 24 is included as one element is set.

즉, 지정된 회전각을 [θ°], 원래폰트(font)의 x방향 도트수를[a+1], 원래폰트(font)의 y방향의 도트수를 [b+1]로 하면, 레지스터(31)에는 DX1=-dx·sinθ°, 레지스터(32)에는 DX2=dx·cosθ°, 레지스터(34)에는 DY1=dy·cosθ°, 레지스터(35)에는 DY2=dy·sinθ°가 각각 세트된다.That is, if the designated rotation angle is [θ °], the number of dots in the x direction of the original font is [a + 1] and the number of dots in the y direction of the original font is [b + 1], the register ( 31) DX1 = -dxsinθ °, register 32 is set to DX2 = dxcosθ °, register 34 is set to DY1 = dycosθ °, and register 35 is set to DY2 = dysinsinθ °. .

또, 레지스터(33,X1 init) 및 레지스터(36, y1 init)에는, (1) 0°

Figure kpo00002
θ°
Figure kpo00003
90°일 때 X1 init=1/2a-1/2(a+1-dx)cos2θ°, Y1 init=-1/2(1-dy)-1/2(a+1-dx)dy/dx sin2θ°, (2) 90°
Figure kpo00004
θ°
Figure kpo00005
180°일때 X1 init=a+1/2(1-dx)-1/2(b+1-by)dx/dy sin2θ°, Y1 init=1/2b+1/2(b+1-dy)cos2θ°, (3) 180°
Figure kpo00006
θ°
Figure kpo00007
270°일때 X1 init=1/2a+1/2(a+1-dx)cos2θ°, Y1 init=b+1/2(1-dy)+1/2(a+1-dx)dy/dx sin2θ°, (4) 270°<θ°<360°일때 X1 init=1/2(1-dx)+1/2(b+1-dy)dx/dy sin2θ°, Y1 init=1/2b-1/2(b+1-dy)cos2θ°를 각각 세트한다.In addition, the registers 33 and X1 init and the registers 36 and y1 init are (1) 0 °.
Figure kpo00002
θ °
Figure kpo00003
At 90 ° X1 init = 1 / 2a-1 / 2 (a + 1-dx) cos2θ °, Y1 init = -1 / 2 (1-dy) -1/2 (a + 1-dx) dy / dx sin2θ °, (2) 90 °
Figure kpo00004
θ °
Figure kpo00005
At 180 ° X1 init = a + 1/2 (1-dx) -1/2 (b + 1-by) dx / dy sin2θ °, Y1 init = 1 / 2b + 1/2 (b + 1-dy) cos2θ °, (3) 180 °
Figure kpo00006
θ °
Figure kpo00007
At 270 ° X1 init = 1 / 2a + 1/2 (a + 1-dx) cos2θ °, Y1 init = b + 1/2 (1-dy) +1/2 (a + 1-dx) dy / dx sin2θ °, (4) 270 ° <θ ° <360 ° X1 init = 1/2 (1-dx) +1/2 (b + 1-dy) dx / dy sin2θ °, Y1 init = 1 / 2b- 1/2 (b + 1-dy) cos2θ ° are set respectively.

상기와 같이하여 회전각도(θ°)에 따르는 3각함수 데이터를 포함하는 도트새김폭, 초기 어드레스 등의 각 설정치(DX1,DX2,DY1,DY2,X1 init, Y1 init)를 산출하여 각각 대응하는 레지스터(31) 내지 (36)에 세트한 후 상기한 바와 같은 주·주사방향 및 부·주사방향에 대한 도트보간 어드레스 생성처리를 차례로 실행하므로서 지정각도(θ°)에 따른 회전문자 패턴도트가 얻어진다.As described above, each set value (DX1, DX2, DY1, DY2, X1 init, Y1 init), such as dot indentation width and initial address, including trigonometric function data according to the rotation angle (θ °), is calculated, respectively. After setting in the registers 31 to 36, a dot interpolation address generation process for the main, scanning direction and sub-scanning direction as described above is executed in sequence, thereby obtaining a rotating character pattern dot according to the designated angle (θ °). Lose.

또, 경사형 문자를 출력대상으로 했을 경우의 도트보간 어드레스의 생성처리시에 있어서는 레지스터(31) 내지 (36)중의 특정한 레지스터에 지정경사각에 따르는 3각함수 테이블(24)내의 소정의 3각함수 데이터를 한 요소로서 포함하는 데이터가 세트된다.In addition, during the generation process of the dot interpolation address when the oblique character is used as the output target, the predetermined trigonometric function in the trigonometric function table 24 according to the specified inclination angle is specified for the specific register in the registers 31 to 36. Data including data as one element is set.

즉, 지정된 경사각을『θ°』, 원래폰트(font)의 x방향 도트수를[a+1], 원래폰트(font)의 y방향 도트수를 [b+1]로 하면, 0°<θ°<90°의 범위에서, 레지스터(31)에는 DX1=dx·tanθ°, 레지스터(32)에는 DX2=dx, 레지스터(34)에는 DY1=dy, 레지스터(35)에는 DY2=0가 각각 세트되고, 또, 레지스터(33)에는 X1 init=1/2(1-dx)-(b+1-dy)dx/dy tanθ°, 레지스터(36)에는 Y1 init=-1/2(1-dy)가 각각 세트된다.That is, if the designated inclination angle is "θ °", the number of dots in the x direction of the original font is [a + 1] and the number of dots in the y direction of the original font is [b + 1], 0 ° <θ. In the range of ° <90 °, DX1 = dxtanθ ° in the register 31, DX2 = dx in the register 32, DY1 = dy in the register 34 and DY2 = 0 in the register 35, respectively. In the register 33, X1 init = 1/2 (1-dx)-(b + 1-dy) dx / dy tanθ °, and in the register 36, Y1 init = -1 / 2 (1-dy). Are set respectively.

상기와 같이하여 경사각도(θ°)에 따르는 3각함수 데이터를 포함하는 도트새김폭, 초기 어드레스 등의 각 설정치(DX1,DX2,DY1,DY2,X1 init, Y1 init)를 산출하여 각각 대응하는 레지스터(31) 내지 (36)에 세트한 후, 상기와 같은 주·주사방향 및 부·주사방향에 대한 보트보간 어드레스 생성처리를 차례로 실행하므로써 지정각도(θ°)에 따라 경사화된 이탤릭체문자 패턴도트를 얻을 수 있다.As described above, each set value (DX1, DX2, DY1, DY2, X1 init, Y1 init), such as dot indentation width and initial address, including trigonometric function data according to the inclination angle θ °, is calculated, respectively. After setting in the registers 31 to 36, italic character pattern inclined according to the designated angle (θ °) by sequentially performing the above-described boat interpolation address generation processing for the main, scanning and sub-scanning directions. You can get a dot.

상기 설명과 같이, 지정각도(θ°)에 따르는 3각함수 데이터를 포함하는 도트새김폭, 초기 어드레스 등의 각 설정치(DX1,DX2,DY1,DY2,X1 init, Y1 init)에 따라 상기와 같은 주·주사방향 및 부·주사방향에 대한 보트보간 어드레스 생성처리를 차례로 실행하여 그 생성된 도트보간 어드레스를 기초로 새로운 도트정보를 얻는다. 이 새로운 도트정보는 상기와 같이 차례로 시프트 레지스터(60)에 저장되어 바이트(8비트) 단위로 CPU 버스(12)를 경유하여 출력대상이 된다. 예를 들면, 인자제어부(17)의 라인버퍼(18)에 기입된다.As described above, according to the set values (DX1, DX2, DY1, DY2, X1 init, Y1 init), such as dot indentation width and initial address, including trigonometric function data according to the designated angle (θ °). Boat interpolation address generation processing for the main, scanning and sub-scanning directions is executed in order to obtain new dot information based on the generated dot interpolation address. The new dot information is sequentially stored in the shift register 60 as described above, and becomes an output object via the CPU bus 12 in units of bytes (8 bits). For example, it is written to the line buffer 18 of the print control unit 17.

이때, 라인버퍼(18)는 통상 인자문자높이의 도트구성에 대응하는 비트쪽(예를 들면, 세로 8×3=24도트)으로 구성되므로, 상기와 같은 회전체문자, 이탤릭체문자 등의 변형문자에 대해서는 축소패턴의 경우를 제외하고는 24도트의 크기에 수용되지 않는다. 따라서, 이와 같은 경우에는 상기한 레지스터의 초기 설정시에 새로이 생성되는 문자패턴을 복수의 구역으로 구분하도록 CPU(10)가 지정된 변환문자체 및 그 글자의 각도, 확대·축소배율 등을 토대로 변환된 문자에 대한 구역수를 산출하여 그 구역수를 표시하는 데이터를 구역지정용 레지스터(25)에 세트하여 구역단위로 패턴을 기입할때마다 상기한 레지스터(25)의 내용을 감소(-1)하고, 그 내용이 『0』가 될 때까지는 각 구역의 패턴 데이터를 동일문자패턴으로서 취급한다. 즉 구역지정용 레지스터(25)에 의하여 지정된 구역에 대해서는 그 각 패턴간에 공백에리어(area, 행간격)를 끼어놓지 않고, 연속하는 도트인자지정을 실행한다. 이때의 구역구분의 한 예를 제11도에 도시한다.At this time, since the line buffer 18 is generally composed of the bit side (for example, 8 × 3 = 24 dots vertically) corresponding to the dot structure of the print character height, the modified characters such as the above-mentioned rotating body characters and italic characters. Is not accommodated in the size of 24 dots except for the reduction pattern. Therefore, in such a case, the characters converted by the CPU 10 to which the newly generated character pattern is divided into a plurality of zones at the time of initial setting of the register into a plurality of zones, and the angle, enlargement / reduction ratio, etc. of the character are converted. The data of the register 25 is decreased (-1) each time the pattern is written in the unit of the zone by calculating the number of zones for the zone and setting the data indicating the number of zones in the zone designation register 25. Until the contents become "0", the pattern data of each zone is treated as the same character pattern. In other words, for the area designated by the area designation register 25, continuous dot factor designation is executed without interleaving an area (line spacing) between the patterns. An example of the zone division at this time is shown in FIG.

상기 구역수의 산출수단은 제7도 및 제8도의 도시와 같이, 지정된 회전각도/경사각도/확대·축소배율등에서 변환(변형)된 문자에 대하여 외접하는 x,y방향의 직사각형(정사각형을 포함)의 크기를 구하고 그 사각형이 서로 접하는 2변의 각 도트수(x,y도트수)를 구하여 이것을 상기한 레지스터 초기 설정시에 V size 및 H size의 데이터로서 레지스터(21,22)에 세트해 놓으므로서 쉽게 인식할 수 있다. 즉, 어떤 각도를 가지고 변환된 문자에서는 그 문자의 기입(취급)이 그 문자에 외접하는 수평·수직선상의 직사각형의 에리어(area)를 토대로하여 실행되는 것으로, 예를 들면 프린트아우트일때의 도트보간처리시에 있어서는 레지스터(22)에 저장된 H size의 데이터를 라인버퍼(18)의 비트폭『24』으로 나눗셈하므로서 쉽게 상기 구역수를 구할 수 있고, 또 표시출력일때의 도트보간처리시에 있어서는 레지스터(21)에 저장된 V Size의 데이터를 1표시행의 비트폭『24』로 나눗셈하므로서 쉽게 구역수를 구할 수 있다.The means for calculating the number of zones includes a rectangle (square) in the x and y directions that circumscribes the characters converted (deformed) at a designated rotation angle, tilt angle, enlargement, and reduction ratio, as shown in FIGS. 7 and 8. ), And the number of dots (x, y dots) of the two sides of the squares which are in contact with each other, and is set in the registers 21 and 22 as data of V size and H size at the initial register setting. Therefore, it can be easily recognized. That is, in a character converted at an angle, the writing (handling) of the character is performed based on an area of horizontal and vertical rectangles circumscribed to the character, for example, dot interpolation processing for a printout. In the city, the area number can be easily obtained by dividing the H size data stored in the register 22 by the bit width &quot; 24 &quot; of the line buffer 18, and in the case of dot interpolation processing at display output, the register ( The number of zones can be easily obtained by dividing the V size data stored in 21) by the bit width &quot; 24 &quot;

또, 상기 구역지정용 레지스터(25)에 임의의 구역지정 데이터를 고정적으로 부여하므로서 지정된 동일구역의 이미지 데이터를 연속적으로 반복하여 이미지 전개할 수 있다. 이에 의하여 상기 도트보간처리에 의하여 변형된 문자패턴을 다시 그 일부 또는 전부를 용장화(冗長化)된 변형문자 패턴으로서 인자 또는 표시출력할 수도 있다.Further, by arbitrarily giving arbitrary zoning data to the zoning register 25, image data of the designated same zone can be continuously and repeatedly image developed. As a result, the character pattern deformed by the dot interpolation process can be printed or displayed as a modified character pattern which is partially or entirely redundant.

또, 상기한 V size 및 H size의 데이터는 문자피치를 설정할때와, 하선/방선을 처리할때에도 참조된다. 즉, 상기와 같은 주사방향으로 임의의 경사각도를 가지는 도트보간에 의하여 얻어지는 경사, 회전 등의 문자는 그 문자전체의 높이(문자높이) 및 폭(문자폭)이 경사각도, 또는 그것에 더하여 확대·축소배율 등에 따라 여러 가지로 변화된다. 따라서, 상기와 같은 변형문자를 통상의 행, 열방향(x,y방향)을 가지고 이미지 출력했을 때 문자피치, 또는 하선/방선 등을 기존의 고정적인 파라미터 지정수단으로 정할 수가 없다.The V size and H size data described above are also referred to when setting the character pitch and when processing the underline / radiation. That is, the characters such as the inclination and rotation obtained by dot interpolation having an arbitrary inclination angle in the scanning direction as described above have the height (character height) and width (character width) of the entire character being inclined angle or in addition to that. It varies depending on the reduction factor. Therefore, when the above-described modified characters are outputted in the usual line, column direction (x, y direction), the character pitch, underline / line, etc. cannot be determined by the existing fixed parameter designation means.

그러므로, 문자피치, 하선/방선 등의 처리에 대해서도 상기와 같은 외접하는 직사각형을 문자의 보디페이스(body face)로 하여 취급한다. 이하에 이들의 처리수단을 설명한다.Therefore, the above-mentioned circumscribed rectangles are also treated as the body face of the character in the processing of the character pitch, underline / radiation, and the like. These processing means will be described below.

우선, 문자피치의 처리동작을 설명한다. 상기와 같이 1문자분의 도트보간처리가 실행되어 새로이 생성된 1문자분의 도트이미지가 출력대상이 되는, 예를 들면 인자제어부(17)내의 라인버퍼(18)에 전개될(기입)때마다 CPU(10)는 레지스터(21)의 내용(V size)이 갱신되었는지 아닌지를 판단한다. 그리고 상기 레지스터(21)의 내용이 갱신되어 있지 아니하면 레지스터(21)에 저장된 데이터(V size)에 다시 그 1/2의 값을 더한 데이터를 문자피치를 표시하는 제어데이터로서 인자제어부(17)에 공급하고 라인버퍼(18)상에 전개되는 문자의 피치를 제어한다. 또, 상기 레지스터(21)의 내용이 갱신될때는 그 갱신전의 데이터를 특정 레지스터영역에 보관해 놓고, 그 갱신시에 있어서의 특정 레지스터영역에 보관한 갱신전의 데이터와 갱신된 데이터의 합의 1/4의 값을 다시 상기 레지스터(21)에 저장된 갱신후의 데이터에 더해서 이것을 문자피치를 표시하는 제어데이터로서 인자제어부(17)에 공급하고, 라인버퍼(18)상에 전개되는 문자의 피치를 제어한다.First, the processing operation of the character pitch will be described. When the dot interpolation process for one character is executed as described above and a newly generated dot image for one character is to be outputted, for example, each time it is developed (written) in the line buffer 18 in the print control unit 17. The CPU 10 determines whether or not the contents V size of the register 21 have been updated. If the contents of the register 21 are not updated, the print control unit 17 serves as control data for displaying the character pitch of the data (V size) stored in the register 21, plus the value of the value 1/2. The pitch of the characters to be supplied to and expanded on the line buffer 18 is controlled. When the contents of the register 21 are updated, 1/4 of the sum of the data before the update and the updated data is stored in the specific register area at the time of the update and stored in the specific register area. Is added to the updated data stored in the register 21 again and supplied to the print control unit 17 as control data indicating character pitch, and the pitch of the characters developed on the line buffer 18 is controlled.

이와 같이, 어떤 각도를 가지고 변환된 문자에 대해서는 그 문자의 기입(취급)이 그 문자에 외접하는 수평·수직선상의 직사각형의 에리어(area)를 토대로 하여 실행되므로 그 직사각형의 횡폭(프린트아우트의 경우는 V size, 표시출력의 경우는 H size)을 따라 인접하는 문자와의 사이의 피치가 결정된다. 행피치에 대해서도 상기와 같은 피치제어가 실시된다. 이때의 각종 변형문자에 대한 문자피치(CP) 및 행피치(LP)의 설정예를 제9도에 도시한다.Thus, for a character converted at an angle, the writing (handling) of the character is performed based on the horizontal and vertical rectangular area that circumscribes the character, so that the width of the rectangle (in the case of printout) The pitch between adjacent characters is determined along V size and H size for display output. The pitch control as described above is also performed for the row pitch. FIG. 9 shows an example of setting the character pitch CP and the row pitch LP for various modified characters at this time.

또, 상기한 피치제어는 항상 인접하는 문자가 차지하는 에리어(외접하는 직사각형)를 고려하면서 피치를 결정했으나 처리를 간소화하기 위하여 단순히 그때 그때의 레지스터(21)(또는 레지스터(22))치를 토대로 피치를 결정하는 제어수단을 취해도 좋다.In addition, the above pitch control always determines the pitch while considering the area occupied by adjacent characters (circumscribed rectangle). However, in order to simplify the processing, the pitch control is based on the value of the register 21 (or register 22) at that time. You may take control means for determining.

다음에 상기한 외접하는 직사각형을 토대로 하선/방선을 출력할때의 동작을 설명한다. 이때, 프린트아우트의 경우는 레지스터(21)에 저장된 데이터(V size)가 참조되고, 표시출력의 경우는 레지스터(22)에 저장된 데이터(H size)가 참조된다. 여기에서는 프린트아우트의 경우를 예로 들어 하선/방선의 처리동작을 설명한다. 인자제어부(17)에 설치된 하선/방선제어부(23)는 CPU 버스(12)를 통하여 입력되는 인자제어정보에 포함되는 하선/방선의 지시에 따라 라인버퍼(18)상에 하선 또는 방선의 도트를 전개하나, 상기와 같은 회전, 이탤릭체등의 변형문자에 대해서는 통상의 문자폭에 의한 라인전개로는 대응을 취할 수 없다.Next, the operation at the time of outputting the underline / radiation on the basis of the circumscribed rectangle described above will be described. In this case, the data V size stored in the register 21 is referred to in the case of printout, and the data H size stored in the register 22 is referred to in the case of display output. Here, the processing operation of the underline / radiation will be described taking the case of the printout as an example. The underline / radiation control unit 23 installed in the print control unit 17 draws a line of underline or radiation on the line buffer 18 according to the underline / radiation instruction included in the print control information input through the CPU bus 12. However, for the deformed characters such as rotation and italic type as described above, it is not possible to respond to the line expansion by the normal character width.

그러므로, 레지스터(21)의 내용(V size)을 항상 입력하여 하선/방선의 지시가 있으면 그때의 레지스터(21)의 갱신데이터 내용에 따르는 라인길이를 가지고 하선/방선의 도트패턴을 생성하고, 라인버퍼(18)상에 그 문자에 대응시켜서 패턴을 전개한다.Therefore, when the contents (V size) of the register 21 are always inputted, and if there is an indication of the underline / radiation, the underline / radiation dot pattern is generated with the line length corresponding to the contents of the update data of the register 21 at that time. The pattern is developed on the buffer 18 in correspondence with the character.

이때의 각종 변형문자에 대한 하선의 전개예를 제10도에 도시한다.FIG. 10 shows an example of development of underlines for various modified characters at this time.

이상의 상세한 설명과 같이 본 발명에 의하면 소정의 도트매트릭스 구성의 문자패턴을 적어도 주·주사방향 또는 부·주사방향으로 도트보간하는 도트보간장치를 보간도트패턴의 출력제어장치에 있어서, x성분과 y성분으로 표시되는 주·주사방향의 도트보간 어드레스를 생성하는 수단, 및 x성분과 y성분으로 표시되는 부·주사방향의 도트보간 어드레스를 생성하는 보간도트 어드레스 생성수단과, 이 보간도트 어드레스 생성수단에 의하여 생성된 상기 각 도트보간 어드레스에 따르는 좌표점의 보간도트를 생성하는 보간도트 생성수단과, 이 보간도트 생서수단으로 생성된 보간도트정보를 그 도트보간처리된 문자패턴이 전개되는 이미지 메모리의 기입폭에 대응하는 비트길이를 가지고 저장하는 시프트 레지스터와, 이 시프트 레지스터에 대하여 주·주사마다의 보간도트의 기입에 앞서서 상기 이미지 메모리의 기입폭에 상당하는 비트범위내의 오프셋값을 선택적으로 생성하고 상기 시프트 레지스터에 기입하는 오프셋 데이터 생성수단을 구비하며, 도트보간에 의하여 발생하는 문자패턴 도트의 기입개시 위치와 상기 이미지 메모리의 기입경계와의 대응을 취할 수 있도록 하므로서 원문자자체를 고정밀도의 도트보간을 가지고 임의의 확대 및 축소배율, 각도등에 따라 변형했을때에 변형문자마다의 이미지 데이터의 취급이 쉬워지고 또 임의의 문자를 이미지 메모리의 기입폭의 범위내에서 이동이 가능하므로 도트보간된 문자패턴의 출력기능을 확충할 수 있다.As described above, according to the present invention, a dot interpolation device for dot interpolation of a character pattern having a predetermined dot matrix configuration in at least the main, scanning direction, or sub-scanning direction is used in the output control device of the interpolation dot pattern. Means for generating dot interpolation addresses in the main / scanning direction indicated by components, and interpolation dot address generating means for generating dot interpolation addresses in the sub-scanning directions indicated by the x and y components, and the interpolation dot address generating means. Interpolation dot generation means for generating interpolation dots of coordinate points corresponding to each of the dot interpolation addresses generated by the interpolation dot and interpolation dot information generated by the interpolation dot generation means. Shift register for storing with bit length corresponding to write width, and note A character pattern generated by dot interpolation, comprising offset data generating means for selectively generating an offset value within a bit range corresponding to a writing width of said image memory prior to writing interpolation dots for each phase, and writing to said shift register; The image for each deformed character when the original letter itself is transformed according to an arbitrary magnification, reduction factor, angle, etc. with high-precision dot interpolation, so that the dot writing start position can correspond to the writing boundary of the image memory. Since the data can be easily handled and arbitrary characters can be moved within the range of the write width of the image memory, the output function of the dot interpolated character pattern can be expanded.

Claims (1)

소정도트매트릭스 구성의 문자패턴을 적어도 주·주사방향 또는 부·주사방향으로 도트보간하도록 구성된 도트보간장치의 보간도트패턴의 출력제어장치에 있어서, x성분과 y성분으로 표시되는 주·주사방향의 도트보간 어드레스를 생성하는 동시에 x성분과 y성분으로 표시되는 부·주사방향의 도트보간 어드레스를 생성하는 보간도트 어드레스 생성수단(31-49)과 ; 이 보간도트 어드레스 생성수단에 의하여 생성된 상기 각 도트보간 어드레스에 따르는 좌표점의 보간도트를 생성하는 보간도트 생성수단(58)과 ; 이 보간도트 생성수단으로 생성된 보간도트정보를 그 도트보간처리된 문자패턴이 전개되는 이미지 메모리의 기입폭에 대응하는 비트길이를 가지고 조장하는 시프트 레지스터(60)와 ; 이 시프트 레지스터에 대하여 주·주사마다의 보간도트의 기입에 앞서서 상기 이미지 메모리의 기입폭에 상당하는 비트범위내의 오프셋치를 선택적으로 생성하고 상기 시프트 레지스터에 기입하는 오프셋 데이터 생성수단(29)을 구비하여, 상기 도트보간에 의하여 생기는 문자패턴도트의 기입개시 위치와 상기 이미지 메모리의 기입경계와의 대응을 취할 수 있도록 구성한 것을 특징으로 하는 보간도트패턴의 출력제어장치.An output control device of an interpolation dot pattern of a dot interpolation device configured to dot interpolate a character pattern having a predetermined dot matrix configuration in at least the main, scanning direction, or sub-scanning direction, the main / scanning direction represented by the x component and the y component. Interpolation dot address generating means (31-49) for generating a dot interpolation address and generating a dot interpolation address in the sub-scanning direction represented by the x component and the y component; Interpolation dot generation means (58) for generating interpolation dots of coordinate points corresponding to the respective dot interpolation addresses generated by the interpolation dot address generating means; A shift register 60 for promoting interpolation dot information generated by the interpolation dot generating means with a bit length corresponding to the write width of the image memory in which the dot interpolated character pattern is developed; And offset data generating means 29 for selectively generating an offset value within a bit range corresponding to a write width of the image memory prior to writing interpolation dots for each scan and scan with respect to the shift register. And a write start position of the character pattern dot generated by the dot interpolation so as to correspond to a writing boundary of the image memory.
KR1019850000083A 1984-04-28 1985-01-09 Output controller of interpolation dot pattern KR900004949B1 (en)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
JP59-86372 1984-04-28
JP59086372A JPS60229766A (en) 1984-04-28 1984-04-28 Output control system of interpolation dot pattern

Publications (2)

Publication Number Publication Date
KR850007711A KR850007711A (en) 1985-12-07
KR900004949B1 true KR900004949B1 (en) 1990-07-12

Family

ID=13885047

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1019850000083A KR900004949B1 (en) 1984-04-28 1985-01-09 Output controller of interpolation dot pattern

Country Status (2)

Country Link
JP (1) JPS60229766A (en)
KR (1) KR900004949B1 (en)

Families Citing this family (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPS6195952A (en) * 1984-10-15 1986-05-14 ガ−バ−・サイエンテイフイツク・プロダクツ・インコ−ポレ−テツド Device for generating text and other character by various constitution

Family Cites Families (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPS5432153A (en) * 1977-08-16 1979-03-09 Kawasaki Steel Co Continuous treatment line for metal plate
JPS5950435B2 (en) * 1981-04-14 1984-12-08 川崎製鉄株式会社 Method for joining metal strip ends in continuous metal strip processing production line

Also Published As

Publication number Publication date
JPS60229766A (en) 1985-11-15
KR850007711A (en) 1985-12-07

Similar Documents

Publication Publication Date Title
EP0471482B1 (en) Character processing method
US5719595A (en) Method and apparauts for generating a text image on a display with anti-aliasing effect
US4712185A (en) Dot interpolation control system
JP3286796B2 (en) Method and image creation device for reducing the amount of storage required
KR960016739B1 (en) Method of correctly aligning the line width of outline font
GB2115657A (en) Method of storing characters and photo-typsetting apparatus
KR900004949B1 (en) Output controller of interpolation dot pattern
KR900004950B1 (en) Character interpolation control method
KR900004892B1 (en) Dot inter polation system
KR900004948B1 (en) Under/side line pattern generating device
US4642622A (en) Video signal generating circuit
EP0392499A2 (en) Apparatus for generating high-quality character pattern
JPH05120441A (en) Vector picture plotting device
KR900007681B1 (en) Dot interpolation control system
JPH046554B2 (en)
JPH049152B2 (en)
KR910005779B1 (en) Printer controlling method for reducing the number of dot
KR910005778B1 (en) Printer controlling method for designating printing direction
JP2782752B2 (en) Character pattern output device
JPH0392897A (en) Pattern generating device
JPH06175639A (en) Method and device for character generation
KR890005005B1 (en) Dot interpolation control system
JP3347756B2 (en) Character generation method and device
KR870000432B1 (en) Memroy system of characters and drawing and apparatus for photo-composing
JP2835056B2 (en) High quality character pattern generation method

Legal Events

Date Code Title Description
A201 Request for examination
E902 Notification of reason for refusal
G160 Decision to publish patent application
E701 Decision to grant or registration of patent right
GRNT Written decision to grant
FPAY Annual fee payment

Payment date: 19971227

Year of fee payment: 9

LAPS Lapse due to unpaid annual fee