KR20220085313A - Method and system to provide handwriting font generation service - Google Patents

Method and system to provide handwriting font generation service Download PDF

Info

Publication number
KR20220085313A
KR20220085313A KR1020200175275A KR20200175275A KR20220085313A KR 20220085313 A KR20220085313 A KR 20220085313A KR 1020200175275 A KR1020200175275 A KR 1020200175275A KR 20200175275 A KR20200175275 A KR 20200175275A KR 20220085313 A KR20220085313 A KR 20220085313A
Authority
KR
South Korea
Prior art keywords
font
processing
handwriting
processor
handwritten
Prior art date
Application number
KR1020200175275A
Other languages
Korean (ko)
Other versions
KR102501631B1 (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 네이버 주식회사
Priority to KR1020200175275A priority Critical patent/KR102501631B1/en
Priority to JP2021197512A priority patent/JP7348446B2/en
Publication of KR20220085313A publication Critical patent/KR20220085313A/en
Application granted granted Critical
Publication of KR102501631B1 publication Critical patent/KR102501631B1/en

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F40/00Handling natural language data
    • G06F40/10Text processing
    • G06F40/103Formatting, i.e. changing of presentation of documents
    • G06F40/109Font handling; Temporal or kinetic typography
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F40/00Handling natural language data
    • G06F40/10Text processing
    • G06F40/12Use of codes for handling textual entities
    • G06F40/126Character encoding
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F40/00Handling natural language data
    • G06F40/10Text processing
    • G06F40/166Editing, e.g. inserting or deleting
    • G06F40/186Templates
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06NCOMPUTING ARRANGEMENTS BASED ON SPECIFIC COMPUTATIONAL MODELS
    • G06N20/00Machine learning

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • Artificial Intelligence (AREA)
  • General Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • Computational Linguistics (AREA)
  • General Health & Medical Sciences (AREA)
  • Audiology, Speech & Language Pathology (AREA)
  • Health & Medical Sciences (AREA)
  • Software Systems (AREA)
  • Evolutionary Computation (AREA)
  • Mathematical Physics (AREA)
  • Data Mining & Analysis (AREA)
  • Medical Informatics (AREA)
  • Computing Systems (AREA)
  • Computer Vision & Pattern Recognition (AREA)
  • Document Processing Apparatus (AREA)
  • Image Analysis (AREA)
  • User Interface Of Digital Computer (AREA)

Abstract

손글씨 폰트 생성 서비스를 제공하는 방법 및 시스템이 개시된다. 손글씨 폰트 생성 방법은, 사용자의 손글씨가 포함된 손글씨 이미지를 학습 가능한 포맷의 이미지 파일로 전처리하는 단계; 상기 이미지 파일을 이용하여 상기 손글씨의 폰트 스타일을 학습하여 손글씨 폰트를 생성하는 단계; 및 상기 손글씨 폰트의 크기 비율을 후처리하는 단계를 포함하는 손글씨 폰트 생성 방법을 제공한다.A method and system for providing a handwritten font generation service are disclosed. The method for generating a handwritten font includes the steps of preprocessing a handwritten image including a user's handwriting into an image file of a learnable format; generating a handwritten font by learning a font style of the handwriting using the image file; and post-processing the size ratio of the handwritten font.

Description

손글씨 폰트 생성 서비스를 제공하는 방법 및 시스템{METHOD AND SYSTEM TO PROVIDE HANDWRITING FONT GENERATION SERVICE}METHOD AND SYSTEM TO PROVIDE HANDWRITING FONT GENERATION SERVICE

아래의 설명은 폰트 생성 서비스를 제공하는 기술에 관한 것이다.The description below relates to a technology that provides a font creation service.

폰트(font)란 미리 디자인된 여러 가지 스타일 및 크기의 글자를 보관해 놓은 일종의 문자 라이브러리(library)로, 활자 조판에 필요한 모든 글자, 숫자 및 특수 기호들을 포함한다.A font is a type of character library in which pre-designed characters of various styles and sizes are stored, and includes all letters, numbers, and special symbols necessary for typesetting.

이러한 폰트가 컴퓨터를 통해 표시되거나 인쇄되도록 하려면 문자의 형태를 0 과 1 의 데이터로 표현해야 한다. 폰트를 0 과 1로 된 디지털 데이터로 표현할 수 있다면 컴퓨터는 이를 보존, 가공 또는 외부의 출력 장치에 출력할 수 있다. 따라서, 폰트는 디지털 형태로 표현된 문자형상 데이터의 집합이라 할 수 있다.In order for these fonts to be displayed or printed through a computer, the shape of the character must be expressed as data of 0's and 1's. If a font can be expressed as digital data of 0's and 1's, a computer can preserve, process, or output it to an external output device. Accordingly, the font can be said to be a set of character data expressed in digital form.

예컨대, 한국 등록특허공보 제10-1777521호(등록일 2017년 09월 05일)에는 다양한 스타일 변경을 배치 작업 없이 글자 단위로 실시간 사용할 수 있는 폰트 생성 기술이 개시되어 있다.For example, Korean Patent Publication No. 10-1777521 (registration date of September 05, 2017) discloses a font generation technology that can use various style changes in real time in units of characters without a batch operation.

사용자가 직접 쓴 손글씨를 기반으로 폰트 파일을 생성할 수 있는 서비스 모델을 제공한다.It provides a service model that can create a font file based on the handwriting written by the user.

폰트 생성 결과를 사용자가 직접 검수할 수 있는 커스텀 튜닝 기능을 제공한다.It provides a custom tuning function that allows users to directly inspect the results of font creation.

컴퓨터 장치에서 실행되는 손글씨 폰트 생성 방법에 있어서, 상기 컴퓨터 장치는 메모리에 포함된 컴퓨터 판독가능한 명령들을 실행하도록 구성된 적어도 하나의 프로세서를 포함하고, 상기 손글씨 폰트 생성 방법은, 상기 적어도 하나의 프로세서에 의해, 사용자의 손글씨가 포함된 손글씨 이미지를 학습 가능한 포맷의 이미지 파일로 전처리하는 단계; 상기 적어도 하나의 프로세서에 의해, 상기 이미지 파일을 이용하여 상기 손글씨의 폰트 스타일을 학습하여 손글씨 폰트를 생성하는 단계; 및 상기 적어도 하나의 프로세서에 의해, 상기 손글씨 폰트의 크기 비율을 후처리하는 단계를 포함하는 손글씨 폰트 생성 방법을 제공한다.A method of generating a handwritten font executed on a computer device, the computer device comprising at least one processor configured to execute computer readable instructions contained in a memory, the method comprising: by the at least one processor , preprocessing the handwritten image including the user's handwriting into an image file of a learnable format; generating, by the at least one processor, a handwriting font by learning a font style of the handwriting using the image file; and post-processing, by the at least one processor, the size ratio of the handwritten font.

일 측면에 따르면, 상기 전처리하는 단계는, 주어진 글자 셋을 포함하는 템플릿을 제공하는 단계; 상기 글자 셋이 손글씨로 작성된 템플릿을 입력 이미지로 수신하는 단계; 및 상기 입력 이미지를 글자 단위로 잘라 각 글자 이미지를 학습 가능한 포맷의 이미지 파일로 가공하는 단계를 포함할 수 있다.According to one aspect, the pre-processing may include: providing a template including a given character set; receiving a template in which the character set is written by hand as an input image; and cutting the input image into character units and processing each character image into an image file in a learnable format.

다른 측면에 따르면, 상기 전처리하는 단계는, 글자 단위로 주어진 글자의 이미지와 상기 주어진 글자에 대한 손글씨 이미지로 이루어진 이미지 쌍을 학습 데이터로 생성하는 단계를 포함할 수 있다.According to another aspect, the pre-processing may include generating an image pair consisting of an image of a given character in units of characters and a handwritten image of the given character as learning data.

또 다른 측면에 따르면, 상기 손글씨 폰트 생성 방법은, 상기 적어도 하나의 프로세서에 의해, 상기 전처리하는 단계에서의 전처리 결과, 상기 생성하는 단계에서의 폰트 생성 결과, 및 상기 후처리하는 단계에서의 후처리 결과 중 적어도 하나를 상기 사용자가 검수하기 위한 사용자 검수용 인터페이스를 제공하는 단계를 더 포함할 수 있다.According to another aspect, in the method for generating a handwritten font, a pre-processing result in the pre-processing step, a font generation result in the generating step, and a post-processing in the post-processing step, by the at least one processor The method may further include providing an interface for user inspection for the user to inspect at least one of the results.

또 다른 측면에 따르면, 상기 손글씨 폰트 생성 방법은, 상기 적어도 하나의 프로세서에 의해, 상기 전처리하는 단계에서의 전처리 결과를 상기 사용자가 검수하기 위한 전처리 검수용 인터페이스를 제공하는 단계를 더 포함하고, 상기 전처리 검수용 인터페이스는 글자 단위로 전처리가 완료된 글자를 확인하기 위한 기능 및 글자 단위로 손글씨를 수정하기 위한 기능이 포함될 수 있다.According to another aspect, the method for generating a handwriting font further comprises, by the at least one processor, providing an interface for preprocessing inspection for the user to inspect a preprocessing result in the preprocessing step, The interface for pre-processing inspection may include a function for confirming pre-processed characters in units of characters and a function for correcting handwriting in units of characters.

또 다른 측면에 따르면, 상기 손글씨 폰트 생성 방법은, 상기 적어도 하나의 프로세서에 의해, 상기 생성하는 단계에서의 폰트 생성 결과를 상기 사용자가 검수하기 위한 폰트 검수용 인터페이스를 제공하는 단계를 더 포함하고, 상기 폰트 검수용 인터페이스는 폰트 생성 결과를 확인하기 위한 기능 및 상기 폰트 생성 결과에서 글자 단위로 다른 모델의 생성 결과로 대체하거나 손글씨를 재입력하기 위한 기능이 포함될 수 있다.According to another aspect, the method for generating a handwritten font further includes, by the at least one processor, providing an interface for font inspection for the user to inspect the font generation result in the generating step, The font inspection interface may include a function for confirming a font generation result and a function for replacing the font generation result with the generation result of another model in character units or for re-entering handwriting.

또 다른 측면에 따르면, 상기 폰트 검수용 인터페이스는 상기 폰트 생성 결과를 확인하기 위한 기능으로서 복수 개의 모델 중 디폴트 모델의 폰트 생성 결과를 제공하는 기능, 상기 복수 개의 모델 중 품질 스코어가 가장 높은 모델의 폰트 생성 결과를 제공하는 기능, 글자 단위로 품질 스코어가 가장 높은 모델 조합의 폰트 생성 결과를 제공하는 기능 중 어느 하나가 포함될 수 있다.According to another aspect, the font inspection interface is a function for confirming the font generation result, a function of providing a font generation result of a default model among a plurality of models, a font of a model having the highest quality score among the plurality of models Any one of a function providing a generation result and a function providing a font generation result of a model combination having the highest quality score in units of characters may be included.

또 다른 측면에 따르면, 상기 손글씨 폰트 생성 방법은, 상기 적어도 하나의 프로세서에 의해, 상기 후처리하는 단계에서의 후처리 결과를 상기 사용자가 검수하기 위한 후처리 검수용 인터페이스를 제공하는 단계를 더 포함하고, 상기 후처리 검수용 인터페이스는 후처리가 완료된 폰트를 확인하기 위한 기능 및 상기 손글씨 폰트의 문장 내 글자 크기 비율을 조정하기 위한 기능이 포함될 수 있다.According to another aspect, the method for generating a handwritten font further includes, by the at least one processor, providing an interface for post-processing inspection for the user to inspect a post-processing result in the post-processing step And, the post-processing inspection interface may include a function for confirming the post-processing completed font and a function for adjusting the character size ratio in the sentence of the handwritten font.

또 다른 측면에 따르면, 상기 후처리 검수용 인터페이스는 사전 설정(preset) 또는 상기 사용자의 커스텀 설정으로 정해진 글자 크기로 상기 손글씨 폰트를 조정하기 위한 기능이 포함될 수 있다.According to another aspect, the post-processing inspection interface may include a function for adjusting the handwritten font to a font size determined by a preset or a custom setting of the user.

또 다른 측면에 따르면, 상기 손글씨 폰트 생성 방법은, 상기 적어도 하나의 프로세서에 의해, 후처리가 완료된 폰트를 패키징하여 웹 컨텐츠 또는 문서에 적용 가능한 폰트 포맷의 파일로 등록하는 단계를 더 포함할 수 있다.According to another aspect, the method for generating a handwritten font may further include packaging, by the at least one processor, the post-processing font and registering it as a file of a font format applicable to web content or documents. .

상기 손글씨 폰트 생성 방법을 상기 컴퓨터 장치에 실행시키기 위해 컴퓨터 판독가능한 기록 매체에 저장되는 컴퓨터 프로그램을 제공한다.There is provided a computer program stored in a computer-readable recording medium for executing the method for generating a handwritten font in the computer device.

컴퓨터 장치에 있어서, 메모리에 포함된 컴퓨터 판독가능한 명령들을 실행하도록 구성된 적어도 하나의 프로세서를 포함하고, 상기 적어도 하나의 프로세서는, 사용자의 손글씨가 포함된 손글씨 이미지를 학습 가능한 포맷의 이미지 파일로 전처리하고, 상기 이미지 파일을 이용하여 상기 손글씨의 폰트 스타일을 학습하여 손글씨 폰트를 생성하고, 상기 손글씨 폰트의 크기 비율을 후처리하는 것을 특징으로 하는 컴퓨터 장치를 제공한다.A computer device comprising: at least one processor configured to execute computer readable instructions contained in a memory, wherein the at least one processor preprocesses a handwritten image including a user's handwriting into an image file in a learnable format; , by using the image file to learn the font style of the handwriting to generate a handwritten font, and to post-process the size ratio of the handwritten font.

본 발명의 실시예들에 따르면, 사용자가 직접 쓴 손글씨를 기반으로 폰트 파일을 생성할 수 있는 서비스 모델을 제공함으로써 웹 컨텐츠나 문서에 적용할 수 있는 폰트 파일을 자신만의 스타일로 자유롭게 디자인할 수 있다.According to embodiments of the present invention, a font file that can be applied to web content or documents can be freely designed in one's own style by providing a service model that can generate a font file based on handwriting written by a user. have.

본 발명의 실시예들에 따르면, 폰트 생성 결과를 사용자가 직접 검수할 수 있는 커스텀 튜닝 기능을 제공함으로써 보다 편리하게 사용자가 원하는 스타일을 반영할 수 있다.According to embodiments of the present invention, a user's desired style can be more conveniently reflected by providing a custom tuning function that allows the user to directly inspect the font generation result.

본 발명의 실시예들에 따르면, 사용자가 직접 평가, 생성, 조율 가능한 서비스 환경을 제공함으로써 손글씨 폰트 생성을 위한 서비스 효율성을 향상시킬 수 있고 폰트 생성 과정에서 필요한 커뮤니케이션을 단축시킬 수 있다.According to embodiments of the present invention, by providing a service environment in which a user can directly evaluate, create, and tune, service efficiency for generating a handwritten font can be improved and communication required in the font creation process can be shortened.

도 1은 본 발명의 일실시예에 따른 네트워크 환경의 예를 도시한 도면이다.
도 2는 본 발명의 일실시예에 따른 컴퓨터 장치의 예를 도시한 블록도이다.
도 3은 본 발명의 일실시예에 따른 컴퓨터 장치가 수행할 수 있는 방법의 예를 도시한 순서도이다.
도 4는 본 발명의 일실시예에 있어서 손글씨 폰트의 커스텀 튜닝을 위한 사용자 검수 과정을 설명하기 위한 순서도이다.
도 5 내지 도 15는 본 발명의 일실시예에 있어서 손글씨 폰트 생성 서비스를 설명하기 위한 사용자 인터페이스 화면의 예시를 도시한 것이다.
1 is a diagram illustrating an example of a network environment according to an embodiment of the present invention.
2 is a block diagram illustrating an example of a computer device according to an embodiment of the present invention.
3 is a flowchart illustrating an example of a method that a computer device may perform according to an embodiment of the present invention.
4 is a flowchart for explaining a user inspection process for custom tuning of a handwriting font according to an embodiment of the present invention.
5 to 15 are diagrams illustrating examples of a user interface screen for explaining a handwriting font generation service according to an embodiment of the present invention.

이하, 본 발명의 실시예를 첨부된 도면을 참조하여 상세하게 설명한다.Hereinafter, embodiments of the present invention will be described in detail with reference to the accompanying drawings.

본 발명의 실시예들은 폰트 생성 서비스를 제공하는 기술에 관한 것이다.Embodiments of the present invention relate to a technology for providing a font generation service.

본 발명의 실시예들에 따른 손글씨 폰트 생성 시스템은 적어도 하나의 컴퓨터 장치에 의해 구현될 수 있으며, 본 발명의 실시예들에 따른 손글씨 폰트 생성 방법은 손글씨 폰트 생성 시스템에 포함되는 적어도 하나의 컴퓨터 장치를 통해 수행될 수 있다. 이때, 컴퓨터 장치에는 본 발명의 일실시예에 따른 컴퓨터 프로그램이 설치 및 구동될 수 있고, 컴퓨터 장치는 구동된 컴퓨터 프로그램의 제어에 따라 본 발명의 실시예들에 따른 손글씨 폰트 생성 방법을 수행할 수 있다. 상술한 컴퓨터 프로그램은 컴퓨터 장치와 결합되어 손글씨 폰트 생성 방법을 컴퓨터에 실행시키기 위해 컴퓨터 판독 가능한 기록매체에 저장될 수 있다.The handwritten font generating system according to the embodiments of the present invention may be implemented by at least one computer device, and the handwritten font generating method according to the embodiments of the present invention includes at least one computer device included in the handwritten font generating system. can be done through In this case, the computer program according to an embodiment of the present invention may be installed and driven in the computer device, and the computer device may perform the handwriting font generation method according to the embodiments of the present invention under the control of the driven computer program. have. The above-described computer program may be stored in a computer-readable recording medium in combination with a computer device to execute the method for generating a handwriting font in a computer.

도 1은 본 발명의 일실시예에 따른 네트워크 환경의 예를 도시한 도면이다. 도 1의 네트워크 환경은 복수의 전자 기기들(110, 120, 130, 140), 복수의 서버들(150, 160) 및 네트워크(170)를 포함하는 예를 나타내고 있다. 이러한 도 1은 발명의 설명을 위한 일례로 전자 기기의 수나 서버의 수가 도 1과 같이 한정되는 것은 아니다. 또한, 도 1의 네트워크 환경은 본 실시예들에 적용 가능한 환경들 중 하나의 예를 설명하는 것일 뿐, 본 실시예들에 적용 가능한 환경이 도 1의 네트워크 환경으로 한정되는 것은 아니다.1 is a diagram illustrating an example of a network environment according to an embodiment of the present invention. The network environment of FIG. 1 shows an example including a plurality of electronic devices 110 , 120 , 130 , 140 , a plurality of servers 150 , 160 , and a network 170 . 1 is an example for explaining the invention, and the number of electronic devices or the number of servers is not limited as in FIG. 1 . In addition, the network environment of FIG. 1 only describes one example of environments applicable to the present embodiments, and the environment applicable to the present embodiments is not limited to the network environment of FIG. 1 .

복수의 전자 기기들(110, 120, 130, 140)은 컴퓨터 장치로 구현되는 고정형 단말이거나 이동형 단말일 수 있다. 복수의 전자 기기들(110, 120, 130, 140)의 예를 들면, 스마트폰(smart phone), 휴대폰, 내비게이션, 컴퓨터, 노트북, 디지털방송용 단말, PDA(Personal Digital Assistants), PMP(Portable Multimedia Player), 태블릿 PC, 게임 콘솔(game console), 웨어러블 디바이스(wearable device), IoT(internet of things) 디바이스, VR(virtual reality) 디바이스, AR(augmented reality) 디바이스 등이 있다. 일례로 도 1에서는 전자 기기(110)의 예로 스마트폰의 형상을 나타내고 있으나, 본 발명의 실시예들에서 전자 기기(110)는 실질적으로 무선 또는 유선 통신 방식을 이용하여 네트워크(170)를 통해 다른 전자 기기들(120, 130, 140) 및/또는 서버(150, 160)와 통신할 수 있는 다양한 물리적인 컴퓨터 장치들 중 하나를 의미할 수 있다.The plurality of electronic devices 110 , 120 , 130 , and 140 may be a fixed terminal implemented as a computer device or a mobile terminal. Examples of the plurality of electronic devices 110 , 120 , 130 , 140 include a smart phone, a mobile phone, a navigation device, a computer, a notebook computer, a digital broadcasting terminal, a personal digital assistant (PDA), and a portable multimedia player (PMP). ), tablet PCs, game consoles, wearable devices, Internet of things (IoT) devices, virtual reality (VR) devices, augmented reality (AR) devices, and the like. As an example, in FIG. 1 , the shape of a smartphone is shown as an example of the electronic device 110 , but in embodiments of the present invention, the electronic device 110 is substantially different through the network 170 using a wireless or wired communication method. It may refer to one of various physical computer devices capable of communicating with the electronic devices 120 , 130 , 140 and/or the servers 150 and 160 .

