KR900007681B1 - Dot interpolation control system - Google Patents

Dot interpolation control system Download PDF

Info

Publication number
KR900007681B1
KR900007681B1 KR1019850000081A KR850000081A KR900007681B1 KR 900007681 B1 KR900007681 B1 KR 900007681B1 KR 1019850000081 A KR1019850000081 A KR 1019850000081A KR 850000081 A KR850000081 A KR 850000081A KR 900007681 B1 KR900007681 B1 KR 900007681B1
Authority
KR
South Korea
Prior art keywords
dot
interpolation
character
register
data
Prior art date
Application number
KR1019850000081A
Other languages
Korean (ko)
Other versions
KR850007709A (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 KR850007709A publication Critical patent/KR850007709A/en
Application granted granted Critical
Publication of KR900007681B1 publication Critical patent/KR900007681B1/en

Links

Images

Classifications

    • 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
    • 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

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)
  • Image Processing (AREA)
  • Controls And Circuits For Display Device (AREA)
  • Processing Or Creating Images (AREA)
  • Document Processing Apparatus (AREA)

Abstract

The dot interpolation control system includes a pair of registers for designating initial addresses of interpolated dots along the main scanning direction. Another pair of registers designates a dot picth along the main scanning direction, and still another pair of registers designats a dot pitch along the subscanning direction. Data pairs of x and y components, which selectively include trigonometric function data representing a designated rotation or inclination angle, are set in the correspponding registers. Dot interpolation of a character pattern is performed by main scanning and subscanning in accordance with the contents of the respective registers, thereby obtaining a rotated or inclined character on the basis of the designated angle.

Description

도트보간 제어방식Dot interpolation control method

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

제2도는 본 발명의 일실시예에서 요부의 구성을 나타낸 블록도.Figure 2 is a block diagram showing the configuration of the main portion in one embodiment of the present invention.

제3도 내지 제11도는 각각 상기 실시예의 동작을 설명하기 위한 것으로, 제3도(a) 내지 (f)는 각각 도트보간 처리에 의하여 생성되는 새로운 도트를 둘러싼 1격자 4점의 도트정보(도트패턴) 및 보간 테이블ROM에 설정된 보간치의 레벨구분과 테이블 타이프와의 관계를 나타낸 도면.3 to 11 are views for explaining the operation of the above embodiment, respectively, and FIGS. 3A to 3F respectively show dot information (dots) of four points of one lattice surrounding a new dot generated by dot interpolation processing. Pattern) and the relationship between the level classification of the interpolation value set in the interpolation table ROM and the table type.

제4도는 테이블 타이프의 선택을 바꾸는 동작을 설명하기 위한 도면.4 is a diagram for explaining an operation of changing the selection of the table type.

제5도(a) 내지 (d)는 각각 패턴의 변환예를 나타낸 도면.5 (a) to (d) are diagrams showing conversion examples of patterns, respectively.

제6도(a),(b)는 CRT를 표시할때의 주.부주사 방향과 프린트 아우트일때의 주.부주사방향을 대비하여 나타낸 도면.6 (a) and 6 (b) show the main and sub-scanning directions when displaying CRTs and the main and sub-scanning directions when printing outs.

제7도는 각종 설정데이타의 관계를 나타낸 도면.7 is a diagram showing a relationship between various setting data.

제8도는 도트보간 처리에 의하여 패턴이 변환된 문자와 그 문자에 외접하는 장방형과의 관계를 나타낸 도면.8 is a diagram showing a relationship between a character whose pattern is converted by dot interpolation processing and a rectangle circumscribed to the character.

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

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

제11도는 구역의 분할수단을 설명하기 위한 도면.11 is a view for explaining division means of a zone.

* 도면의 주요부분에 대한 부호의 설명* 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 : 병렬-직렬 변환회로(P-S)14: Frame memory (FM) 15: Parallel-to-serial conversion circuit (P-S)

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

13 : 하선/방선 제어부13: disembarkation / radiation control part

24 : 삼각함수 테이블 29 : 오프셋 데이타 생성부24: trigonometric function table 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 selection circuit 55: discrimination control circuit

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

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

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

문자작성 장치등, 규정된 도트 매트릭스 구성의 문자폰트를 취급하는 장치에 있어서, 규정된 도트 매트릭스 구성의 문자폰트를 어떠한 배율로 확대.축소할 수 있는 기능을 갖게 하는 경우, 종래에는 제1도(a) 내지 (b)에 나타낸 바와같이 원문자 패턴 도트(SD &)에서 단순히 도트를 증가, 또는 삭제하는 소위 단순확대 축소방식이 채용되어 왔다.In a device that handles a character font having a prescribed dot matrix configuration, such as a character writing device, when the character font having a prescribed dot matrix configuration has a function capable of expanding and contracting at a certain magnification, conventionally, FIG. As shown in a) to (b), a so-called simple enlargement and reduction method of simply increasing or deleting dots in the original pattern pattern (SD &) has been adopted.

이와같은 종래의 확개.축소 수단은, 비교적 간단하고 또 염가로 실현할 수 있으나, 예를들면 경사선 부분에서의 계단형상의 형성부가 두드러지게 되는 등, 출력되는 패턴형상이 본래의 표현하고자 하는 문자형태에서 빗나가게되어, 인식하기 어려운 부자연스러운 문자표현을 하게되는 불합리점이 있었다.Such conventional expansion / contraction means can be realized relatively simply and inexpensively. However, for example, a character form intended to be inherently expressed by the pattern shape to be output, such as a stepped portion in the inclined line portion becomes prominent. There was an absurdity that was deviated from, resulting in unnatural character expression that was difficult to recognize.

또 상기한 바와같은 종래의 도트보간 수단에 있어서는 원문자 패턴, 또는 임의의 확대.축소배율을 가진 문자패턴을 임의의 각도를 가지고 경사형상화 하거나 또는 회전시킨 변형문자체를 얻고자 할때, 이것을 쉽게 얻을 수 없고, 또 그 변형범위를 대폭으로 제약하더라도, 변환된 문자패턴에 왜곡이 생기고, 또 변환정밀도가 크게 낮아져서 충실성이 높은 패턴변환을 할 수 없는 등, 형편이 좋지 못하였다.In addition, in the conventional dot interpolation means as described above, when the original character pattern or the character pattern having an arbitrary magnification / reduction ratio is slanted or rotated at an arbitrary angle, it is easily obtained. In addition, even if the deformation range was largely restricted, distortion was generated in the converted character pattern, the conversion precision was greatly lowered, and high fidelity pattern conversion was not possible.

