Skip to content

Latest commit

 

History

History
234 lines (150 loc) · 8.72 KB

README.md

File metadata and controls

234 lines (150 loc) · 8.72 KB

Asset Store Guide

logo Image

Korean Typer

C# string class 키보드 한글 입력 효과 Extension


1. 소개

Demo GIF

한글은 알파벳이나 한자와는 다르게 초성, 중성, 종성으로 이루어진 음절 단위를 사용합니다.

또한, string class의 가장 작은 기본 단위는 음절이기 때문에,

string의 각 원소를 하나씩 출력하게 된다면 한 음절씩 나타나는 모습을 볼 수 있습니다.

이 패키지는 그러한 문제를 해결하기 위해

주어진 string 입력을 마치 실제 키보드로 입력하는 것 처럼 보이는 효과를 주는 string class Extension입니다.

이 에셋을 사용하여 Unity 엔진에서 사람이 문자열을 직접 타이핑 하는 듯 한 느낌을

스크립트로 쉽게 구현 할 수 있습니다.

플랫폼 버전
Unity




2. 사용법

KoreanTyper는 아주 간단하게 사용 할 수 있습니다.

먼저, KoreanTyper 네임 스페이스를 사용한다는 코드를 스크립트의 상단에 배치합니다.

using KoreanTyper;

원하는 stringTyping() 함수를 사용합니다.

Debug.Log("안녕하세요".Typing(7));		// 출력 결과 : 안녕ㅎ

이게 끝 입니다. 참 쉽죠?




3. 더 자세한 사용법

KoreanTyper는 다음 3가지의 string Class Extension을 제공합니다:

  • Korean Typer
      1. 소개
      1. 사용법
      1. 더 자세한 사용법
      • 3.1 public int GetTypingLength()
      • 3.2 public string Typing(int count)
      • 3.3 public string Typing(float percent)
      1. 간단한 데모
      1. NOTICE

3.1 public int GetTypingLength()

해당 문장이 총 몇번의 타이핑으로 입력 할 수 있는지 반환하는 함수입니다.

예를 들어, "동해물과 백두산이 마르고 닳도록"이라는 스트링은

22회의 키보드 누름으로 입력할 수 있습니다.

(띄움)
ㄷㅗㅇ ㅎㅐ ㅁㅜㄹ ㄱㅗㅏ - ㅂㅐㄱ ㄷㅜ ㅅㅏㄴ ㅇㅣ
3 2 3 3 1 3 2 3 2

public int GetTypingLength()는 이 횟수를 리턴하는 함수입니다.

영어, 숫자, 특수 문자, 한글 자음, 쌍자음과 모음은 1회 입력으로 간주하고

, 와 같이 두 자음이 합쳐져 있거나

, , 와 같이 두 모음이 합쳐져 있는 경우는 2회 입력으로 간주합니다.

Debug.Log("동해물과 백두산이".GetTypingLength());		// 출력 결과 : 22

3.2 public string Typing(int count)

count횟수 만큼 키보드를 눌렀을 때, 해당 문자가 어디까지 입력되는지 계산하고 이를 반환하는 함수입니다.

count0이하면 ""을 리턴하고,

count가 해당 문자열의 GetTypingLength()이상이면 해당 문자열을 그대로 리턴합니다.

"안녕하세요" 라는 문자열을 예로 들면, 다음과 같습니다.

조합 ㅇㅏㄴ ㄴㅕㅇ ㅎㅏ ㅅㅔ ㅇㅛ
필요 타이핑 수 3 3 2 2 2
누적 필요 타이핑 수 3 6 8 10 12
count "안녕하세요".Typing(count) 계산 결과 출력 결과
0
1
2 ㅇㅏ
3 ㅇㅏㄴ
4 ㅇㅏㄴㄴ 안ㄴ
5 ㅇㅏㄴㄴㅕ 안녀
6 ㅇㅏㄴㄴㅕㅇ 안녕
7 ㅇㅏㄴㄴㅕㅇㅎ 안녕ㅎ
8 ㅇㅏㄴㄴㅕㅇㅎㅏ 안녕하
9 ㅇㅏㄴㄴㅕㅇㅎㅏㅅ 안녕하ㅅ
10 ㅇㅏㄴㄴㅕㅇㅎㅏㅅㅔ 안녕하세
11 ㅇㅏㄴㄴㅕㅇㅎㅏㅅㅔㅇ 안녕하세ㅇ
12 ㅇㅏㄴㄴㅕㅇㅎㅏㅅㅔㅇㅛ 안녕하세요

위 함수를 Update함수나 Coroutine안에 집어 넣어,

일정 시간마다 한 음절씩 입력되도록 구현하면 됩니다.

Debug.Log("안녕하세요".Typing(9));		// 출력 결과 : 안녕하ㅅ

3.3 public string Typing(float percent)

몇 번에 걸쳐 진행 될 지 모르겠다면, 그냥 0~1 사이의 진행률로 입력해도 됩니다.

percent0이하면 ""을 리턴하고,

percent1이상이면 해당 문자열을 그대로 리턴합니다.

percent0보다 크고, 1보다 작다면 진행률에 맞는 문자열을 리턴합니다.

Debug.Log("안녕하세요".Typing(0.845f));		// 출력 결과 : 안녕하세



4. 간단한 데모

본 코드는 Text UI에 문자열을 타이핑하는 효과를 주는 아주 간단한 예제입니다.

using KoreanTyper;			// Korean Typer 네임 스페이스 추가
using UnityEngine;
using UnityEngine.UI;

//======================================================================================
//  Simple  Demo
//  간단한 데모
//======================================================================================
public class KoreanTyperDemo : MonoBehaviour {
    public Text TestText;

    //==================================================================================
    // Initializing | 초기화
    //==================================================================================
    private void Start() {
        StartCoroutine(TypingCoroutine("동해물과 백두산이 마르고 닳도록"));
    }

    //==================================================================================
    // TypingCoroutine | 데모 코루틴
    //==================================================================================
    public IEnumerator TypingCoroutine(string str) {
        TestText.text = "";                                   // 초기화
        yield return new WaitForSeconds(1f);                  // 1초 대기
        
        int strTypingLength = str.GetTypingLength();          // 최대 타이핑 수 구함
        for(int  i = 0 ; i <= strTypingLength ; i ++ ) {      // 반복문
        	TestText.text = str.Typing(i);                    // 타이핑
        	yield return new WaitForSeconds(0.03f);           // 0.03초 대기
        }
    }
}



5. NOTICE

이때, for문과 함께 Korean Typer 패키지를 사용할 땐

반드시 str.GetTypingLength()보다 같거나 작을 때까지 반복하도록 해야합니다.

만약 4번 데모에서 i <= strTypingLength 가 아닌

i < strTypingLength으로 했다면, 마지막 한 글자가 제대로 나오지 않을겁니다.