통신 방식은 제한되지 않으며, 네트워크(170)가 포함할 수 있는 통신망(일례로, 이동통신망, 유선 인터넷, 무선 인터넷, 방송망)을 활용하는 통신 방식뿐만 아니라 기기들간의 근거리 무선 통신 역시 포함될 수 있다. 예를 들어, 네트워크(170)는, PAN(personal area network), LAN(local area network), CAN(campus area network), MAN(metropolitan area network), WAN(wide area network), BBN(broadband network), 인터넷 등의 네트워크 중 하나 이상의 임의의 네트워크를 포함할 수 있다. 또한, 네트워크(170)는 버스 네트워크, 스타 네트워크, 링 네트워크, 메쉬 네트워크, 스타-버스 네트워크, 트리 또는 계층적(hierarchical) 네트워크 등을 포함하는 네트워크 토폴로지 중 임의의 하나 이상을 포함할 수 있으나, 이에 제한되지 않는다.The communication method is not limited, and not only a communication method using a communication network (eg, a mobile communication network, a wired Internet, a wireless Internet, a broadcasting network) that the network 170 may include, but also short-range wireless communication between devices may be included. For example, the network 170 may include a personal area network (PAN), a local area network (LAN), a campus area network (CAN), a metropolitan area network (MAN), a wide area network (WAN), and a broadband network (BBN). , the Internet, and the like. In addition, the network 170 may include any one or more of a network topology including a bus network, a star network, a ring network, a mesh network, a star-bus network, a tree or a hierarchical network, etc. not limited

서버(150, 160) 각각은 복수의 전자 기기들(110, 120, 130, 140)과 네트워크(170)를 통해 통신하여 명령, 코드, 파일, 컨텐츠, 서비스 등을 제공하는 컴퓨터 장치 또는 복수의 컴퓨터 장치들로 구현될 수 있다. 예를 들어, 서버(150)는 네트워크(170)를 통해 접속한 복수의 전자 기기들(110, 120, 130, 140)로 서비스(일례로, 손글씨 폰트 생성 서비스, 웹툰 서비스, 동영상 공유 서비스, 소셜 네트워크 서비스 등)를 제공하는 시스템일 수 있다.Each of the servers 150 and 160 communicates with the plurality of electronic devices 110 , 120 , 130 , 140 and the network 170 through a computer device or a plurality of computers that provides commands, codes, files, contents, services, etc. It can be implemented in devices. For example, the server 150 serves as a service (eg, a handwriting font generation service, a webtoon service, a video sharing service, a social network service, etc.).