또 상기한 바와같은 회전문자나 경사화 문자등의 변형문자에 대해서는 그 도트보간된 문자의 문자폭 또는 문자높이, 또는 그중 어느 한편이 지정된 확대.출소배율 또는 각도등에 의하여 여러가지로 변화되고, 특히 확대, 전개, 경사화를 할때 등에 있어서는, 변환된 1문자분의 도트 이미지가 1행분의 이미지 기억공간(예를들면 이미지 라인버퍼)에 들어가지 않고, 통상의 문자출력 수단으로는 문자의 일부에 소위 모자라는 부분이 생기고 문자가 복수행으로 겹쳐져쳐서 분리 출력되는 등 문자 이미지 취급상 불합리점이 생기며, 또 어떠한 슬라이스폭의 이미지를 여러변 반복하여 예를들면 인자출력한 경우에, 이에 응할 수 없는 기능상의 불합리점도 발생하였었다.In addition, as for the deformed characters such as the rotation character or the oblique character, the character width or the height of the dot interpolated character or one of them is changed in various ways by the designated magnification / release ratio or angle, and in particular, the magnification and the expansion. In the case of tilting, for example, the converted dot image for one character does not enter one row of image storage space (e.g., an image line buffer), and a portion of the character is so-called as a normal character output means. There is an irregularity in the handling of the character image, such as a part is formed and the characters are overlapped in multiple lines, and the output is separated. Also, if the image of any slice width is repeatedly printed, for example, printing, the functional irrationality cannot be met. Viscosity occurred.

본 발명은 상기한 실정에 입각하여 이루어진 것으로, 원문자폰트를 도트보간 처리에 의하여, 임의의 배율, 각도등을 가지고 변형했을 때에, 이미지 메모리상에 전개되는 문자패턴이 규정된 행폭을 넘더라도, 그 문자패턴을 하나의 자체로서 취급하여 도트 전개할 수 있는 동시에 임의의 부분 이미지를 임의 회수로 연속하여 도트 전개할 수 있는 도트보간 장치를 제공하는 것을 목적으로 한다.The present invention has been made in view of the above-described circumstances. Even when the original font is deformed by an arbitrary magnification, angle, etc. by dot interpolation processing, even if the character pattern developed on the image memory exceeds the prescribed row width, It is an object of the present invention to provide a dot interpolation apparatus capable of dot development by treating the character pattern as one itself and at the same time continuously dot developing any partial image at any number of times.

본 발명은 소정의 도트 매트릭스 구성의 문자패턴을 적어도 주.주사방향 또는 부.주사방향으로 도트보간하는 보간장치에 있어서, x성분과 y성분으로 표시되는 주.주사방향의 도트보간 어드레스 및 x성분과 y성분으로 표시되는 부.주사방향의 도트보간 어드레스를 기본으로 하여 도트보간를 생성하는 수단, 그 생성된 도트보간 정보를 소정의 도트단위의 슬라이스 폭을 가지고 구역 나누기를 하기 위한 구역지정수단, 및 그 구역 지정수단으로 지정된 구역의 이미지 데이타를 전송 제어하는 수단을 구비하여, 확대, 회전 또는 경사화된 변형문자를 소정이 도트폭 단위의 조운으로 나누어서 이미지 전개하는 구성으로 함으로써, 원문자폰트를 도트보간 처리에 의하여 임의의 배율, 각도등을 가지고 변형하였을 때에 이미지 메모리상에 전개되는 문자패턴이 규정된 행폭을 넘더라도, 그 문자패턴을 하나의 자체로 취급하여 도트전개 할 수 있는 동시에 임의의 부분 이미지를 임의 회수로 연속하여 도트 전개할 수 있게 된다.The present invention relates to an interpolation apparatus for dot interpolating a character pattern having a predetermined dot matrix configuration in at least the main, scanning direction, or sub-scanning direction, wherein the dot interpolation address and the x component in the main and scanning directions represented by the x component and the y component. Means for generating dot interpolation based on the dot interpolation address in the sub-scanning direction expressed by the y component, and zone specifying means for dividing the generated dot interpolation information with a slice width in a predetermined dot unit, and The original character font is dot-contained by providing a structure which transmits and controls image data of the area | region designated by the area | region designation means, and expands, rotates, or inclines the deformed character by dividing the image into predetermined | prescribed division of the dot width unit, and a dot of the original font When the pattern is deformed at an arbitrary magnification or angle by interpolation, the character pattern developed on the image memory Even if the prescribed width is exceeded, the character pattern can be treated as a single dot, and dot development can be performed, and the random partial image can be dot-developed continuously at any number of times.

이하 도면을 참조하여 본 발명의 일실시예를 설명한다.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)에 기입하는 하선/방선 제어부이다.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.

참조번호(24)는 문자의 경사형 회전시등에 있어서의 지정각도에 따른 각도정보(3각 함수데이타)를 저장하는 3각 함수 테이블이다. 참조번호(25)는 패턴변환시에 있어서 기준문자 높이를 초과한 변환처리후의 문자패턴을 상기 기준문자 높이를 단위로 구역을 구분하기 위한 구역지정용 레지스터이다. 참조번호(26) 및 (27)는 문자의 확대.축소배율에 따르는 도트새김폭(dx,dy)을 저장하는 레지스터, 참조번호(28)는 패턴변환된 문자에 0 내지 7도트 범위에서 선택적으로 오프셋(offset)을 주기 위한 오프셋 레지스터, 참조번호(29)는 오프셋 레지스터(28)의 오프셋치에 따르는 도트수를 가지고 오프셋 데이타(비표시를 나타내는 "0")를 생성하는 오프셋 데이타 생성부이다.Reference numeral 24 is a trigonometric function table for storing angular information (triangular function data) according to the designated angle in the case of the oblique rotation of characters. Reference numeral 25 denotes a zone designation register for dividing zones in units of the reference character height from the character pattern after the conversion process exceeding the reference character height in pattern conversion. Reference numerals 26 and 27 denote registers for storing the dot notation widths (dx, dy) according to the enlargement / reduction ratio of the characters, and reference numeral 28 selectively in the range of 0 to 7 dots for pattern converted characters. The offset register for giving an offset, reference numeral 29, is an offset data generation unit that generates 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)을 저장하는 레지스터, 참조번호(35)는 y성분을 포함하는 주.주사방향의 도트새김폭(DY2)을 저장하는 레지스터, 참조번호(36)는 y성분을 포함하는 부.주사방향의 초기치(초기 어드레스 : Y1 init)를 저장하는 레지스터이다.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 x components. , 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 35 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.

