libhangul  Version 0.1.0
함수
한글 자판

함수

unsigned int hangul_keyboard_list_get_count ()
 libhangul에서 제공하는 자판 개수를 구하는 함수 더 자세히 ...
 
const char * hangul_keyboard_list_get_keyboard_id (unsigned index_)
 libhangul에서 제공하는 자판의 id를 구하는 함수 더 자세히 ...
 
const char * hangul_keyboard_list_get_keyboard_name (unsigned index_)
 libhangul에서 제공하는 자판의 이름을 구하는 함수 더 자세히 ...
 

상세한 설명

libhangul이 지원하는 한글 자판

libhangul에서 지원하는 자판은 두벌식, 두벌식 옛글, 세벌식 최종, 세벌식 390, 세벌식 순아래, 세벌식 옛글, 안마태, 로마자 자판 이다.

아래의 자판 배열은 libhangul에서 지원하는 자판을 알아보기 쉽게 그림형태로 나타낸 것이다.

두벌식

이 자판은 표준 두벌식을 구현한 것이다. 그러나 표준 자판과 조금 다른 동작이 있다. 된소리 ㅃㅉㄸㄲㅆ들은 shift와 함께 누르는 방법 이외에도 반복해서 누르면 입력된다.

~
`
!
1
@
2
#
3
$
4
%
5
^
6
&
7
*
8
(
9
)
0
_
-
+
=
Backspace
Tab









{
[
}
]
|
\
Caps Lock








:
;
"
'
Enter
Shift






<
,
>
.
?
/
Shift

두벌식 옛글

이 자판은 옛한글을 입력하기 위한 두벌식 자판이다. 아래한글의 두벌식 옛글 자판과 같은 배열을 가지도록 만들었다. 두벌식 자판과 마찬가지로 된소리를 두번 누르는 방법으로 입력할 수 있다.

~
`
!
1
@
2
#
3
$
4
%
5
^
6
&
7
*
8
(
9
)
0
_
-
+
=
Backspace
Tab









{
[
}
]
|
\
Caps Lock
ᅝᅠ



ᅟᆃ



:
;
"
'
Enter
Shift ᄼᅠ
ᄾᅠ
ᅎᅠ
ᅐᅠ
ᅔᅠ
ᅕᅠ

<
,
>
.
?
/
Shift

세벌식 최종

이 자판은 세벌식 최종 자판을 구현한 것이다. 원래 방식대로라면 왼쪽의 ㅗㅜ는 다른 모음과 조합되지 않아야 하지만, libhangul에서는 좌우의 ㅗㅜ를 구분하지 않고 다른 모음과 조합된다.


*





=


'
~
;
)
+
>
Backspace
Tab