도 2는 본 발명의 일실시예에 따른 컴퓨터 장치의 예를 도시한 블록도이다. 앞서 설명한 복수의 전자 기기들(110, 120, 130, 140) 각각이나 서버들(150, 160) 각각은 도 2를 통해 도시된 컴퓨터 장치(200)에 의해 구현될 수 있다.2 is a block diagram illustrating an example of a computer device according to an embodiment of the present invention. Each of the plurality of electronic devices 110 , 120 , 130 , 140 or the servers 150 and 160 described above may be implemented by the computer device 200 illustrated in FIG. 2 .

이러한 컴퓨터 장치(200)는 도 2에 도시된 바와 같이, 메모리(210), 프로세서(220), 통신 인터페이스(230) 그리고 입출력 인터페이스(240)를 포함할 수 있다. 메모리(210)는 컴퓨터에서 판독 가능한 기록매체로서, RAM(random access memory), ROM(read only memory) 및 디스크 드라이브와 같은 비소멸성 대용량 기록장치(permanent mass storage device)를 포함할 수 있다. 여기서 ROM과 디스크 드라이브와 같은 비소멸성 대용량 기록장치는 메모리(210)와는 구분되는 별도의 영구 저장 장치로서 컴퓨터 장치(200)에 포함될 수도 있다. 또한, 메모리(210)에는 운영체제와 적어도 하나의 프로그램 코드가 저장될 수 있다. 이러한 소프트웨어 구성요소들은 메모리(210)와는 별도의 컴퓨터에서 판독 가능한 기록매체로부터 메모리(210)로 로딩될 수 있다. 이러한 별도의 컴퓨터에서 판독 가능한 기록매체는 플로피 드라이브, 디스크, 테이프, DVD/CD-ROM 드라이브, 메모리 카드 등의 컴퓨터에서 판독 가능한 기록매체를 포함할 수 있다. 다른 실시예에서 소프트웨어 구성요소들은 컴퓨터에서 판독 가능한 기록매체가 아닌 통신 인터페이스(230)를 통해 메모리(210)에 로딩될 수도 있다. 예를 들어, 소프트웨어 구성요소들은 네트워크(170)를 통해 수신되는 파일들에 의해 설치되는 컴퓨터 프로그램에 기반하여 컴퓨터 장치(200)의 메모리(210)에 로딩될 수 있다.As shown in FIG. 2 , the computer device 200 may include a memory 210 , a processor 220 , a communication interface 230 , and an input/output interface 240 . The memory 210 is a computer-readable recording medium and may include a random access memory (RAM), a read only memory (ROM), and a permanent mass storage device such as a disk drive. Here, a non-volatile mass storage device such as a ROM and a disk drive may be included in the computer device 200 as a separate permanent storage device distinct from the memory 210 . Also, an operating system and at least one program code may be stored in the memory 210 . These software components may be loaded into the memory 210 from a computer-readable recording medium separate from the memory 210 . The separate computer-readable recording medium may include a computer-readable recording medium such as a floppy drive, a disk, a tape, a DVD/CD-ROM drive, and a memory card. In another embodiment, the software components may be loaded into the memory 210 through the communication interface 230 instead of a computer-readable recording medium. For example, the software components may be loaded into the memory 210 of the computer device 200 based on a computer program installed by files received through the network 170 .

프로세서(220)는 기본적인 산술, 로직 및 입출력 연산을 수행함으로써, 컴퓨터 프로그램의 명령을 처리하도록 구성될 수 있다. 명령은 메모리(210) 또는 통신 인터페이스(230)에 의해 프로세서(220)로 제공될 수 있다. 예를 들어 프로세서(220)는 메모리(210)와 같은 기록 장치에 저장된 프로그램 코드에 따라 수신되는 명령을 실행하도록 구성될 수 있다.The processor 220 may be configured to process instructions of a computer program by performing basic arithmetic, logic, and input/output operations. The instructions may be provided to the processor 220 by the memory 210 or the communication interface 230 . For example, the processor 220 may be configured to execute a received instruction according to a program code stored in a recording device such as the memory 210 .

통신 인터페이스(230)는 네트워크(170)를 통해 컴퓨터 장치(200)가 다른 장치(일례로, 앞서 설명한 저장 장치들)와 서로 통신하기 위한 기능을 제공할 수 있다. 일례로, 컴퓨터 장치(200)의 프로세서(220)가 메모리(210)와 같은 기록 장치에 저장된 프로그램 코드에 따라 생성한 요청이나 명령, 데이터, 파일 등이 통신 인터페이스(230)의 제어에 따라 네트워크(170)를 통해 다른 장치들로 전달될 수 있다. 역으로, 다른 장치로부터의 신호나 명령, 데이터, 파일 등이 네트워크(170)를 거쳐 컴퓨터 장치(200)의 통신 인터페이스(230)를 통해 컴퓨터 장치(200)로 수신될 수 있다. 통신 인터페이스(230)를 통해 수신된 신호나 명령, 데이터 등은 프로세서(220)나 메모리(210)로 전달될 수 있고, 파일 등은 컴퓨터 장치(200)가 더 포함할 수 있는 저장 매체(상술한 영구 저장 장치)로 저장될 수 있다.The communication interface 230 may provide a function for the computer device 200 to communicate with other devices (eg, the storage devices described above) through the network 170 . For example, a request, command, data, file, etc. generated by the processor 220 of the computer device 200 according to a program code stored in a recording device such as the memory 210 is transmitted to the network ( 170) to other devices. Conversely, signals, commands, data, files, etc. from other devices may be received by the computer device 200 through the communication interface 230 of the computer device 200 via the network 170 . A signal, command, or data received through the communication interface 230 may be transferred to the processor 220 or the memory 210 , and the file may be a storage medium (described above) that the computer device 200 may further include. persistent storage).

입출력 인터페이스(240)는 입출력 장치(250)와의 인터페이스를 위한 수단일 수 있다. 예를 들어, 입력 장치는 마이크, 키보드 또는 마우스 등의 장치를, 그리고 출력 장치는 디스플레이, 스피커와 같은 장치를 포함할 수 있다. 다른 예로 입출력 인터페이스(240)는 터치스크린과 같이 입력과 출력을 위한 기능이 하나로 통합된 장치와의 인터페이스를 위한 수단일 수도 있다. 입출력 장치(250)는 컴퓨터 장치(200)와 하나의 장치로 구성될 수도 있다.The input/output interface 240 may be a means for an interface with the input/output device 250 . For example, the input device may include a device such as a microphone, keyboard, or mouse, and the output device may include a device such as a display or a speaker. As another example, the input/output interface 240 may be a means for an interface with a device in which functions for input and output are integrated into one, such as a touch screen. The input/output device 250 may be configured as one device with the computer device 200 .

또한, 다른 실시예들에서 컴퓨터 장치(200)는 도 2의 구성요소들보다 더 적은 혹은 더 많은 구성요소들을 포함할 수도 있다. 그러나, 대부분의 종래기술적 구성요소들을 명확하게 도시할 필요성은 없다. 예를 들어, 컴퓨터 장치(200)는 상술한 입출력 장치(250) 중 적어도 일부를 포함하도록 구현되거나 또는 트랜시버(transceiver), 데이터베이스 등과 같은 다른 구성요소들을 더 포함할 수도 있다.Also, in other embodiments, the computer device 200 may include fewer or more components than those of FIG. 2 . However, there is no need to clearly show most of the prior art components. For example, the computer device 200 may be implemented to include at least a portion of the above-described input/output device 250 or may further include other components such as a transceiver and a database.

이하에서는 손글씨 폰트 생성 서비스를 제공하는 방법 및 시스템의 구체적인 실시예를 설명하기로 한다.Hereinafter, a specific embodiment of a method and system for providing a handwriting font generation service will be described.

도 3은 본 발명의 일실시예에 따른 컴퓨터 장치가 수행할 수 있는 방법의 예를 도시한 흐름도이다.3 is a flowchart illustrating an example of a method that a computer device may perform according to an embodiment of the present invention.

본 실시예에 따른 컴퓨터 장치(200)는 클라이언트를 대상으로 클라이언트 상에 설치된 전용 어플리케이션이나 컴퓨터 장치(200)와 관련된 웹/모바일 사이트 접속을 통해 손글씨 폰트 생성 서비스를 제공할 수 있다. 컴퓨터 장치(200)에는 컴퓨터로 구현된 손글씨 폰트 생성 시스템이 구성될 수 있다. 일례로, 손글씨 폰트 생성 시스템은 독립적으로 동작하는 프로그램 형태로 구현되거나, 혹은 특정 어플리케이션의 인-앱(in-app) 형태로 구성되어 상기 특정 어플리케이션 상에서 동작이 가능하도록 구현될 수 있다.The computer device 200 according to the present embodiment may provide a handwriting font generation service to the client through a dedicated application installed on the client or a web/mobile site connection related to the computer device 200 . A computer-implemented handwriting font generation system may be configured in the computer device 200 . For example, the handwriting font generation system may be implemented in the form of a program that operates independently, or may be implemented in the form of an in-app of a specific application to be able to operate on the specific application.

컴퓨터 장치(200)의 프로세서(220)는 도 3에 따른 손글씨 폰트 생성 방법을 수행하기 위한 구성요소로서 적어도 하나 이상의 구성요소를 포함할 수 있다. 실시예에 따라 프로세서(220)의 구성요소들은 선택적으로 프로세서(220)에 포함되거나 제외될 수도 있다. 또한, 실시예에 따라 프로세서(220)의 구성요소들은 프로세서(220)의 기능의 표현을 위해 분리 또는 병합될 수도 있다.The processor 220 of the computer device 200 may include at least one component as a component for performing the method for generating a handwriting font according to FIG. 3 . Depending on the embodiment, components of the processor 220 may be selectively included or excluded from the processor 220 . Also, according to an embodiment, the components of the processor 220 may be separated or merged to express a function of the processor 220 .

이러한 프로세서(220) 및 프로세서(220)의 구성요소들은 도 3의 손글씨 폰트 생성 방법이 포함하는 단계들(S310 내지 S330)을 수행하도록 컴퓨터 장치(200)를 제어할 수 있다. 예를 들어, 프로세서(220) 및 프로세서(220)의 구성요소들은 메모리(210)가 포함하는 운영체제의 코드와 적어도 하나의 프로그램의 코드에 따른 명령(instruction)을 실행하도록 구현될 수 있다.The processor 220 and components of the processor 220 may control the computer device 200 to perform steps S310 to S330 included in the method for generating a handwriting font of FIG. 3 . For example, the processor 220 and components of the processor 220 may be implemented to execute instructions according to the code of the operating system included in the memory 210 and the code of at least one program.

여기서, 프로세서(220)의 구성요소들은 컴퓨터 장치(200)에 저장된 프로그램 코드가 제공하는 명령에 따라 프로세서(220)에 의해 수행되는 서로 다른 기능들(different functions)의 표현들일 수 있다.Here, the components of the processor 220 may be expressions of different functions performed by the processor 220 according to instructions provided by the program code stored in the computer device 200 .

프로세서(220)는 컴퓨터 장치(200)의 제어와 관련된 명령이 로딩된 메모리(210)로부터 필요한 명령을 읽어들일 수 있다. 이 경우, 상기 읽어들인 명령은 프로세서(220)가 이후 설명될 단계들(S310 내지 S330)을 실행하도록 제어하기 위한 명령을 포함할 수 있다.The processor 220 may read a necessary command from the memory 210 in which the command related to the control of the computer device 200 is loaded. In this case, the read command may include a command for controlling the processor 220 to execute steps S310 to S330 to be described later.