상기의 각 레지스터(31)-(36)에 저장되는 도트보간 어드레스는 각각 정수부의 데이타와 소수부의 데이타로 구성된다. 참조번호(37)는 상기의 레지스터(31)의 내용과 x성분을 포함하는 부.주사방향의 도트위치를 표시하는 레지스터(42)의 내용을 가산하는 가산회로(ADD-A), 참조번호(38)는 상기 레지스터(32)의 내용과 x성분을 포함하는 주.주사방향의 도트위치를 표시하는 레지스터(44)의 내용을 가산하는 가산회로(ADD-B), 참조번호(39)는 상기 레지스터(34)의 내용과 y성분을 포함하는 부.주사방향의 도트위치를 표시하는 레지스터(46)의 내용을 가산하는 가산회로(ADD-C), 참조번호(40)는 상기 레지스터(35)의 내용과 y성분을 포함하는 주.주사방향의 도트위치를 표시하는 레지스터(48)의 내용을 가산하는 가산회로(ADD-D)이다.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. 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성분을 포함하는 도트보간시의 새로운 도트 어드레스를 저장하는 레지스터이다.Reference numeral 41 selects the contents of the register 33 at the start of the dot interpolation process for one character, and then selects the output of the addition circuit 37 each time a main scan / scan is executed. Denotes a new dot address for dot interpolation represented by an integer part and a fractional part including an x component selected by the data selector 41, and reference numeral 43 denotes the register at the start of scanning and scanning. A data selector for selecting the contents of (42), and then selecting the output of the addition circuit 38 for each dot interpolation process, and reference numeral 44 denotes a dot interpolation including the x component selected by the data selector 43; This register stores the new dot address of the hour.

참조번호(45)는 1문자분의 도트보간 처리를 개시할 때에 상기 레지스터(36)의 내용을 선택하고, 이후 1회의 주.주사가 실행될 때마다 가산회로(39)의 출력을 선택하는 데이타 셀렉터, 참조번호(46)는 데이타 셀렉터(45)에서 선택된 y성분을 포함하는 정수부와 소수로 표시되는 도트보간시의 새로운 도트 어드레스를 저장하는 레지스터, 참조번호(47)는 주.주사를 개시할 때에 상기 레지스터(46)의 내용을 선택하고, 이후 1도트분의 보간처리를 할때마다 가산회로(40)의 출력을 선택하는 데이타 셀렉터, 참조번호(48)는 데이타 셀렉터(47)에서 선택된 y성분을 포함하는 도트보간시의 새로운 도트 어드레스를 저장하는 레지스터이다.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. Denotes an integer portion containing the y component selected by the data selector 45, and a register for storing a new dot address in dot interpolation represented by a decimal number. A data selector which selects the contents of the register 46, and then selects the output of the addition circuit 40 each time the interpolation process is performed for one dot, and the reference numeral 48 denotes the y component selected by the data selector 47. Is a register for storing a new dot address during dot interpolation.

참조번호(49)는 상기 각 데이타 셀렉터(41),(43),(45),(47)를 제어하는 선택 제어회로(SC)이다. 참조번호(50)는 후술하는 보간치와의 비교를 실행하기 위한 비교치, 즉 임계치(th)를 저장하는 레지스터이다. 참조번호(51)는 한자를 포함하는 소정의 도트 매트릭스단위(16×16도트)의 문자패턴 데이타가 격납된 한자 패턴메모리(KPM)이다. 참조번호(52)는 한자 패턴메모리(51)에서 판독된 1문자분의 도트패턴을 저장하는 고속 RAM에 의하여 구성된 1문자 버퍼이다.Reference numeral 49 denotes a selection control circuit SC for controlling the respective data selectors 41, 43, 45, 47. 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. 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.

여기에서는 1문자분의 도트패턴을 그 주위를 오프도트 "0"의 비트패턴으로 채운 상태로 기억한다. 참조번호(53)는 1문자버퍼(52)에 저장된 문자패턴 데이타중 레지스터(44),(48)의 각 정수부의 치에 따라 새로운도트를 둘러싸는 1격자 4점의 도트정보를 선택적으로 출력하는 비트선택회로이다.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.

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

참조번호(56)는 이 판별제어회로(55)의 제어로 판독된 4비트의 정보를 저장하는 레지스터이다. 참조번호(57)는 판별제어회로(55)의 제어로 판독된 2격자분의 도트정보와 레지스터(54)의 도트정보와의 도트패턴 상태에 따른 1비트의 보간치절환 선택신호를 출력하는 도트판별 회로이다.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. An interpolation table ROM that outputs an 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"레벨의 신호를 출력한다. 참조번호(60)는 비교기(59)에서 출력된 도트정보를 차례로 저장하고, 문자패턴이 전개되는 메모리의 기입비트단위(여기에서는 8비트 단위로 한다)마다 CPU 버스(12)에 출력하는 시프트레지스터이다.Reference numeral 59 denotes a comparator for comparing the interpolation value output from the interpolation table ROM 58 with the threshold stored in the register 50, and an dot (bright point) when the interpolation value exceeds the comparison value, that is, the threshold value. Outputs a signal of level " 1 " 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도(a) 내지 (f)는 각각 보간처리에 의하여 생성되는 새로운 도트를 둘러싸는 1격자 4점의 도트정보(도트패턴)와, 보간 테이블ROM(58)에 설정된 보간치의 레벨구분과, 테이블 형태와의 관계를 도시하는 도면이다.3 to 11 are diagrams for explaining the operation of the above embodiment, respectively. 3 (a) to 3 (f) 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, It is a figure which shows the relationship with a table form.