5
6
7
8
9
%
(
/
<
\
:
Caps Lock




0
1
2
3
4
·
Enter
Shift



?
-
"

,

.
!
Shift

세벌식 390

이 자판은 세벌식 390 자판을 구현한 것이다. 원래 방식대로라면 왼쪽의 ㅗㅜ는 다른 모음과 조합되지 않아야 하지만, libhangul에서는 좌우의 ㅗㅜ를 구분하지 않고 다른 모음과 조합된다.

~
`

@
#
$
%
^
&
*
(
)
_
-
+
=
Backspace
Tab



;
<
7
8
9
>
{
[
}
]
|
\
Caps Lock



/
'
4
5
6
:
"
Enter
Shift



!
0
1
2
,
3
.
?
Shift

세벌식 순아래

이 자판은 세벌식 순아래 자판을 구현한 것이다.

~
`
!
@
#
$
%
^
&
*
(
)
_
+
Backspace
Tab



;
<
7
8
9
>
{
}
|
Caps Lock
[
]

/
'
4
5
6
:
"
Enter
Shift -
=
\

!
0
1
2
,
3
.
?
Shift

세벌식 옛글

이 자판은 세벌식 옛글 자판을 구현한 것이다. 자판 배열은 아래한글의 세벌식 옛글 자판과 동일하다.

ᅟᅠᇰ
ᅟᅠᇹ

ᅟᅠᇫ
#
$
%

&
*
(
)
_
-
+
=
Backspace
Tab



;
<
·
ᅔᅠ
ᅕᅠ
>
{
[
}
]
|
\
Caps Lock




'

ᅎᅠ
ᅐᅠ
:
"
Enter
Shift



!


ᄼᅠ
,
ᄾᅠ
.
?
Shift

세벌식 두벌배열

이 자판은 두벌식 자판의 배열을 그대로 사용하면서 shift와 함께 자음을 누르면 종성으로 입력되도록 만든 자판이다. 일반 사용을 위해 만들어진 것이 아니고 두벌식 사용자가 손쉽게 세벌식 자판의 테스트를 할 수 있도록 하기 위해서 만든 자판이다.


`
!
1
@
2
#
3
$
4
%
5
^
6
&
7
*
8
(
9
)
0
_
-
+
=
Backspace
Tab









{
[
}
]
|
\
Caps Lock








:
;
"
'
Enter
Shift






<
,
>
.
?
/
Shift

안마태

이 자판은 안마태 자판을 구현한 것이다. libhangul의 안마태 자판 구현은 안마태 자판의 규격을 충실하게 구현한 것은 아니고 적당한 수준에서 사용가능하게 만든 것이다. 키입력이 동시에 일어났는지 판단하여 입력을 하는 방식이 아니고, 키를 순서대로 입력하여도 자모를 조합하도록 구현하여, 안마태 자판과 유사한 동작을 하도록 구현하였다.

~
`
!
1
@
2
#
3
$
4
%
5
^
6
&
7
*
8
(
9
)
0
_
-
+
=
Backspace
Tab




;
'
/
[
]
{
,
}
?
|
\
Caps Lock








:
"
.
Enter
Shift



ᅟᅠᇰ
ᅟᅠᇫ

<
>
ᅟᅠᇹ
Shift

로마자

이 자판은 현재 자판 배열의 라틴 문자를 음차하여 한글로 입력되도록 만든 자판이다. 예를 들면 'an'을 치면 '안'이 입력되는 방식이다. 로마자 자판은 다른 한글자판과 달리 Transliteration 방식으로 작동하는 자판이므로 별도의 레이아웃이 없다. 이 입력 자판에서 사용한 알파벳과 한글 자모의 대응은 기본적으로 한글 로마자 표기법과 유사하지만 동일하지는 않다. 로마자 자판은 한글을 입력하기 위한 것이므로 한글을 그럴듯 하게 표기하기 위한 로마자 표기법과는 목적이 다르다. 주로 한글 자모를 모두 입력할 수 있도록 하는 것을 우선적으로 고려하였다. 따라서 아래 자판의 대응대로 한글을 로마자로 표기하는 것은 로마자 표기법으로는 적절하지 않다.

한글 자모와 알파벳의 대응은 아래와 같다.

그 외에 다음과 같은 조합 규칙이 있다.

참고
다음 위키 페이지를 참조하라.
http://en.wikipedia.org/wiki/Korean_romanization
http://en.wikipedia.org/wiki/Revised_Romanization_of_Korean

한글 키보드 추가 방법

libhangul이 한글 키보드 파일을 읽는 위치는 두 곳이다.

키보드 파일의 로딩 순서는 시스템 파일을 먼저 로딩하고 사용자 파일을 로딩한다. 따라서 한글 키보드 목록을 이터레이션하면 사용자 추가 자판은 마지막에 나오게 된다. 사용자 자판 선택 알고리듬이 처음 나온 자판을 인식하는 방식이므로 동일한 id를 가진 자판을 등록하면 먼저 등록된 자판만 인식되므로 주의가 필요하다. 다시 말해서 시스템 자판과 같은 id를 가진 자판은 등록하여 사용할 수 없다.

함수 문서화

◆ hangul_keyboard_list_get_count()

unsigned int hangul_keyboard_list_get_count ( )

libhangul에서 제공하는 자판 개수를 구하는 함수

이 함수의 리턴값을 이용해서 자판을 iteration할 수 있다. 한글 자판의 설치 위치에 대한 정보는 한글 키보드 추가 방법 를 참고하라.

반환값
HangulInputContext 에서 선택 가능한 자판 개수

다음에 의해서 참조됨 : hangul_ic_get_n_keyboards().

◆ hangul_keyboard_list_get_keyboard_id()

const char* hangul_keyboard_list_get_keyboard_id ( unsigned  index_)

libhangul에서 제공하는 자판의 id를 구하는 함수

index_ 로 지정된 자판의 id 값을 리턴한다. 이 id는 hangul_ic_select_keyboard() 함수의 인자로 사용하는 문자열이다.

반환값
지정된 자판의 id. 이 문자열은 libhangul 내부에서 관리하는 것으로 free해서는 안된다.

다음에 의해서 참조됨 : hangul_ic_get_keyboard_id().

◆ hangul_keyboard_list_get_keyboard_name()

const char* hangul_keyboard_list_get_keyboard_name ( unsigned  index_)

libhangul에서 제공하는 자판의 이름을 구하는 함수

index_ 로 지정된 자판의 이름을 리턴한다. 이 문자열은 사용자에게 보여주기 위한 것으로, 번역되어 사람이 읽을 수 있는 형태의 문자열이다.

반환값
지정된 자판의 이름. 이 문자열은 libhangul 내부에서 관리하는 것으로 free해서는 안된다.

다음에 의해서 참조됨 : hangul_ic_get_keyboard_name().