이후 설명될 단계들(S310 내지 S330)은 도 3에 도시된 순서와 다른 순서로 수행될 수 있으며, 단계들(S310 내지 S330) 중 일부가 생략되거나 추가의 과정이 더 포함될 수 있다.Steps S310 to S330 to be described later may be performed in an order different from that shown in FIG. 3 , and some of steps S310 to S330 may be omitted or additional processes may be further included.

프로세서(220)는 폰트 생성 권한을 가진 사용자를 대상으로 사용자가 직접 쓴 손글씨를 기반으로 폰트 파일을 생성할 수 있는 서비스 모델을 제공한다. 특히, 프로세서(220)는 손글씨 폰트를 생성하기 위한 각 단계 별 중간 결과를 사용자가 보면서 직접 검수할 수 있는 커스텀 튜닝 기능을 제공한다.The processor 220 provides a service model capable of generating a font file based on a handwriting directly written by the user for a user having the authority to generate the font. In particular, the processor 220 provides a custom tuning function that allows the user to directly inspect the intermediate result for each step for generating the handwritten font.

도 3을 참조하면, 단계(S310)에서 프로세서(220)는 손글씨 이미지를 학습 가능한 형태의 이미지로 전처리할 수 있다. 프로세서(220)는 사용자에 의해 작성된 손글씨 이미지를 사용자 입력으로 수신하여 수신된 손글씨 이미지를 모델이 학습 가능한 이미지 포맷(예를 들어, pdf, png, jpeg, heif 등)의 파일로 가공할 수 있다. 일례로, 프로세서(220)는 주어진 목적 글자 셋에 대해 해당 목적 글자들을 사용자가 손글씨로 작성할 수 있는 템플릿을 제공하고 목적 글자 별로 손글씨가 작성된 템플릿을 입력 이미지로 수신할 수 있다. 그리고, 프로세서(220)는 입력 이미지로 수신된 템플릿 이미지의 aruco 코드를 인식해서 글자(character) 단위로 자른 후 각각의 글자 이미지를 학습 가능한 포맷의 이미지 파일로 가공함으로써 글자 하나 당 하나의 목적 글자 이미지와 하나의 손글씨 글자 이미지로 이루어진 학습 쌍을 만들 수 있다.Referring to FIG. 3 , in step S310 , the processor 220 may pre-process the handwritten image into a learnable image. The processor 220 may receive the handwritten image created by the user as a user input, and process the received handwritten image into a file of an image format (eg, pdf, png, jpeg, heif, etc.) in which the model can learn. For example, for a given target character set, the processor 220 may provide a template in which the user can write the corresponding target characters by handwriting, and receive the template in which the target characters are written by hand as an input image. Then, the processor 220 recognizes the aruco code of the template image received as an input image, cuts it in character units, and processes each character image into an image file of a learnable format, so that each character has one target character image. and one handwritten letter image.

프로세서(220)는 손글씨 이미지에 대한 전처리 결과를 검수하기 위한 전처리 검수용 인터페이스를 제공할 수 있다. 사용자는 전처리 검수용 인터페이스를 통해 전처리가 완료된 글자를 확인할 수 있으며, 이때 전처리 검수용 인터페이스는 글자 단위로 손글씨를 수정할 수 있는 기능을 포함한다. 다시 말해, 프로세서(220)는 손글씨 이미지를 전처리한 후 폰트화하기 이전에 이미지 상태에서 사용자 검수를 진행할 수 있다. 프로세서(220)는 잘못 전처리된 글자나 전처리가 누락된 글자 등 오류 글자를 사용자가 직접 선택함에 따라 템플릿을 추가로 생성할 수 있고 추가 템플릿을 통해 오류 글자만을 다시 전처리하여 해당 글자의 학습 쌍을 업데이트할 수 있다.The processor 220 may provide an interface for preprocessing inspection for inspecting the preprocessing result for the handwritten image. The user can check the pre-processed characters through the pre-processing inspection interface, and the pre-processing inspection interface includes a function to correct handwriting in character units. In other words, after preprocessing the handwritten image, the processor 220 may perform user inspection in the image state before fontization. The processor 220 may additionally generate a template as the user directly selects erroneous characters, such as erroneously pre-processed characters or missing pre-processing characters, and re-pre-processes only erroneous characters through the additional template to update the learning pair of the corresponding characters. can do.

단계(S320)에서 프로세서(220)는 단계(S310)에서 전처리된 이미지를 이용하여 사용자 손글씨의 폰트 스타일을 학습함으로써 폰트화에 따른 손글씨 폰트를 생성할 수 있다. 프로세서(220)는 손글씨 생성 모델을 통해 글자 별 목적 글자 이미지와 손글씨 글자 이미지로 이루어진 학습 쌍을 이용하여 손글씨 스타일을 학습할 수 있다. 프로세서(220)는 목적 글자 이미지와 손글씨 글자 이미지를 이용하여 틀린 글자 없이 안정적으로 손글씨 스타일을 글자에 반영하도록 학습할 수 있다. 일례로, 프로세서(220)는 생성자(Generator)와 구분자(Discriminator)로 구성된 GAN(Generative Adversarial Network) 모델을 이용하여 손글씨 스타일을 학습할 수 있다. 프로세서(220)는 GAN 모델 중 하나로 입력 이미지와 출력 이미지의 매핑에 필요한 손실 함수를 학습하는 pix2pix 모델을 활용할 수 있다. 프로세서(220)는 목적 글자 셋에 대한 손글씨 스타일을 학습하여 해당 스타일의 문자 라이브러리(활자 조판에 필요한 모든 글자, 숫자, 특수 기호를 포함함)를 생성할 수 있다. 이때, 프로세서(220)는 하나의 손글씨 이미지에 대해 복수 개의 모델을 이용하여 여러 개의 손글씨 폰트 후보를 생성할 수 있다.In step S320 , the processor 220 may generate a handwritten font according to fontization by learning the font style of the user's handwriting using the image preprocessed in step S310 . The processor 220 may learn a handwriting style by using a learning pair consisting of a target letter image for each letter and a handwritten letter image through the handwriting generation model. The processor 220 may learn to stably reflect the handwriting style to the letters without erroneous letters by using the target letter image and the handwritten letter image. For example, the processor 220 may learn a handwriting style using a Generative Adversarial Network (GAN) model including a generator and a discriminator. The processor 220 may utilize a pix2pix model that learns a loss function required for mapping an input image and an output image as one of the GAN models. The processor 220 may learn a handwriting style for the target character set and generate a character library (including all letters, numbers, and special symbols required for typesetting) of the corresponding style. In this case, the processor 220 may generate several handwritten font candidates by using a plurality of models for one handwritten image.

프로세서(220)는 손글씨 폰트화에 따른 폰트 생성 결과를 검수하기 위한 폰트 검수용 인터페이스를 제공할 수 있다. 사용자는 폰트 검수용 인터페이스를 통해 폰트 생성 결과인 손글씨 폰트 후보를 확인할 수 있으며, 이때 폰트 검수용 인터페이스는 복수 개의 모델을 통해 만들어진 손글씨 폰트 후보들을 보여주고 최종 모델을 선택할 수 있는 기능을 포함한다. 프로세서(220)는 여러 모델과 여러 단계의 폰트 생성 결과를 병렬로 보여주고 사용자 선택이 가능한 인터페이스를 제공할 수 있다. 폰트 검수 단계에서는 문장 안에서의 밸런스나 글자의 높낮이 등은 고려하지 않고 글자 레벨의 검수를 진행한다. 디폴트 글자 셋에 대한 폰트 생성 결과를 검수하는 것은 물론이고, 서비스 시나리오에 따라 주요한 글자들을 따로 목록화하여 검수하는 것 또한 가능하다. 프로세서(220)는 폰트 검수용 인터페이스를 통해 폰트 생성 결과의 품질 스코어 순으로 손글씨 생성 모델을 보여줄 수 있고, 글자 단위로 품질 스코어가 가장 높은 모델의 글자가 자동 선택된 상태의 기본 설정을 보여줄 수 있다. 프로세서(220)는 폰트 검수용 인터페이스를 통해 사용자에게 최적의 모델을 제안할 수 있고, 글자 단위로 다른 모델의 생성 결과를 선택할 수 있는 검수 환경을 제공한다. 폰트 검수용 인터페이스는 특정 글자에 대해 손글씨 폰트 후보 중에서 제대로 생성된 것이 없는 경우 사용자가 해당 글자의 손글씨를 다시 작성할 수 있는 기능을 포함한다. 폰트 검수 단계에서 다시 작성된 글자의 손글씨는 학습을 다시 진행하지 않고 즉시 대체되는 방식으로 사용자 검수를 통한 최종 폰트에 포함될 수 있다. 프로세서(220)는 폰트 생성 결과 중 품질 스코어를 기준으로 일부를 샘플링하여 손글씨 생성 모델의 학습 샘플로 활용하는 것 또한 가능하다.The processor 220 may provide an interface for font inspection for inspecting a font generation result according to handwriting fontization. The user can check the handwritten font candidates as a result of font generation through the font review interface, and the font check interface includes a function to show handwritten font candidates created through a plurality of models and select the final model. The processor 220 may display multiple models and results of font generation in multiple steps in parallel and provide an interface that enables user selection. In the font inspection stage, the character level inspection is carried out without considering the balance in the sentence or the height of the characters. It is not only possible to inspect the font generation result for the default character set, but also to list and inspect the main characters separately according to the service scenario. The processor 220 may show the handwriting generation model in the order of the quality score of the font generation result through the interface for font inspection, and may show the default setting in which the character of the model having the highest quality score is automatically selected for each character. The processor 220 can suggest an optimal model to the user through the interface for font inspection, and provides an inspection environment in which the generation result of another model can be selected in units of characters. The interface for font inspection includes a function for the user to rewrite the handwriting of a given character when none of the handwritten font candidates for a specific character have been properly generated. The handwriting of the characters rewritten in the font inspection stage can be included in the final font through user inspection in a way that is replaced immediately without re-learning. The processor 220 may also sample a part of the font generation result based on the quality score and use it as a learning sample of the handwriting generation model.

단계(S330)에서 프로세서(220)는 사용자 검수를 통해 최종 선택된 폰트 생성 결과를 후처리할 수 있다. 다시 말해, 프로세서(220)는 손글씨 폰트의 크기 비율, 즉 문장 내 비율 밸런싱을 후처리할 수 있다. 프로세서(220)는 문장 내 비율 밸런싱을 위해 기준선 정렬, 글자 확대 상한, 글자 확대 하한, 특정 글자 축소 등을 이용하여 글자 별로 크기 비율을 조정할 수 있다.In step S330, the processor 220 may post-process the result of generating the font finally selected through the user inspection. In other words, the processor 220 may post-process the size ratio of the handwritten font, that is, the ratio balancing within the sentence. The processor 220 may adjust the size ratio for each character by using a baseline alignment, a character enlargement upper limit, a character enlargement lower limit, a specific character reduction, etc. for balancing the ratio within a sentence.

프로세서(220)는 폰트 생성 결과에 대한 후처리 결과를 검수하기 위한 후처리 검수용 인터페이스를 제공할 수 있다. 사용자는 후처리 검수용 인터페이스를 통해 후처리가 완료된 글자를 확인할 수 있으며, 이때 후처리 검수용 인터페이스는 지정된 특정 글자를 줄이는 기능(reduce specific text function), 하단 정렬, 중앙 정렬 등 기본 정렬을 조정하는 기능(baseline align function), 사전 설정(preset)이나 사용자의 커스텀 설정으로 정해진 글자 크기로 조정된 후처리 결과를 보여주는 기능을 포함한다. 즉, 프로세서(220)는 폰트 생성 결과에 대한 후처리 결과로서 문장-폰트 레벨의 사용자 검수를 진행할 수 있다.The processor 220 may provide an interface for post-processing inspection for inspecting the post-processing result for the font generation result. The user can check the text that has been post-processed through the post-processing inspection interface. At this time, the post-processing inspection interface adjusts basic alignment such as reduce specific text function, bottom alignment, and center alignment. It includes a function (baseline align function), a function that shows the post-processing result adjusted to a font size determined by a preset or a user's custom setting. That is, the processor 220 may proceed with the user inspection of the sentence-font level as a post-processing result for the font generation result.