여기에서는 보간치를 0 내지 255계단의 휘도(명암레벨)로 표시하고, 그 구분된 일부의 영역을 등고선으로 나타내고 있다.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="1"일때에 제3도(d)의 도시와 같은 코오너 형태의 테이를(T1)을 선택하고, 또 Da.Db의 적어도 어느 한쪽이 "0"이면 제3도(f)의 도시와 같은 경사형태의 테이블(T0)을 선택한다. 이와같이 4점의 도트영역내에 위치하는 새로운 도트의 보간치는 그 4점의 도트가 상기한 특정의 패턴을 형성할 때 다시 그 주위의 도트 상태에 의하여 정해진다.FIG. 4 is a diagram for explaining a table-type selection switching example when only one dot of the dot patterns of one grid and four points is turned on ("1") or off ("0"). Dot pattern recognition unit (DSP) For example, when only one point of four surrounding dots D0, D1, D2, and D3 is OFF, that is, "0" (D0 denoted by a white circle in the drawing), and a specific dot (Da) of the surrounding grid is shown. Recognizes the on / off state of Db) and selects a co-owned table (T1) as shown in FIG. 3d when Da, Db = " 1 " If one is "0", the inclined table T0 as shown in FIG. 3 (f) is selected. In this way, the interpolation value of the new dot positioned 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.

제5도(a) 내지 (d)는 각종의 패턴변환예를 도시한 것으로, 도면중 Sm는 주.주사방향, Ss는 부.주사방향을 각각 나타내고, 도면(a)는 정체(正體)(또는 장체,평체), 도면(b)는 경사체, 도면(c)는 하부정돈경사체, 도면(d)는 회전체를 각각 나타낸다.5 (a) to 5 (d) show various pattern conversion examples, in which Sm represents the main / scanning direction, Ss represents the sub-scanning direction, and FIG. Or (b) is a slant body, (c) is a bottom trimmer, and (d) is a rotating body.

제6도(a),(b)는 도트보간 처리의 출력대상 즉 이미지 출력대상과 그때의 도트보간시에 있어서의 주.주사방향(Sm) 및 부.주사방향(Ss)과의 관계를 설명하는 도면이다.6 (a) and 6 (b) illustrate 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. It is a figure.

도면(a)는 CRT 표시시의 도트보간시에 있어서의 주.주사 및 부.주사의 방향을 나타내고, 도면(b)는 프린트 아우트시의 도트보간시에 있어서의 주.주사 및 부.주사의 방향을 각각 나타내고 있다. 이와같이 CRT 표시출력시의 도트보간 처리와 프린트 아우트시의 도트보간 처리에 있어서는 주.주사방향과 부.주사방향이 서로 뒤바뀐 상태가 된다.(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 and scanning directions and the sub-scanning directions are inverted.

제7도는 각종 설정데이타의 대응관계를 도시한 도면이다. 제8도는 도트보간 처리에 의하여 패턴변환된 문자와 그 문자에 외접(外接)하는 직사각형(정사각형을 포함)과의 관계를 도시한 도면이다.7 is a diagram showing a correspondence relationship between various setting data. FIG. 8 is a diagram showing a relationship between a character pattern-converted by dot interpolation processing and a rectangle (including a square) that circumscribes the character.

제9도는 각종 변형문자에 대한 문자피치(CP) 및 행피치(LP)의 실정예를 도시한 도면이다. 제10도는 각 종류의 변형문자에 대한 하선의 전개예를 도시한 도면이다.FIG. 9 is a diagram showing a practical example of the character pitch CP and the hang pitch LP for various modified characters. FIG. 10 is a diagram showing an example of development of underline for each type of deformed character.

제11도는 구역지정동작을 설명하는 도면이다. 이제부터 본 발명의 일실시예의 동작을 설명한다. 도트보간시에 있어서 CPU(10)는 외부로부터 입력된 도트보간 지정정보에 따라 각종 레지스터의 초기 설정을 실시한다. 즉, CPU(10)는 보간 테이블 ROM(58)에서 생성되는 보간치의 비교를 하기 위한 비교치, 즉 임계치(th)를 레지스터(50)에 세트한 후 지정된 확대.축소 배율에 따라 기준이 되는 도트새김폭(dx,dy : 확대.축소배율의 역수치)을 산출하여 이것을 레지스터(26),(27)에 세트하고, 다시 회전 또는 경사체일때는 그 지정 각도에 따르는 3각 함수데이타(sin,cos,tan)를 3각 함수 테이블(24)에 세트한다.11 is a diagram for explaining the zoning operation. The operation of one embodiment of the present invention will now be described. In dot interpolation, the CPU 10 performs initial setting of various registers in accordance with dot interpolation designation information input from the outside. That is, the CPU 10 sets a comparison value for comparing the interpolation values generated in the interpolation table ROM 58, that is, a threshold value th in the register 50, and then becomes a reference point according to the designated magnification / reduction ratio. Calculate the engraving 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 (sin, cos, tan) is set in the trigonometric function table 24.

그후 이들 레지스터(26),(27) 및 3각 함수 테이블(24)의 설정데이타(sin,cos,tan)에 따라 도트보간 어드레스를 생성하기 위한 초기치(초기치 어드레스 : X1 init, Yl 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, Yl 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. Calculate the engraving widths DX1, DY1, DX2, and DY2, set their data in the registers 31 to 36, and at the same time change the character height and character width caused by pattern conversion such as enlargement rotation. The data of the V size and the H size is calculated and set in the registers 21 and 22, and when the zone is divided, the number of zones is calculated and the data is set in the register 25. Also, when the dot interpolated character is shifted within the range of 1 to 7 dots at 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 image memory side of the image memory that is not a multiple of the write width (8 dots) of the image memory to be outputted. 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 process of generating the dot interpolation address as follows.

우선, 도트보간이 제5도(a)의 도시와 같은 정체(또는 정체,평체)를 출력대상으로 하여 실시되는 경우(예를들면, 단순한 확대·축소)를 예를들어 전체의 동작을 설명한다.First, the whole operation will be described, for example, in the case where dot interpolation is performed with a stagnation (or stagnation, plane) as shown in FIG. 5A as an output target (e.g., simple enlargement / reduction). .

이 도트보간시에 있어서는 레지스터(31)에 『0』 레지스터(32)에 도트새김폭『dx』, 레지스터(33)에 주.주사방향(Sm)의 초기치 『sx』, 레지스터(34)에 도트새김폭『dy』, 레지스터(35)에 『0』, 레지스터(36)에 부.주사방향(Ss)의 초기치『sy』가 각각 세트된다.In this dot interpolation, the register 31 has a dot writing width "dx" in the "32" register 32, the note 33 in the initial scanning direction Sm and the dot in the register 34. 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]로 되는 1y가 초기치(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, dy) set in the registers 32 and 34 are given as inverse values of the magnification / reduction ratio. In the register 33, Ix having [Ix = (dx-1) / 2] is given as an initial value Sx, and the register 36 has 1y having [Iy = (dy-1) / 2]. It is given by the initial value Sy. Here, when dx or dy is equal to or smaller than "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. 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"의 도트로 둘러싸인 상태로 기억된다.Then, 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 interpolated as described above in a state surrounded by dots of "0" meaningless.

상기 레지스터(31∼36)의 데이타 및 1문자버퍼(52)로의 보간대상 문자패턴의 취출이 끝난후, 선택 제어회로(49)의 제어하에 레지스터(33,36)에 저장된 초기 어드레스가 되는 데이타(Sx,Sy)가 데이타 셀렉터(41,45)에 의하여 선택되어 각각 대응하는 레지스터(42,46)에 저장된다. 또, 주.주사를 개시할 때에 있어서는 상기 레지스터(42,46)에 저장된 데이타(Sx,Sy)가 데이타 셀렉터(43,47)에 의하여 선택되어 각각 대응하는 레지스터(44,48)이다.After extraction of the data of 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. At the start of the main / scanning, the data Sx and Sy stored in the registers 42 and 46 are selected by the data selectors 43 and 47 to correspond to the corresponding registers 44 and 48, respectively.

이 레지스터(44,48)에 저장된 데이타(Sx,Sy)는 그 정수부의 치가 비트선택회로(53)에 주어지고, 소수부의 치가 보간 테이블 ROM(58)에 주어진다. 비트선택회로(53)는 상기 입력된 정수부의 치에 따라 1문자버퍼(52)로부터 1격자 4점의 도트정보를 선택하여 보간 테이블 ROM(58)에 공급한다. 이때, 확대시(dx,dy<1)에 있어서는 비트선택회로(53)에, 1문자버퍼(52)의 원문자패턴 격납영역외의 어드레스를 표시하는 부(負)의 치가 주어지므로 원문자패턴 격납영역외의 도트를 포함하는 1격자 4점의 도트정보에서 도트선택을 개시한다.The data Sx and Sy stored in these registers 44 and 48 are given the value of the integer part to the bit select circuit 53, and the value of the fractional part is given to the interpolation table ROM 58. The bit selection circuit 53 selects 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 enlargement (dx, dy <1), since the bit selection circuit 53 is given a negative value indicating an address outside the original character pattern storage area of the one-character buffer 52, the original character pattern is stored. Dot selection is started from dot information of four grids of one grid including dots outside the area.

또 축소시(dx,dy>1)에 있어서는 비트선택회로(53)에, 1문자버퍼(52)의 원문자패턴 격납영역내의 어드레스를 표시하는 정(正)의 치가 주어지므로 원문자패턴 격납영역내의 1격자 4점의 도트정보에서 도트선택을개시한다.In 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)를 출력한다.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.

이때, 비트선택회로(23)에서 출력된 1격자 4점의 도트패턴이 도트패턴 인식부(DSP)에 의하여 인식되어 제4도의 도시와 같이 특정의 도트패턴일때는 다시 그 주위의 격자의 특정도트의 온.오프상태를 인식하여,그 도트상태에 따른 1비트의 보간치 절환선택 신호를 출력한다. 즉, 예를들면 제4도의 도시와 같이 주위 4점의 도트(D0,D1,D2,D3)중 1점만이 오프 즉 "0"(도면에서는 흰동그라미로 표시한 D0)일때는 다시 그 주위의 격자의 특정도트(Da,Db)의 온 오프상태를 인식하고, Da,Db="1"이면 제3도(d)의 도시와 같은 코오너 형태의 테이블(T1)을 선택하고, 또 Da,Db의 적어도 어느 한쪽이 "0"이면 제3도(f)의 도시와 같은 경사형 형태의 테이블(T0)을 선택하도록 보간치 절환선택 신호를 출력한다. 또, 주위 4점의 도트(D0,D1,D2,D3)중 1점만이 온 즉 "1" (도면에서 흰동그라미에 시선을 그은 동그라미로 도시한 D0)일때는 다시 그 주위의 격자의 특정도트(Da,Db)의 온.오프상태를 인식하고, Da,Db="0"이면 제3도(a)의 도시와 같은 코오너 형태의 테이블(T1)을 선택하고, 또 Da,Db의 적어도 어느한쪽이 "1"이면 제3도(e)의 도시와 같은 경사형 형태의 테이블(T0)을 선택하기 위한 보간치 절환 선택신호를 출력한다.At this time, when the dot pattern of one grid four points output from the bit select circuit 23 is recognized by the dot pattern recognition unit DSP and is a specific dot pattern as shown in FIG. Recognizes the on / off state of 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 a white circle in the drawing), Recognize the on-off states of the specific dots Da and Db of the lattice, and if Da, Db = " 1 ", select the co-owner type table T1 as shown in FIG. If at least one of Db is " 0 ", an 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 of four surrounding dots (D0, D1, D2, D3) is on, that is, "1" (D0 shown as a circle drawn in 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 the co-owner type table T1 as shown in FIG. If either side is "1", an interpolation value switching selection signal for selecting the inclined table T0 as shown in Fig. 3E is output.

이와같이 4점의 도트영역내에 위치하는 새로운 도트의 보간치는 그 4점의 도트가 상기와 같은 특정의 패턴을 형성할 때 다시 그 주위의 도트상태에 의하여 정해진다. 그리고, 상기 보간 테이블 ROM(58)에서 출력된 8비트(0-255레벨)의 보간치는 비교기(59)에 입력되어 레지스터(36)에 저장된 비교치 즉 임계치와 비교되는 보간치가 임계치를 초과하고 있으면 의미있는 도트인 것을 나타내는 "1" 레벨의 신호를 출력하고, 또 보간치가 임계치를 초과하고 있지 않으면 의미가 없는 도트인 것을 표시하는 "0" 레벨의 신호를 출력한다.In this way, the interpolation value of the new dot located in the dot area of four points is determined again by the dot state around when the dot of four points forms a specific pattern as described above. When the 8-bit (0-255 level) interpolation value output from the interpolation table ROM 58 is input to the comparator 59 and the interpolation value stored in the register 36, that is, the interpolation value compared with the threshold value, exceeds the threshold value, A signal of level "1" indicating that the dot is meaningful is output, and a signal of level "0" indicating that the dot is meaningless if the interpolation value does not exceed the threshold.

한편, 보간 테이블 MOR(58)에서 1도트의 보간치가 출력된 후에는 레지스터(44)의 내용과 레지스터(32)의 내용이 가산회로(38)에 의하여 가산되는 동시에 레지스터(48)의 내용과 레지스터(35)의 내용이 가산회로(40)에 의하여 가산되고 그 각 가산결과의 데이타가 선택 제어회로(49)의 제어하에 각각 대응되는 데이타 셀렉터(43,47)에 의하여 선택 되어서 레지스터(44,48)에 저장된다. 이때, 주.주사방향의 도트새김폭을 도시하는 레지스터(32,35)중 레지스터(32)에는 지정된 확대.축소배율에 따르는 도트새김폭(dx)이 설정되어 있고, 레지스터(35)에는 정체(또는 장체,평체)의 도트보간이므로 상기와 같이 『0』이 설정됨으로, 레지스터(44)의 내용(도트 어드레스)은 1도트의 보간처리마다 지정된 확대.축소배율에 따른 도트새김폭(dx)을 가지고 차례로 갱신되나, 레지스터(48)의 내용은 결과적으로 갱신되지 않고 초기설정시의 데이타가 그대로 유지된다.On the other hand, after an interpolation value of one dot is output from the interpolation table MOR 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 content of (35) is 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-indentation widths in the main / scanning direction, the dot-indentation 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 content (dot address) of the register 44 is the dot indentation width (dx) according to the enlargement / reduction ratio specified for each dot interpolation process. The contents of the register 48 are not updated as a result, but the data at the initial setting is maintained as it is.

또, 1회의 주.주사가 끝날 때마다, 레지스터(42)의 내용과 레지스터(31)의 내용이 가산회로(37)에 의하여 가산되는 동시에 레지스터(46)의 내용과 레지스터(34)의 내용이 가산회로(39)에 의하여 가산되고, 그 각 가산결과의 데이타가 선텍 제어회로(49)의 제어하에 각각 대응되는 데이타 셀렉터(41,45)에 의하여 선택 되어서 레지스터(42,46)에 각각 저장된다.In addition, each time one scan / injection is completed, the contents of the register 42 and the contents of the register 31 are added by the addition circuit 37, 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 Suntec control circuit 49 and stored in the registers 42 and 46, respectively. .

이때, 부.주사방향의 도트새김폭을 표시하는 레지스터(31,34)중 레지스터(34)에는 지정된 확대.축소배율에 따르는 도트새김폭(dy)이 설정되어 있고, 레지스터(31)에는 정체(또는 장체,평체)의 도트보간이므로 상기와 같이 『0』이 설정되므로, 레지스터(46)의 내용(도트 어드레스)은 1회의 주.주사가 실행될 때마다 지정된 확대.축소배율에 따른 도트새김폭(dy)을 가지고 갱신되나, 레지스터(42)의 내용은 결과적으로 갱신되지않고 초기 설정시의 데이타가 그대로 유지된다.At this time, among the registers 31 and 34 indicating the sub-scan direction in the scanning direction, the dot 34 according to 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 because it is dot interpolation of a long body and a flat body. Therefore, the content (dot address) of the register 46 is the dot indentation width according to the designated magnification / reduced magnification ratio each time one main / injection 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.

이와같이 하여 차례로 보간 테이블 MOR(58)로부터 새로운 도트 어드레스에 대한 보간치가 출력되고 이 보간치가 비교기(59)에 의하여 레지스터(50)의 임계치(th)와 비교되어 새로운 도트정보가 생성된다.In this way, the interpolation value for the new dot address is output from the interpolation table MOR 58 in turn, and the interpolation value is compared by the comparator 59 with the threshold value th of the register 50 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, when the dot interpolation-processed character pattern data sent to the CPU bus 12 is written to the line buffer 18 of the printing control unit 17, for example, for the printout, it is further set to 1 to 1 in the offset register 28. When offset values within the range of 7 degrees are set (for example, when the dot interpolated ruby letter is moved below i (i = 1, 2, ... 7) dots at the time of printout), or is pattern-converted. The number of dots in the main / scanning direction of the character does not need to be a multiple of the write width (8 dots) of the image memory to be the output direction, and must be combined with the byte boundary (write width) on the image memory side. In the case where (i) is set, the offset data generating unit 29 generates offset data (i " 0 ") in accordance with the offset value i of the offset register 28, and this data is mainly used. Prior to the start of injection, the shift register 60 Is set, 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 target is output target, each of the registers 31 to 36 is used. In the trigonometric function table 24 according to the designated rotational angle, data is set in which predetermined trigonometric function data is included as one element.

즉, 지정된 회전각을 [θo], 원래폰트(font)의 x방향 도트수를 [a+1], 원래 폰트(font)의 y방향의 도트수를 [b+1]로 하면,That is, if the designated rotation angle is [θo], 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].