프로세서(220)는 후처리가 완료된 폰트를 패키징하여 웹 컨텐츠나 문서 등에 실제 적용 가능한 폰트 파일로 등록할 수 있다. 프로세서(220)는 후처리 결과물을 TTF(true type font), OTF(open type font) 등의 폰트 포맷으로 제공할 수 있다. 프로세서(220)는 손글씨 폰트에 대해 적어도 하나 이상의 폰트 포맷으로 제공할 수 있으며, 폰트 포맷 또한 사용자가 직접 선택할 수 있는 인터페이스를 제공할 수 있다.The processor 220 may package the post-processing font and register it as a font file that is actually applicable to web content or documents. The processor 220 may provide the post-processing result in a font format such as a true type font (TTF) or an open type font (OTF). The processor 220 may provide at least one font format for the handwritten font, and may also provide an interface through which the user can directly select the font format.

프로세서(220)는 폰트 레벨에서의 수정이 가능한 폰트 수정 인터페이스를 제공할 수 있다. 예를 들어, TTF 안에 있는 SVG(벡터 파일)를 웹 상에서 로드하여 수정하고 이를 다시 TTF에 업데이트할 수 있다.The processor 220 may provide a font modification interface capable of modification at the font level. For example, you can load an SVG (vector file) in a TTF from the web, modify it, and update it back to the TTF.

요컨대, 도 4를 참조하면, 프로세서(220)는 사용자 손글씨를 이미지 파일로 수신하여 학습 데이터를 만드는 이미지 전처리 과정(S310), 전처리된 이미지 파일로 손글씨 스타일을 학습하여 손글씨 폰트를 생성하는 폰트 생성 과정(S320), 손글씨 폰트를 후처리하는 폰트 후처리 과정(S330)을 진행한다. 특히, 프로세서(220)는 손글씨 폰트에 대한 커스텀 튜닝 기능으로서 각 과정마다 중간 결과를 사용자가 직접 검수할 수 있는 인터페이스를 제공한다. 다시 말해, 프로세서(220)는 이미지 전처리 과정(S310)에서 전처리 결과를 검수하기 위한 전처리 검수용 인터페이스를, 폰트 생성 과정(S320)에서 폰트 생성 결과를 검수하기 위한 폰트 검수용 인터페이스를, 폰트 후처리 과정(S330)에서 후처리 결과를 검수하기 위한 후처리 검수용 인터페이스를 제공할 수 있다. 실시예에 따라서는 검수 대상에 따라 전처리 검수용 인터페이스와 폰트 검수용 인터페이스 및 후처리 검수용 인터페이스 중 일부, 예를 들어 후처리 검수에 한하여 사용자를 대신하여 서비스 관리자가 관여하는 형태로 제공될 수도 있다.In other words, referring to FIG. 4 , the processor 220 receives the user's handwriting as an image file and creates an image pre-processing process ( S310 ) for creating learning data, and a font generation process for generating a handwritten font by learning a handwriting style from the pre-processed image file (S320), a font post-processing process (S330) of post-processing the handwritten font is performed. In particular, the processor 220 provides an interface through which the user can directly inspect the intermediate result for each process as a custom tuning function for the handwritten font. In other words, the processor 220 provides an interface for pre-processing inspection for inspecting the pre-processing result in the image pre-processing process (S310), a font inspection interface for inspecting the font generation result in the font generation process (S320), and a font post-processing An interface for post-processing inspection for inspecting the post-processing result may be provided in step S330. According to the embodiment, depending on the inspection target, some of the interface for pre-processing inspection, the interface for font inspection, and the interface for post-processing inspection, for example, may be provided in a form in which the service manager is involved on behalf of the user only for the post-processing inspection. .

도 5 내지 도 15는 본 발명의 일실시예에 있어서 손글씨 폰트 생성 서비스를 설명하기 위한 사용자 인터페이스 화면의 예시를 도시한 것이다.5 to 15 are diagrams illustrating examples of a user interface screen for explaining a handwriting font generation service according to an embodiment of the present invention.

도 5는 손글씨 폰트 생성 서비스의 대시보드 화면(510) 예시를 나타내고 있다.5 shows an example of the dashboard screen 510 of the handwriting font generation service.

대시보드 화면(510)에는 손글씨 폰트를 생성하기 위한 생성 버튼(501)이 포함된다. 손글씨 폰트는 사용자 권한에 따라 1개만 생성 가능하거나 혹은 여러 개 생성 가능하다. 생성 버튼(501)을 이용하여 손글씨 폰트 생성을 요청하는 과정에서 사용자의 손글씨 폰트를 다른 사람도 이용 가능하게 허용할지 등에 대한 선택 팝업이 노출될 수 있다.The dashboard screen 510 includes a creation button 501 for generating a handwritten font. Only one handwriting font can be created or multiple handwritten fonts can be created depending on the user's authority. In the process of requesting generation of a handwritten font using the create button 501 , a selection pop-up for whether to allow the user's handwritten font to be used by others, etc. may be exposed.

대시보드 화면(510)에는 사용자에 의해 생성된 손글씨 폰트 목록(502)이 포함될 수 있다. 손글씨 폰트 목록(502)에는 생성이 진행 중인 폰트 목록, 생성이 완료된 폰트 목록 등이 포함될 수 있고, 최근 업데이트된 순서대로 노출될 수 있다. 손글씨 폰트 목록(502)에 포함된 각각의 손글씨 폰트를 나타내는 폰트 카드에는 폰트 이름, 최근 업데이트 날짜, 현재 상태(예를 들어, 생성 완료, 전처리 중, 생성 중, 후처리 중), 생성 완료된 폰트의 경우 폰트 파일 다운로드 버튼 등이 포함될 수 있다.The dashboard screen 510 may include a list of handwritten fonts 502 generated by the user. The handwritten font list 502 may include a list of fonts that are being generated, a list of fonts that have been created, and the like, and may be exposed in the order of being recently updated. The font card indicating each handwritten font included in the handwritten font list 502 includes a font name, a recent update date, a current state (eg, creation completed, pre-processing, generating, post-processing), the generated font. In this case, a font file download button may be included.

프로세서(220)는 사용자가 대시보드 화면(510)에서 생성 버튼(501)을 입력하는 경우 도 6에 도시한 바와 같이 손글씨 이미지 입력 화면(620)을 제공한다.When the user inputs the create button 501 on the dashboard screen 510 , the processor 220 provides a handwriting image input screen 620 as shown in FIG. 6 .

손글씨 이미지 입력 화면(620)에는 손글씨를 쓸 템플릿을 다운로드받기 위한 템플릿 다운로드 버튼(601), 템플릿으로 작성된 손글씨 이미지를 업로드하기 위한 이미지 입력 버튼(602) 등이 포함될 수 있다. 손글씨 템플릿은 목적 글자 셋이 포함된 서식으로, PDF 파일이나 JPG 파일 등으로 제공될 수 있다. 사용자는 손글씨 이미지 입력 화면(620)에서 템플릿 다운로드 버튼(601)을 통해 템플릿을 다운로드받은 후 프린트해서 템플릿에 주어진 목적 글자 셋에 대해 직접 자신만의 스타일로 손글씨를 작성한다. 그리고, 사용자는 손글씨 이미지 입력 화면(620)에서 이미지 입력 버튼(602)을 통해 손글씨가 작성된 템플릿을 스캔하거나 촬영하여 이미지 형태로 업로드한다.The handwriting image input screen 620 may include a template download button 601 for downloading a template for handwriting, an image input button 602 for uploading a handwritten image created as a template, and the like. The handwriting template is a format including a target character set, and may be provided as a PDF file or a JPG file. The user downloads the template through the template download button 601 on the handwriting image input screen 620, prints it, and directly writes handwriting in his/her own style for the target character set given in the template. Then, the user scans or shoots the handwritten template through the image input button 602 on the handwriting image input screen 620 , and uploads it in the form of an image.

프로세서(220)는 사용자가 업로드한 손글씨 이미지에 대해 전처리가 완료되면 도 7에 도시한 바와 같이 전처리 검수 화면(730)을 제공한다. 전처리 검수 화면(730)은 사용자가 전처리 완료된 글자를 확인할 수 있는 전처리 검수용 인터페이스로서 글자 단위로, 즉 사용자가 손글씨로 작성한 글자(701) 각각에 대한 전처리 결과(702)를 보여줄 수 있다. 프로세서(220)는 사용자가 전처리 검수 화면(730)에서 체크 박스(703)를 이용하여 전처리가 잘못된 글자를 선택한 후 개선 버튼(704)을 입력하는 경우 글씨를 다시 써서 입력할 수 있는 화면(손글씨 재작성 화면)을 제공한다. 손글씨 재작성 화면에서는 전처리가 잘못된 글자의 글씨를 다시 작성하기 위한 템플릿을 제공한다.When the pre-processing of the handwritten image uploaded by the user is completed, the processor 220 provides a pre-processing inspection screen 730 as shown in FIG. 7 . The pre-processing inspection screen 730 is an interface for pre-processing inspection through which the user can check the pre-processed characters, and may show the pre-processing results 702 for each character 701 written by the user in character units. The processor 220 is a screen (handwriting rewrite) in which the user can rewrite the text when inputting the improvement button 704 after selecting the wrong text in the pre-processing using the check box 703 on the pre-processing inspection screen 730 writing screen). In the handwriting rewriting screen, a template is provided for rewriting the text of characters that have not been pre-processed.

프로세서(220)는 사용자가 전처리 검수 화면(730)에서 검수 완료 버튼(705)을 입력하는 경우 도 8에 도시한 바와 같이 손글씨 폰트 생성 화면(840)을 제공한다. 손글씨 폰트 생성 화면(840)에는 손글씨 폰트 생성에 따른 현재 상태(예를 들어, 생성 중, 생성 완료)가 노출된다.The processor 220 provides a handwriting font generation screen 840 as shown in FIG. 8 when the user inputs the inspection completion button 705 on the preprocessing inspection screen 730 . On the handwriting font generation screen 840 , a current state (eg, during generation, generation completion) according to the generation of the handwriting font is exposed.