레지스터(31)에는 DX1=dx.sin θoRegister 31 contains DX1 = dx.sin θo

레지스터(32)에는 DX2=dx.cos θoRegister 32 contains DX2 = dx.cos θo

레지스터(34)에는 DY1=dy.cos θoRegister 34 contains DY1 = dy.cos θo

레지스터(35)에는 DY2=dy.sin θoIn register 35, DY2 = dy.sin θo

가 각각 세트된다.Are set respectively.

또, 레지스터(33)(X1 init) 및 레지스터(36)(Y1 init)에는, (1) 0°≤θ≤90°일때In addition, in the register 33 (X1 init) and the register 36 (Y1 init), when (1) 0 ° ≤θ≤90 °

X1 init=1/2a-1/2(a+1-dx)cos 2θoX1 init = 1 / 2a-1 / 2 (a + 1-dx) cos 2θo

Y1 init=-1/2(1-dy)-1/2(a+1-dx) dy/dx sin 2θoY1 init = -1 / 2 (1-dy) -1/2 (a + 1-dx) dy / dx sin 2θo

(2) 90°≤θo≤180°일때(2) When 90 ° ≤θo≤180 °

X1 init=a+1/2(1-dx)-1/2(b+1-dy) dx/dy sin 2θoX1 init = a + 1/2 (1-dx) -1/2 (b + 1-dy) dx / dy sin 2θo