프로세서(220)는 손글씨 폰트의 생성이 완료되면 도 9에 도시한 바와 같이 폰트 검수 화면(950)을 제공한다. 폰트 검수 과정은 사용자 손글씨 스타일이 반영된 문자 집합(활자 조판에 필요한 글자, 숫자, 특수 기호 등이 포함됨)을 사용자가 직접 검수하고, 폰트 생성이 잘못된 글자의 경우 다른 모델에서 생성된 글자로 대체하거나 글씨를 다시 작성하여 최종 폰트를 결정하는 시나리오에 해당된다. 일례로, 프로세서(220)는 폰트 검수 화면을 통해 복수 개의 모델 중 품질 스코어가 가장 높은 최적 모델의 폰트 생성 결과(901)를 보여줄 수 있다. 프로세서(220)는 복수 개의 모델 중 디폴트 모델의 폰트 생성 결과를 보여주는 것 또한 가능하다. 프로세서(220)는 최적 모델의 폰트 생성 결과(901) 내에서 특정 글자(902)를 선택하면 도 10에 도시한 바와 같이 특정 글자(902)에 대하여 각 모델 별 폰트 생성 결과(1001)를 제공할 수 있다. 사용자는 각 모델 별 폰트 생성 결과(1001)를 확인한 후 특정 글자(902)를 다른 모델의 폰트 생성 결과로 대체하여 최종 폰트에 포함시킬 수 있다. 다른 모델의 생성 결과를 이용하여 최종 폰트를 결정하는 것 이외에, 도 9의 폰트 생성 결과(901)에서 적어도 하나 이상의 글자를 선택한 후 개선 버튼(903)을 입력하는 경우 도 11에 도시한 바와 같이 선택된 글자의 손글씨를 다시 써서 최종 폰트에 반영할 수 있는 글자 개선 화면(1101)을 제공할 수 있다. 사용자는 최적 모델의 폰트 생성 결과(901)에서 선택한 글자에 대해 글자 개선 화면(1101)을 이용하여 해당 글자의 손글씨를 다시 써서 최종 폰트에 반영할 수 있다.When the generation of the handwritten font is completed, the processor 220 provides a font inspection screen 950 as shown in FIG. 9 . In the font inspection process, the user directly inspects the character set that reflects the user's handwriting style (including letters, numbers, and special symbols required for typesetting). It corresponds to the scenario where the final font is determined by rewriting the For example, the processor 220 may show the font generation result 901 of the optimal model having the highest quality score among the plurality of models through the font inspection screen. The processor 220 may also display the font generation result of the default model among the plurality of models. When a specific character 902 is selected from within the font generation result 901 of the optimal model, the processor 220 provides a font generation result 1001 for each model with respect to the specific character 902 as shown in FIG. can After checking the font generation result 1001 for each model, the user can replace the specific character 902 with the font generation result of another model to include it in the final font. In addition to determining the final font using the generation result of another model, when at least one character is selected from the font generation result 901 of FIG. 9 and then the improvement button 903 is inputted, as shown in FIG. It is possible to provide a character improvement screen 1101 that can be reflected in the final font by rewriting the handwriting of the character. The user may use the character improvement screen 1101 for the character selected in the font generation result 901 of the optimal model to rewrite the handwriting of the character and reflect it in the final font.

다른 예로, 프로세서(220)는 손글씨 폰트의 생성이 완료되면 도 12에 도시한 바와 같이 폰트 검수 화면(950)을 통해 모델 조합에 따른 최종 폰트로서 글자 단위로 품질 스코어가 가장 높은 모델의 폰트가 자동 선택된 폰트 생성 결과(1201)를 제공할 수 있다. 사용자는 폰트 검수 화면(950)을 통해 품질 스코어 기반 모델 조합의 폰트 생성 결과(1201)를 확인할 수 있고, 특정 글자에 대해 다른 모델의 생성 결과로 대체하여 최종 폰트에 포함시킬 수도 있다.As another example, when the generation of the handwritten font is completed, the processor 220 automatically selects the font of the model having the highest quality score in units of characters as the final font according to the model combination through the font inspection screen 950 as shown in FIG. 12 . The selected font generation result 1201 may be provided. The user may check the font generation result 1201 of the quality score-based model combination through the font inspection screen 950, and may replace a specific character with the generation result of another model and include it in the final font.

프로세서(220)는 도 13에 도시한 바와 같이 폰트 검수 화면(950)을 통한 검수 과정에서 사용자에 의한 검수 내용(모델 선택, 글자 개선 등)이 반영된 최종 폰트 결과(1301)를 제공할 수 있다. 사용자는 자신의 손글씨로 생성된 폰트에 대해 자신이 검수한 최종 폰트 결과(1301)를 확인할 수 있다.As shown in FIG. 13 , the processor 220 may provide the final font result 1301 in which the user's inspection contents (model selection, character improvement, etc.) are reflected in the inspection process through the font inspection screen 950 . The user may check the final font result 1301 that he/she has inspected for the font generated by his/her handwriting.

프로세서(220)는 사용자가 도 13의 폰트 검수 화면(950)에서 최종 폰트 결과(1301)를 확인한 후 검수 완료 버튼(1304)을 입력하는 경우 도 14에 도시한 바와 같이 후처리 검수 화면(1460)을 제공한다. 후처리 검수 화면(1460)은 사용자가 후처리 완료된 글자를 확인할 수 있는 후처리 검수용 인터페이스로서 문장 내 글자 별 크기 비율을 조정한 후처리 결과(1401)를 보여줄 수 있다.When the user inputs the inspection completion button 1304 after checking the final font result 1301 on the font inspection screen 950 of FIG. 13, the processor 220 is a post-processing inspection screen 1460 as shown in FIG. 14 provides The post-processing inspection screen 1460 is an interface for post-processing inspection through which the user can check the post-processed characters, and may show the post-processing result 1401 after adjusting the size ratio of each character in the sentence.

후처리 검수 화면(1460)에는 지정된 특정 글자를 특히 작게 만드는 기능(1402), 기본 정렬(하단 정렬, 중앙 정렬 등)을 선택하기 위한 기능(1403) 등이 포함될 수 있으며, 사전 설정이나 사용자의 커스텀 설정으로 정해진 글자 크기 별로 생성된 폰트 샘플인 후처리 결과(1401)가 노출될 수 있다.The post-processing inspection screen 1460 may include a function 1402 for making a specified specific character particularly small, a function 1403 for selecting a default alignment (bottom alignment, center alignment, etc.) A post-processing result 1401 that is a font sample generated for each character size determined by setting may be exposed.

프로세서(220)는 사용자가 후처리 검수 화면(1460)에서 후처리 결과(1401)를 확인한 후 검수 완료 버튼(1404)을 입력하는 경우 후처리가 완료된 최종 폰트를 패키징하여 웹 컨텐츠나 문서 등에 실제 적용 가능한 폰트 파일로 등록할 수 있다.When the user inputs the inspection completion button 1404 after checking the post-processing result 1401 on the post-processing inspection screen 1460, the processor 220 packages the final font for which the post-processing is completed and actually applies it to web content or documents, etc. It can be registered as a possible font file.

도 15는 손글씨 폰트 생성 서비스의 데모 페이지 화면(510) 예시를 나타내고 있다.15 shows an example of a demo page screen 510 of a handwriting font generation service.

데모 페이지 화면(510)에는 사용자의 손글씨 폰트를 직접 적용해 볼 수 있는 웹 데모 화면으로, 사용자의 손글씨로 생성된 폰트 목록(1501), 테스트할 글자를 입력하기 위한 글자 입력란(1502), 폰트 목록(1501)에서 선택된 폰트를 글자 입력란(1502)을 통해 입력된 글자에 적용한 테스트 결과를 제공하기 위한 테스트 결과 화면(1503) 등이 포함될 수 있다. 사용자는 데모 페이지 화면(510)을 통해 자신의 손글씨로 생성된 폰트를 문장 등에 실제 사용해볼 수 있다.The demo page screen 510 is a web demo screen where the user's handwritten fonts can be directly applied. A list of fonts created with the user's handwriting 1501, a character input field 1502 for inputting characters to be tested, and a list of fonts A test result screen 1503 for providing a test result of applying the font selected in 1501 to the character input through the character input field 1502 may be included. The user can actually use the font generated by his or her handwriting on a sentence or the like through the demo page screen 510 .

이처럼 본 발명의 실시예들에 따르면, 사용자가 직접 쓴 손글씨를 기반으로 폰트 파일을 생성할 수 있는 서비스 모델을 제공함으로써 웹 컨텐츠나 문서에 적용할 수 있는 폰트 파일을 자신만의 스타일로 자유롭게 디자인할 수 있다. 특히, 본 발명의 실시예들에 따르면, 폰트 생성 과정 중에 중간 결과를 사용자가 직접 검수할 수 있는 커스텀 튜닝 기능을 제공함으로써 보다 편리하게 사용자가 원하는 스타일을 반영할 수 있다. 따라서, 본 실시예들은 사용자가 직접 평가, 생성, 조율 가능한 서비스 환경을 제공함으로써 손글씨 폰트 생성을 위한 서비스 효율성을 향상시킬 수 있고 폰트 생성 과정에서 필요한 커뮤니케이션을 단축시킬 수 있다.As such, according to the embodiments of the present invention, by providing a service model that can generate a font file based on handwriting written by a user, a font file that can be applied to web content or documents can be freely designed in your own style. can In particular, according to embodiments of the present invention, a user's desired style can be more conveniently reflected by providing a custom tuning function that allows the user to directly inspect the intermediate result during the font creation process. Accordingly, the present embodiments provide a service environment in which the user can directly evaluate, create, and tune, thereby improving service efficiency for generating handwritten fonts and shortening communication required in the font creation process.

이상에서 설명된 장치는 하드웨어 구성요소, 소프트웨어 구성요소, 및/또는 하드웨어 구성요소 및 소프트웨어 구성요소의 조합으로 구현될 수 있다. 예를 들어, 실시예들에서 설명된 장치 및 구성요소는, 프로세서, 콘트롤러, ALU(arithmetic logic unit), 디지털 신호 프로세서(digital signal processor), 마이크로컴퓨터, FPGA(field programmable gate array), PLU(programmable logic unit), 마이크로프로세서, 또는 명령(instruction)을 실행하고 응답할 수 있는 다른 어떠한 장치와 같이, 하나 이상의 범용 컴퓨터 또는 특수 목적 컴퓨터를 이용하여 구현될 수 있다. 처리 장치는 운영 체제(OS) 및 상기 운영 체제 상에서 수행되는 하나 이상의 소프트웨어 어플리케이션을 수행할 수 있다. 또한, 처리 장치는 소프트웨어의 실행에 응답하여, 데이터를 접근, 저장, 조작, 처리 및 생성할 수도 있다. 이해의 편의를 위하여, 처리 장치는 하나가 사용되는 것으로 설명된 경우도 있지만, 해당 기술분야에서 통상의 지식을 가진 자는, 처리 장치가 복수 개의 처리 요소(processing element) 및/또는 복수 유형의 처리 요소를 포함할 수 있음을 알 수 있다. 예를 들어, 처리 장치는 복수 개의 프로세서 또는 하나의 프로세서 및 하나의 콘트롤러를 포함할 수 있다. 또한, 병렬 프로세서(parallel processor)와 같은, 다른 처리 구성(processing configuration)도 가능하다.The device described above may be implemented as a hardware component, a software component, and/or a combination of the hardware component and the software component. For example, the apparatus and components described in the embodiments may include a processor, a controller, an arithmetic logic unit (ALU), a digital signal processor, a microcomputer, a field programmable gate array (FPGA), and a programmable logic unit (PLU). It may be implemented using one or more general purpose or special purpose computers, such as a logic unit, microprocessor, or any other device capable of executing and responding to instructions. The processing device may execute an operating system (OS) and one or more software applications running on the operating system. A processing device may also access, store, manipulate, process, and generate data in response to execution of the software. For convenience of understanding, although one processing device is sometimes described as being used, one of ordinary skill in the art will recognize that the processing device includes a plurality of processing elements and/or a plurality of types of processing elements. It can be seen that can include For example, the processing device may include a plurality of processors or one processor and one controller. Other processing configurations are also possible, such as parallel processors.

소프트웨어는 컴퓨터 프로그램(computer program), 코드(code), 명령(instruction), 또는 이들 중 하나 이상의 조합을 포함할 수 있으며, 원하는 대로 동작하도록 처리 장치를 구성하거나 독립적으로 또는 결합적으로(collectively) 처리 장치를 명령할 수 있다. 소프트웨어 및/또는 데이터는, 처리 장치에 의하여 해석되거나 처리 장치에 명령 또는 데이터를 제공하기 위하여, 어떤 유형의 기계, 구성요소(component), 물리적 장치, 컴퓨터 저장 매체 또는 장치에 구체화(embody)될 수 있다. 소프트웨어는 네트워크로 연결된 컴퓨터 시스템 상에 분산되어서, 분산된 방법으로 저장되거나 실행될 수도 있다. 소프트웨어 및 데이터는 하나 이상의 컴퓨터 판독 가능 기록 매체에 저장될 수 있다.Software may comprise a computer program, code, instructions, or a combination of one or more thereof, which configures a processing device to operate as desired or is independently or collectively processed You can command the device. The software and/or data may be embodied in any tangible machine, component, physical device, computer storage medium or device for interpretation by or providing instructions or data to the processing device. have. The software may be distributed over networked computer systems and stored or executed in a distributed manner. Software and data may be stored in one or more computer-readable recording media.