Y1 init=1/2b+1/2(b+1-dy)cos 2θY1 init = 1 / 2b + 1/2 (b + 1-dy) cos 2θ

(3) 180°≤θo≤270°일때(3) When 180 ° ≤θo≤270 °

X1 init=1/2a+1/2(a+1-dx)cos 2θoX1 init = 1 / 2a + 1/2 (a + 1-dx) cos 2θo

Y1 init=b+1/2(1-dy)+1/2(a+1-dx) dy+dx sin 2θY1 init = b + 1/2 (1-dy) +1/2 (a + 1-dx) dy + dx sin 2θ

(4) 270°≤θo≤360°일때(4) When 270 ° ≤θo≤360 °

X1 init=1/2(1-dx)+1/2(b+1-dy) dx/dy sin 2θoX1 init = 1/2 (1-dx) +1/2 (b + 1-dy) dx / dy sin 2θo

Y1 init=1/2b-1/2(b+1-dy)cos 2θY1 init = 1 / 2b-1 / 2 (b + 1-dy) cos 2θ

를 각각 세트한다.Set each of them.

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

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

즉, 지정된 경사각을 『θo』 원래포트(font)의 x방향도트수를 [a+1], 원래폰트(font)의 y방향도트수를 [b+1]로 하면, 0°≤θo≤90°의 범위에서,That is, if the designated inclination angle is [a + 1] and the number of y-direction dots of the original font is [b + 1] as [θo] original port, 0 ° ≤θo≤90 In the range of °,

레지스터(31)에는 DX1=dx.tan θoRegister 31 contains DX1 = dx.tan θo.

레지스터(32)에는 DX12=dxRegister 12 has DX12 = dx

레지스터(34)에는 DY1=dyRegister 34 contains DY1 = dy.

레지스터(35)에는 DY2=0Register 35 has DY2 = 0

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

상기 설명과 같이, 지정각도(θo)에 따르는 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 θo, The dot interpolation address generation processing for the scanning direction and the sub-scanning direction 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도트의 크기에 수용되지 않는다.At this time, since the line buffer 18 is usually composed of a bit width (for example, 8 × 3 = 24 dots vertically) corresponding to the dot configuration of the printed character height, the above-described deformation of the rotating body character and italic character is performed. Characters are not accepted in the size of 24 dots except for the reduction pattern.

따라서, 이와같은 경우에는 상기한 레지스터의 초기설정시에 새로이 생성되는 문자패턴을 복수의 구역으로 구분하도록 CPU(10)가 지정된 변환문자체 및 그 글자의 각도, 확대, 축소배율등을 토대로 변환된 문자에 대한 구역수를 산출하여 그 구역수를 표시하는 데이타를 구역지정용 레지스터(25)에 세트하여 구역단위로 패턴을 기입할때마다 상기한 레지스터(25)의 내용을 감소(-)하고, 그 내용이 『0』가 될때까지는 각 구역의 패턴 데이타를 동일문자 패턴으로서 취급한다.Therefore, in such a case, the character 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, magnification, reduction ratio, etc. of the character are converted. By calculating the number of zones for and setting the data indicating the number of zones in the zone designation register 25, each time the pattern is written in units of zones, the contents of the register 25 are reduced (-). Until the contents become "0", the pattern data of each zone is treated as the same character pattern.

즉 구역지정용 레지스터(25)에 의하여 지정된 구역에 대해서는 그 각 패턴간에 공백에리어(area, 행간격)을 끼어 넣지 않고, 연속하는 도트인자지정을 실행한다. 이때의 구역구분의 한예를 제11도에 도시한다.In other words, for the area designated by the area designation register 25, continuous dot factor designation is executed without interposing an area (line space) 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)에 세트해 놓음으로써 쉽게 인식할 수 있다.The means for calculating the number of zones includes rectangles in the x and y directions (squares) that circumscribe the characters transformed (modified) at a designated rotation angle / tilt angle / enlarge / reduced magnification ratio as shown in FIGS. 7 and 8. ) And the number of dots (x, y dots) of the two sides of the squares in contact with each other, and set them in the registers 21 and 22 as data of V size and H size at the initial register setting. Can be easily recognized.

즉, 어떤 각도를 가지고 변환된 문자에 대해서는 그 문자의 기입(취급)이 그 문자에 외접하는, 수평.수직선상의 직사각형의 에리어(area)를 토대로하여 실행되는 것으로, 예를들면 프린트 아우트일때의 도트보간처리시에 있어서는 레지스터(22)에 저정된 H size의 데이타를 라인버퍼(18)의 비트폭 24으로 나눗셈함으로써 쉽게 상기 구역수를 구할 수 있고, 또 표시출력일때의 도트보간 처리시에 있어서는 레지스터(21)에 저장된 V Size의 데이타를 1표시행의 비트폭 『24』로 나눗셈함으로써 쉽게 구역수를 구할 수 있다.That is, for a character converted at an angle, the writing (handling) of the character is performed based on a horizontal and vertical rectangular area that circumscribes the character, for example, a dot in the case of a print outer. In the interpolation process, the area size can be easily obtained by dividing the H size data stored in the register 22 by the bit width 24 of the line buffer 18, and in the dot interpolation process in display output. The number of zones can be easily obtained by dividing the data of the V size stored in (21) by the bit width &quot; 24 &quot;

또, 상기 구역지정용 레지스터(25)에 임의의 구역지정 데이타를 고정적으로 부여함으로써 지정된 동일구역의 이미지 데이타를 연속적으로 반복하여 이미지 전개할 수 있다. 이에 의하여 상기 도트보간 처리에 의하여 변형된 문자패턴을 다시 그 일부 또는 전부를 용장화(冗長化)된 변형문자 패턴으로서 인자 또는 표시출력할 수도 있다.In addition, 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. Thereby, 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 / line. That is, the characters such as tilt, rotation, etc., obtained by dot interpolation having an arbitrary tilt 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 thereto. It varies depending on the reduction factor. Therefore, when the above-described modified characters are output in the image in the normal line, unidirectional (x, y direction), the character pitch or the underline / radiation cannot be determined by the existing fixed parameter designation means.

그러므로, 문자피치, 하선/방선등의 처리에 대해서도 상기와 같은 외접하는 직사각형을 문자의 보디페이스(body face)로하여 취급한다. 이하에 이들의 처리수단을 설명한다.Therefore, the above-mentioned circumscribed rectangle is 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 performed as described above and a newly generated dot image for one character is to be output, for example, 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 a control data for displaying the character pitch of the data (V size) stored in the register 21, plus the half value thereof. 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 at the time of the update. 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도에 도시한다.In this way, 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 (V for print outers). The pitch between adjacent characters is determined along size, 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), but simply adjusts the pitch based on the value of the register 21 (or register 22) at that time to simplify the processing. 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 the printout, and the data H size stored in the register 22 is referred to in the case of the display output. Here, the processing operation of the underline / radiation will be described taking the case of the print outer as an example. The underline / radiation control unit 23 provided 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 the rotation and italics, the line expansion by the normal character width cannot be taken.

그러므로, 레지스터(21)의 내용(V size)을 항상 입력하여 하선/방선의 지시가 있으면 그때의 레지스터(21)의 갱신 데이타 내용에 따르는 라인 길이를 가지고 하선/방선의 도트패턴을 생성하고, 라인버퍼(18)상에 그 문자에 대응시켜서 패턴을 전개한다.Therefore, if the contents (V size) of the register 21 are always inputted and the direction of underline / radiation is indicated, a dot pattern of underline / radiation is generated with the line length in accordance with the contents of the update data of the register 21 at that time, and the line 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 apparatus for dot interpolating a character pattern having a 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. Means for generating dot interpolation based on the dot interpolation address and the sub-scan interpolation dot interpolation address represented by the y component, and for dividing the generated dot interpolation information with a slice width in a predetermined dot unit A zone designation means and a means for transmitting and controlling image data of the zone designated by the zone designation means, and the enlarged, rotated or inclined deformed characters are divided into zones of a predetermined dot width so that the image is expanded. When the character font is transformed with an arbitrary magnification or angle by dot interpolation, Even if more than the specified character patterns to be deployed haengpok, it is possible to treat the character pattern as one of its own at the same time being able to deploy a continuous dot image of any portion of any number of dots to be deployed.

Claims (1)

소정의 도트 매트릭스 구성의 문자패턴을 적어도 주.주사방향 또는 부.주사방향으로 도트보간하는 도트보간 장치에 있어서, x성분과 y성분으로 표시되는 주.주사방향의 도트보간 어드레스를 생성함과 아울러, x성분과 y성분으로 표시되는 부.주사방향의 도트보간 어드레스를 생성하는 도트보간 어드레스 생성수단(31-49)과, 그 도트보간 어드레스 생성수단에 의하여 생성된 상기한 각 도트보간 어드레스에 따른 좌표점의 도트보간를 생성하는 도트보간 생성수단(58)과, 그 도트보간 생성수단으로 생성된 도트보간 정보를 소정도트단위의 슬라이스폭을 가지고 구역 나누기를 하기 위한 구역지정수단(25)과, 그 구역 지정수단으로 지정된 구역의 이미지 데이타를 전송 제어하는 수단(10)를 구비하고, 확대 또는 회전 또는 경사 형상화된 볜형문자를 소정의 도트폭만위의 구역으로 나누어서 이미지 전개하는 것을 특징으로 하는 도트보간 장치.A dot interpolation apparatus for dot interpolating a character pattern having a predetermined dot matrix configuration in at least the main, scanning or sub-scanning direction, wherein the dot interpolation address in the main and scanning directions represented by the x and y components is generated. dot interpolation address generating means 31-49 for generating a sub-scan interpolation address represented by the x component and the y component, and the dot interpolation addresses generated by the dot interpolation address generating means. Dot interpolation generating means 58 for generating dot interpolation of coordinate points, area designation means 25 for dividing the dot interpolation information generated by the dot interpolation generating means with a slice width of a predetermined dot unit, and Means (10) for transmitting and controlling image data of the zone designated by the zone designation means, and the enlarged, rotated, or inclined shaped 볜 -shaped character is formed in a predetermined degree; Divided into zones above only the width dot interpolation device characterized in that the expansion image.
KR1019850000081A 1984-04-28 1985-01-09 Dot interpolation control system KR900007681B1 (en)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
JP59086373A JPH083709B2 (en) 1984-04-28 1984-04-28 Dot development processor
JP59-86373 1984-04-28

Publications (2)

Publication Number Publication Date
KR850007709A KR850007709A (en) 1985-12-07
KR900007681B1 true KR900007681B1 (en) 1990-10-18

Family

ID=13885073

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1019850000081A KR900007681B1 (en) 1984-04-28 1985-01-09 Dot interpolation control system

Country Status (2)

Country Link
JP (1) JPH083709B2 (en)
KR (1) KR900007681B1 (en)

Also Published As

Publication number Publication date
JPS60231266A (en) 1985-11-16
KR850007709A (en) 1985-12-07
JPH083709B2 (en) 1996-01-17

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
JPH0691604B2 (en) Gradation information scaling method
US4655622A (en) Printer control apparatus
US4712185A (en) Dot interpolation control system
JPS6261277B2 (en)
US6195473B1 (en) Non-integer scaling of raster images with image quality enhancement
US4511893A (en) Method of storing images in the form of contours and photo-typesetting apparatus thereof
JPH0691608B2 (en) Gradation information processing method
KR900007681B1 (en) Dot interpolation control system
KR900004892B1 (en) Dot inter polation system
US5553219A (en) Font outline and bit map generator synthesizing filling data with selected outline data or duplicate outline data
KR900004950B1 (en) Character interpolation control method
US6181835B1 (en) Non-integer scaling of raster images with image quality enhancement using an anamorphically scaled intermediate bitmap
KR900004949B1 (en) Output controller of interpolation dot pattern
KR900004948B1 (en) Under/side line pattern generating device
JPH046554B2 (en)
KR910005780B1 (en) Method for controlling printer for printing characters
KR910005779B1 (en) Printer controlling method for reducing the number of dot
KR910005778B1 (en) Printer controlling method for designating printing direction
KR890005004B1 (en) Dot pattern interpolation system
KR890005005B1 (en) Dot interpolation control system
JPH0392897A (en) Pattern generating device
JP2835056B2 (en) High quality character pattern generation method
JPH0950272A (en) Method and device for outline font generation

Legal Events

Date Code Title Description
A201 Request for examination
E902 Notification of reason for refusal
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: 19971226

Year of fee payment: 9

LAPS Lapse due to unpaid annual fee