실시예에 따른 방법은 다양한 컴퓨터 수단을 통하여 수행될 수 있는 프로그램 명령 형태로 구현되어 컴퓨터 판독 가능 매체에 기록될 수 있다. 이때, 매체는 컴퓨터로 실행 가능한 프로그램을 계속 저장하거나, 실행 또는 다운로드를 위해 임시 저장하는 것일 수도 있다. 또한, 매체는 단일 또는 수 개의 하드웨어가 결합된 형태의 다양한 기록수단 또는 저장수단일 수 있는데, 어떤 컴퓨터 시스템에 직접 접속되는 매체에 한정되지 않고, 네트워크 상에 분산 존재하는 것일 수도 있다. 매체의 예시로는, 하드 디스크, 플로피 디스크 및 자기 테이프와 같은 자기 매체, CD-ROM 및 DVD와 같은 광기록 매체, 플롭티컬 디스크(floptical disk)와 같은 자기-광 매체(magneto-optical medium), 및 ROM, RAM, 플래시 메모리 등을 포함하여 프로그램 명령어가 저장되도록 구성된 것이 있을 수 있다. 또한, 다른 매체의 예시로, 어플리케이션을 유통하는 앱 스토어나 기타 다양한 소프트웨어를 공급 내지 유통하는 사이트, 서버 등에서 관리하는 기록매체 내지 저장매체도 들 수 있다.The method according to the embodiment may be implemented in the form of program instructions that can be executed through various computer means and recorded in a computer-readable medium. In this case, the medium may be to continuously store a program executable by a computer, or to temporarily store it for execution or download. In addition, the medium may be various recording means or storage means in the form of a single or several hardware combined, it is not limited to a medium directly connected to any computer system, and may exist distributed over a network. Examples of the medium include a hard disk, a magnetic medium such as a floppy disk and a magnetic tape, an optical recording medium such as CD-ROM and DVD, a magneto-optical medium such as a floppy disk, and those configured to store program instructions, including ROM, RAM, flash memory, and the like. In addition, examples of other media may include recording media or storage media managed by an app store that distributes applications, sites that supply or distribute other various software, and servers.

이상과 같이 실시예들이 비록 한정된 실시예와 도면에 의해 설명되었으나, 해당 기술분야에서 통상의 지식을 가진 자라면 상기의 기재로부터 다양한 수정 및 변형이 가능하다. 예를 들어, 설명된 기술들이 설명된 방법과 다른 순서로 수행되거나, 및/또는 설명된 시스템, 구조, 장치, 회로 등의 구성요소들이 설명된 방법과 다른 형태로 결합 또는 조합되거나, 다른 구성요소 또는 균등물에 의하여 대치되거나 치환되더라도 적절한 결과가 달성될 수 있다.As described above, although the embodiments have been described with reference to the limited embodiments and drawings, various modifications and variations are possible from the above description by those skilled in the art. For example, the described techniques are performed in an order different from the described method, and/or the described components of the system, structure, apparatus, circuit, etc. are combined or combined in a different form than the described method, or other components Or substituted or substituted by equivalents may achieve an appropriate result.

그러므로, 다른 구현들, 다른 실시예들 및 특허청구범위와 균등한 것들도 후술하는 특허청구범위의 범위에 속한다.Therefore, other implementations, other embodiments, and equivalents to the claims are also within the scope of the following claims.

Claims (20)

컴퓨터 장치에서 실행되는 손글씨 폰트 생성 방법에 있어서,
상기 컴퓨터 장치는 메모리에 포함된 컴퓨터 판독가능한 명령들을 실행하도록 구성된 적어도 하나의 프로세서를 포함하고,
상기 손글씨 폰트 생성 방법은,
상기 적어도 하나의 프로세서에 의해, 사용자의 손글씨가 포함된 손글씨 이미지를 학습 가능한 포맷의 이미지 파일로 전처리하는 단계;
상기 적어도 하나의 프로세서에 의해, 상기 이미지 파일을 이용하여 상기 손글씨의 폰트 스타일을 학습하여 손글씨 폰트를 생성하는 단계; 및
상기 적어도 하나의 프로세서에 의해, 상기 손글씨 폰트의 크기 비율을 후처리하는 단계
를 포함하는 손글씨 폰트 생성 방법.
A method for generating handwritten fonts executed on a computer device, the method comprising:
the computer device comprises at least one processor configured to execute computer readable instructions contained in a memory;
The handwriting font generation method is,
pre-processing, by the at least one processor, a handwritten image including the user's handwriting into an image file of a learnable format;
generating, by the at least one processor, a handwriting font by learning a font style of the handwriting using the image file; and
post-processing, by the at least one processor, the size ratio of the handwritten font
A method of generating a handwritten font comprising a.
제1항에 있어서,
상기 전처리하는 단계는,
주어진 글자 셋을 포함하는 템플릿을 제공하는 단계;
상기 글자 셋이 손글씨로 작성된 템플릿을 입력 이미지로 수신하는 단계; 및
상기 입력 이미지를 글자 단위로 잘라 각 글자 이미지를 학습 가능한 포맷의 이미지 파일로 가공하는 단계
를 포함하는 손글씨 폰트 생성 방법.
According to claim 1,
The pre-processing step is
providing a template including a given character set;
receiving a template in which the character set is written by hand as an input image; and
Cutting the input image in character units and processing each character image into an image file in a learnable format
A method of generating a handwritten font comprising a.
제1항에 있어서,
상기 전처리하는 단계는,
글자 단위로 주어진 글자의 이미지와 상기 주어진 글자에 대한 손글씨 이미지로 이루어진 이미지 쌍을 학습 데이터로 생성하는 단계
를 포함하는 손글씨 폰트 생성 방법.
According to claim 1,
The pre-processing step is
Generating an image pair consisting of an image of a given character in units of characters and a handwritten image for the given character as learning data
A method of creating a handwritten font comprising a.
제1항에 있어서,
상기 손글씨 폰트 생성 방법은,
상기 적어도 하나의 프로세서에 의해, 상기 전처리하는 단계에서의 전처리 결과, 상기 생성하는 단계에서의 폰트 생성 결과, 및 상기 후처리하는 단계에서의 후처리 결과 중 적어도 하나를 상기 사용자가 검수하기 위한 사용자 검수용 인터페이스를 제공하는 단계
를 더 포함하는 손글씨 폰트 생성 방법.
According to claim 1,
The handwriting font generation method is,
User inspection for the user to inspect at least one of the pre-processing result in the pre-processing step, the font generation result in the generating step, and the post-processing result in the post-processing step by the at least one processor Steps to provide an interface for
A handwriting font creation method further comprising a.
제1항에 있어서,
상기 손글씨 폰트 생성 방법은,
상기 적어도 하나의 프로세서에 의해, 상기 전처리하는 단계에서의 전처리 결과를 상기 사용자가 검수하기 위한 전처리 검수용 인터페이스를 제공하는 단계
를 더 포함하고,
상기 전처리 검수용 인터페이스는 글자 단위로 전처리가 완료된 글자를 확인하기 위한 기능 및 글자 단위로 손글씨를 수정하기 위한 기능이 포함되는 것
을 특징으로 하는 손글씨 폰트 생성 방법.
According to claim 1,
The handwriting font generation method is,
Providing, by the at least one processor, an interface for pre-processing inspection for the user to inspect the pre-processing result in the pre-processing step
further comprising,
The pre-processing inspection interface includes a function for checking the pre-processed characters in units of characters and a function for correcting handwriting in units of characters
A method for generating handwritten fonts, characterized in that
제1항에 있어서,
상기 손글씨 폰트 생성 방법은,
상기 적어도 하나의 프로세서에 의해, 상기 생성하는 단계에서의 폰트 생성 결과를 상기 사용자가 검수하기 위한 폰트 검수용 인터페이스를 제공하는 단계
를 더 포함하고,
상기 폰트 검수용 인터페이스는 폰트 생성 결과를 확인하기 위한 기능 및 상기 폰트 생성 결과에서 글자 단위로 다른 모델의 생성 결과로 대체하거나 손글씨를 재입력하기 위한 기능이 포함되는 것
을 특징으로 하는 손글씨 폰트 생성 방법.
The method of claim 1,
The handwriting font generation method is,
Providing, by the at least one processor, an interface for font inspection for the user to inspect the font generation result in the generating step
further comprising,
The font inspection interface includes a function for confirming the font generation result and a function for substituting the result of generating another model for each character in the font generation result or re-entering the handwriting
A method for generating handwritten fonts, characterized in that
제6항에 있어서,
상기 폰트 검수용 인터페이스는 상기 폰트 생성 결과를 확인하기 위한 기능으로서 복수 개의 모델 중 디폴트 모델의 폰트 생성 결과를 제공하는 기능, 상기 복수 개의 모델 중 품질 스코어가 가장 높은 모델의 폰트 생성 결과를 제공하는 기능, 글자 단위로 품질 스코어가 가장 높은 모델 조합의 폰트 생성 결과를 제공하는 기능 중 어느 하나가 포함되는 것
을 특징으로 하는 손글씨 폰트 생성 방법.
7. The method of claim 6,
The font inspection interface is a function for confirming the font generation result, a function of providing a font generation result of a default model among a plurality of models, a function of providing a font generation result of a model having the highest quality score among the plurality of models , that includes any one of the functions that provide the font generation result of the model combination with the highest quality score in units of characters
A method for generating handwritten fonts, characterized in that
제1항에 있어서,
상기 손글씨 폰트 생성 방법은,
상기 적어도 하나의 프로세서에 의해, 상기 후처리하는 단계에서의 후처리 결과를 상기 사용자가 검수하기 위한 후처리 검수용 인터페이스를 제공하는 단계
를 더 포함하고,
상기 후처리 검수용 인터페이스는 후처리가 완료된 폰트를 확인하기 위한 기능 및 상기 손글씨 폰트의 문장 내 글자 크기 비율을 조정하기 위한 기능이 포함되는 것
을 특징으로 하는 손글씨 폰트 생성 방법.
According to claim 1,
The handwriting font generation method is,
Providing, by the at least one processor, an interface for post-processing inspection for the user to inspect the post-processing result in the post-processing step
further comprising,
The interface for post-processing inspection includes a function for confirming the post-processing completed font and a function for adjusting the text size ratio in the text of the handwritten font
A method for generating handwritten fonts, characterized in that
제8항에 있어서,
상기 후처리 검수용 인터페이스는 사전 설정(preset) 또는 상기 사용자의 커스텀 설정으로 정해진 글자 크기로 상기 손글씨 폰트를 조정하기 위한 기능이 포함되는 것
을 특징으로 하는 손글씨 폰트 생성 방법.
9. The method of claim 8,
The interface for post-processing inspection includes a function for adjusting the handwritten font to a font size determined by a preset or a custom setting of the user
A method for generating handwritten fonts, characterized in that
제1항에 있어서,
상기 손글씨 폰트 생성 방법은,
상기 적어도 하나의 프로세서에 의해, 후처리가 완료된 폰트를 패키징하여 웹 컨텐츠 또는 문서에 적용 가능한 폰트 포맷의 파일로 등록하는 단계
를 더 포함하는 손글씨 폰트 생성 방법.
According to claim 1,
The handwriting font generation method is,
Packaging the post-processing font by the at least one processor and registering it as a file of a font format applicable to web content or documents
A handwriting font creation method further comprising a.
제1항 내지 제10항 중 어느 한 항의 손글씨 폰트 생성 방법을 상기 컴퓨터 장치에 실행시키기 위해 컴퓨터 판독가능한 기록 매체에 저장되는 컴퓨터 프로그램.A computer program stored in a computer-readable recording medium for executing the method for generating a handwriting font according to any one of claims 1 to 10 in the computer device. 컴퓨터 장치에 있어서,
메모리에 포함된 컴퓨터 판독가능한 명령들을 실행하도록 구성된 적어도 하나의 프로세서
를 포함하고,
상기 적어도 하나의 프로세서는,
사용자의 손글씨가 포함된 손글씨 이미지를 학습 가능한 포맷의 이미지 파일로 전처리하고,
상기 이미지 파일을 이용하여 상기 손글씨의 폰트 스타일을 학습하여 손글씨 폰트를 생성하고,
상기 손글씨 폰트의 크기 비율을 후처리하는 것
을 특징으로 하는 컴퓨터 장치.
A computer device comprising:
at least one processor configured to execute computer readable instructions contained in memory
including,
the at least one processor,
Pre-processing the handwritten image containing the user's handwriting into an image file in a learnable format,
Using the image file to learn the font style of the handwriting to generate a handwritten font,
Post-processing the size ratio of the handwritten font
A computer device comprising a.
제12항에 있어서,
상기 적어도 하나의 프로세서는,
주어진 글자 셋을 포함하는 템플릿을 제공하고,
상기 글자 셋이 손글씨로 작성된 템플릿을 입력 이미지로 수신하고,
상기 입력 이미지를 글자 단위로 잘라 각 글자 이미지를 학습 가능한 포맷의 이미지 파일로 가공하는 것
을 특징으로 하는 컴퓨터 장치.
13. The method of claim 12,
the at least one processor,
provide a template containing a given character set,
Receives a template in which the character set is written by hand as an input image,
Cutting the input image into character units and processing each character image into an image file in a learnable format
A computer device comprising a.
제12항에 있어서,
상기 적어도 하나의 프로세서는,
글자 단위로 주어진 글자의 이미지와 상기 주어진 글자에 대한 손글씨 이미지로 이루어진 이미지 쌍을 학습 데이터로 생성하는 것
을 특징으로 하는 컴퓨터 장치.
13. The method of claim 12,
the at least one processor,
Creating an image pair consisting of an image of a given character in units of characters and a handwritten image for the given character as learning data
A computer device comprising a.
제12항에 있어서,
상기 적어도 하나의 프로세서는,
상기 전처리하는 단계에서의 전처리 결과, 상기 생성하는 단계에서의 폰트 생성 결과, 및 상기 후처리하는 단계에서의 후처리 결과 중 적어도 하나를 상기 사용자가 검수하기 위한 사용자 검수용 인터페이스를 제공하는 것
을 특징으로 하는 컴퓨터 장치.
13. The method of claim 12,
the at least one processor,
Providing an interface for user inspection for the user to inspect at least one of the pre-processing result in the pre-processing step, the font generation result in the generating step, and the post-processing result in the post-processing step
A computer device comprising a.
제12항에 있어서,
상기 적어도 하나의 프로세서는,
상기 전처리하는 단계에서의 전처리 결과를 상기 사용자가 검수하기 위한 전처리 검수용 인터페이스를 제공하고,
상기 전처리 검수용 인터페이스는 글자 단위로 전처리가 완료된 글자를 확인하기 위한 기능 및 글자 단위로 손글씨를 수정하기 위한 기능이 포함되는 것
을 특징으로 하는 컴퓨터 장치.
13. The method of claim 12,
the at least one processor,
Provides an interface for pre-processing inspection for the user to inspect the pre-processing result in the pre-processing step,
The pre-processing inspection interface includes a function for checking the pre-processed characters in units of characters and a function for correcting handwriting in units of characters
A computer device comprising a.
제12항에 있어서,
상기 적어도 하나의 프로세서는,
상기 생성하는 단계에서의 폰트 생성 결과를 상기 사용자가 검수하기 위한 폰트 검수용 인터페이스를 제공하고,
상기 폰트 검수용 인터페이스는 폰트 생성 결과를 확인하기 위한 기능 및 상기 폰트 생성 결과에서 글자 단위로 다른 모델의 생성 결과로 대체하거나 손글씨를 재입력하기 위한 기능이 포함되는 것
을 특징으로 하는 컴퓨터 장치.
13. The method of claim 12,
the at least one processor,
Provides an interface for font inspection for the user to inspect the font generation result in the generating step,
The font inspection interface includes a function for confirming the font generation result and a function for substituting the result of generating another model for each character in the font generation result or re-entering the handwriting
A computer device comprising a.
제17항에 있어서,
상기 폰트 검수용 인터페이스는 상기 폰트 생성 결과를 확인하기 위한 기능으로서 복수 개의 모델 중 디폴트 모델의 폰트 생성 결과를 제공하는 기능, 상기 복수 개의 모델 중 품질 스코어가 가장 높은 모델의 폰트 생성 결과를 제공하는 기능, 글자 단위로 품질 스코어가 가장 높은 모델 조합의 폰트 생성 결과를 제공하는 기능 중 어느 하나가 포함되는 것
을 특징으로 하는 컴퓨터 장치.
18. The method of claim 17,
The font inspection interface is a function for confirming the font generation result, a function of providing a font generation result of a default model among a plurality of models, a function of providing a font generation result of a model having the highest quality score among the plurality of models , that includes any one of the functions that provide the font generation result of the model combination with the highest quality score in units of characters
A computer device comprising a.
제12항에 있어서,
상기 적어도 하나의 프로세서는,
상기 후처리하는 단계에서의 후처리 결과를 상기 사용자가 검수하기 위한 후처리 검수용 인터페이스를 제공하고,
상기 후처리 검수용 인터페이스는 후처리가 완료된 폰트를 확인하기 위한 기능 및 상기 손글씨 폰트의 문장 내 글자 크기 비율을 조정하기 위한 기능이 포함되는 것
을 특징으로 하는 컴퓨터 장치.
13. The method of claim 12,
the at least one processor,
To provide an interface for post-processing inspection for the user to inspect the post-processing result in the post-processing step,
The interface for post-processing inspection includes a function for confirming the post-processing completed font and a function for adjusting the text size ratio in the text of the handwritten font
A computer device comprising a.
제19항에 있어서,
상기 후처리 검수용 인터페이스는 사전 설정 또는 상기 사용자의 커스텀 설정으로 정해진 글자 크기로 상기 손글씨 폰트를 조정하기 위한 기능이 포함되는 것
을 특징으로 하는 컴퓨터 장치.
20. The method of claim 19,
The post-processing inspection interface includes a function for adjusting the handwritten font to a font size determined by a preset or the user's custom setting
A computer device comprising a.
KR1020200175275A 2020-12-15 2020-12-15 Method and system to provide handwriting font generation service KR102501631B1 (en)

Priority Applications (2)

Application Number Priority Date Filing Date Title
KR1020200175275A KR102501631B1 (en) 2020-12-15 2020-12-15 Method and system to provide handwriting font generation service
JP2021197512A JP7348446B2 (en) 2020-12-15 2021-12-06 Method and system for providing handwritten font generation service

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
KR1020200175275A KR102501631B1 (en) 2020-12-15 2020-12-15 Method and system to provide handwriting font generation service

Publications (2)

Publication Number Publication Date
KR20220085313A true KR20220085313A (en) 2022-06-22
KR102501631B1 KR102501631B1 (en) 2023-02-20

Family

ID=82162660

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1020200175275A KR102501631B1 (en) 2020-12-15 2020-12-15 Method and system to provide handwriting font generation service

Country Status (2)

Country Link
JP (1) JP7348446B2 (en)
KR (1) KR102501631B1 (en)

Families Citing this family (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2024103292A1 (en) * 2022-11-16 2024-05-23 京东方科技集团股份有限公司 Handwritten form recognition method, and handwritten form recognition model training method and device

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20090092158A (en) * 2008-02-26 2009-08-31 (주)윤디자인연구소 System and method of font management
KR101165975B1 (en) * 2011-12-12 2012-07-18 주식회사 한글과컴퓨터 Touch screen apparatus and handwriting input method of the touch screen apparatus
KR101801153B1 (en) * 2016-12-30 2017-11-27 이경민 System for recogniting character based on machine learning
KR20210037280A (en) * 2019-09-27 2021-04-06 이현규 Automatic font generating system and method by using hand-written

Family Cites Families (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20130181995A1 (en) * 2010-09-21 2013-07-18 Hewlett-Packard Developement Company, L.P. Handwritten character font library
JP4971528B1 (en) * 2012-01-05 2012-07-11 義一 中村 Handwritten text creation method and program
JP2019184770A (en) * 2018-04-06 2019-10-24 キヤノン株式会社 Handwritten character creation device, control method thereof, and program

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20090092158A (en) * 2008-02-26 2009-08-31 (주)윤디자인연구소 System and method of font management
KR101165975B1 (en) * 2011-12-12 2012-07-18 주식회사 한글과컴퓨터 Touch screen apparatus and handwriting input method of the touch screen apparatus
KR101801153B1 (en) * 2016-12-30 2017-11-27 이경민 System for recogniting character based on machine learning
KR20210037280A (en) * 2019-09-27 2021-04-06 이현규 Automatic font generating system and method by using hand-written

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
김예진 외, ‘사용자 필적 맞춤형 폰트 생성 서비스’, 2019년 추계학술발표대회 논문집 제26권 제2호, 2019. 11.* *

Also Published As

Publication number Publication date
JP7348446B2 (en) 2023-09-21
JP2022094939A (en) 2022-06-27
KR102501631B1 (en) 2023-02-20

Similar Documents

Publication Publication Date Title
US10783409B2 (en) Font replacement based on visual similarity
US11030389B2 (en) Acquisition of a font portion using a compression mechanism
US10528649B2 (en) Recognizing unseen fonts based on visual similarity
EP3005100A1 (en) Bundle package generation
KR20160013883A (en) Bundle package signing
JP2020027524A (en) Character recognition device, character recognition method, and character recognition program
US10366142B2 (en) Identifier based glyph search
KR102501631B1 (en) Method and system to provide handwriting font generation service
EP3627313B1 (en) Method and system for operating a software application on a processor of a mobile device
KR102074764B1 (en) Method and system for supporting spell checking within input interface of mobile device
CN112799658B (en) Model training method, model training platform, electronic device, and storage medium
KR102352792B1 (en) Method, system, and non-transitory computer readable record medium for onboarding for users of content with image
KR102158544B1 (en) Method and system for supporting spell checking within input interface of mobile device
JP6552162B2 (en) Information processing apparatus, information processing method, and program
US20200034119A1 (en) Translating User Inputs Into Discretely Functional Styled Standalone Web and Mobile Software Features
JP2020027598A (en) Character recognition device, character recognition method, and character recognition program
JP7421137B2 (en) Information processing device, information processing method and program
KR20210000948A (en) Method, system, and non-transitory computer readable record medium for providing font sticker
CN111919199B (en) Neural network system and method for application navigation
JP2022091019A (en) Information processing apparatus, information processing method, and program
CN116416194A (en) Processing method, device and system of image modeling platform
CN117908929A (en) Method, device, equipment and storage medium for automatically generating client
CN117875288A (en) Form page generation method and device and electronic equipment
McAnlis et al. The State of Responsive Design: Tyler Smith, HTML5 Game Developer, Engineer and Tech Evangelist at AgeCheq Colt “MainRoach” McAnlis, Developer Advocate, Google

Legal Events

Date Code Title Description
E902 Notification of reason for refusal
AMND Amendment
E601 Decision to refuse application
AMND Amendment
X701 Decision to grant (after re-examination)
GRNT Written decision to grant