android:pdfdocument:multiline
multiline
차이
문서의 선택한 두 판 사이의 차이를 보여줍니다.
다음 판 | 이전 판 | ||
android:pdfdocument:multiline [2024/12/12 00:43] – 만듦 이거니맨 | android:pdfdocument:multiline [2024/12/14 00:42] (현재) – 세로로쓰기 이거니맨 | ||
---|---|---|---|
줄 3: | 줄 3: | ||
다음과 같이 긴 글을 지정된 너비에 맞추어 여러 줄로 쓰게 하는 기능을 구현할 것이다. | 다음과 같이 긴 글을 지정된 너비에 맞추어 여러 줄로 쓰게 하는 기능을 구현할 것이다. | ||
+ | {{: | ||
- | + | ===== 여러 줄(Multi line) ===== | |
- | ===== 코드 | + | |
다음이 전체 코드이다. | 다음이 전체 코드이다. | ||
줄 25: | 줄 25: | ||
} | } | ||
+ | </ | ||
+ | |||
+ | ==== 1. static layout === | ||
+ | |||
+ | === 가. obtain === | ||
+ | obtatin 함수는 다음과 같이 인자를 받는다. | ||
+ | |||
+ | <code java> | ||
+ | obtain(CharSequence source, int start, int end, TextPaint paint, int width) | ||
</ | </ | ||
+ | |||
+ | 첫번째는 텍스트, 두번째 시작하는 문자, 세번째는 끝나는 문자의 위치, 네번째는 페인터, 마지막은 레이아웃의 너비이다. | ||
+ | |||
+ | 여기서 페인터는 통상읜 Paint가 아니라 TextPaint임을 유의하자. TextPaint는 Paint를 상속받으므로, | ||
+ | |||
+ | 기존에 Paint로 선언했다면, | ||
+ | |||
+ | obtain함수에서 글자를 그릴 너비를 받아서, 이 너비 이상이 되면 줄 바뀜을 하게 해준다. | ||
+ | |||
+ | === 나. setAlignment === | ||
+ | |||
+ | 글자를 정렬하는 것이다. Layout.Alignment를 | ||
+ | |||
+ | 디폴트값은 디폴트 값은 Layout.Alignment# | ||
+ | |||
+ | 각각 다음과 같다. | ||
+ | |||
+ | * ALIGN_NORMAL : 왼쪽 정렬 | ||
+ | * ALIGN_CENTER : 가운데 정렬 | ||
+ | * ALIGN_OPPOSITE : 오른쪽 정렬 | ||
+ | |||
+ | |||
+ | {{: | ||
+ | |||
+ | 위 그림은 다음의 코드를 이용하여 구현하였다. | ||
+ | |||
+ | == (1) 구현 함수 == | ||
+ | |||
+ | <code kotlin> | ||
+ | fun bodyText(text : String, canvas: Canvas, layout : Layout.Alignment) { | ||
+ | |||
+ | val textLayout = StaticLayout.Builder.obtain(text, | ||
+ | .setAlignment(layout) | ||
+ | .setLineSpacing(0f, | ||
+ | .setIncludePad(true).build() | ||
+ | |||
+ | canvas.save() | ||
+ | canvas.translate(50f, | ||
+ | textLayout.draw(canvas) | ||
+ | canvas.restore() | ||
+ | |||
+ | currentPOS.Y+= textLayout.height + 20 | ||
+ | } | ||
+ | </ | ||
+ | |||
+ | == (2) 호출함수 == | ||
+ | |||
+ | <code kotlin> | ||
+ | pdfUtil.headerText(" | ||
+ | pdfUtil.bodyText(" | ||
+ | |||
+ | |||
+ | pdfUtil.headerText(" | ||
+ | pdfUtil.bodyText(" | ||
+ | " | ||
+ | |||
+ | pdfUtil.headerText(" | ||
+ | pdfUtil.bodyText(" | ||
+ | " | ||
+ | </ | ||
+ | |||
+ | === 다. setLineSpacing === | ||
+ | |||
+ | public StaticLayout.Builder setLineSpacing (float spacingAdd, float spacingMult) | ||
+ | |||
+ | 첫번째 인자는 추가할 라인의 갯수이고, | ||
+ | |||
+ | |||
+ | === 라. setIncludePad === | ||
+ | |||
+ | [[android: | ||
+ | |||
+ | {{: | ||
+ | |||
+ | ==== 2. canvas ==== | ||
+ | |||
+ | 위와 같은 레이아웃(layout)을 이용하려면 우선 기존 canvas를 save해야 한다. | ||
+ | |||
+ | 그 다음에 layout를 위치할 자리를 cavas.translate로 정한다. | ||
+ | |||
+ | 그 다음에 canvas를 restore하면, | ||
+ | |||
+ | canvas를 restore한 다음에는 다시 기존 canvas의 좌표계로 돌아올 것이다. | ||
+ | |||
+ | 그런데 layout의 경우에는 height와 | ||
+ | |||
+ | layout으로 출력한 여러 줄의 문장의 아래 위치는 다시 기존 canvas의 절대좌표로 지정할 수 있다. | ||
+ | |||
+ | 이런 식으로 지정이 가능하다. | ||
+ | |||
+ | <code kotlin> | ||
+ | currentPOS.Y+= textLayout.height + 20 | ||
+ | </ | ||
+ | |||
+ | ===== 회전 ===== | ||
+ | |||
+ | 위의 | ||
+ | |||
+ | 이런식으로 말이다. | ||
+ | |||
+ | |||
+ | |||
+ | {{: | ||
+ | |||
+ | |||
+ | ===== 세로로 쓰기 ===== | ||
+ | |||
+ | ==== 1. 개요 ==== | ||
+ | |||
+ | 글자를 세로로 쓰는 방법은 (1) 한 글자씩 루프를 돌린 후에 각 글자의 y축을 바꿔주는 방법 (2) 위의 staticLayout의 폭을 한 글자에 맞추는 방법을 생각할 수 있다. | ||
+ | |||
+ | staticLayout 개념을 연습하는김에 세로로 쓰기를 해보자 | ||
+ | |||
+ | |||
+ | ==== 2. 글자의 폭 계산 ==== | ||
+ | |||
+ | 글자는 각기 폭이 다르다.물론 한글의 경우 거의 대부분의 폭이 같을 것이나 반드시 장담할 수는 없다. 따라서 어떠한 문장 중에서 글자들은 제각기 폭이 다를 것이다. 따라서 안드로이드 API는 getTextWidths()라는 함수를 제공한다. 이를 통해 가장 긴 폭을 가진 글자의 폭을 반환받을 수 있다. | ||
+ | |||
+ | <code kotlin> | ||
+ | // 문장 중에서 가장 너비가 큰 글자의 너비 구하기 | ||
+ | private fun getCharWidth(text : String, textPaint: TextPaint) : Float { | ||
+ | |||
+ | var maxWidth = 0f | ||
+ | |||
+ | val w = FloatArray(text.length) | ||
+ | cellBodyLeft.getTextWidths(text, | ||
+ | w.forEach { | ||
+ | if (maxWidth < it) { | ||
+ | maxWidth = it | ||
+ | } | ||
+ | } | ||
+ | |||
+ | return | ||
+ | } | ||
+ | </ | ||
+ | |||
+ | ==== 3. 텍스트 레이아웃의 폭을 지정하기 ==== | ||
+ | |||
+ | 다음과 같이 가장 긴 글자의 폭을 | ||
+ | |||
+ | <code kotlin> | ||
+ | fun verticalTxt(text : String, canvas: Canvas) { | ||
+ | |||
+ | val cWidth = getCharWidth(text, | ||
+ | |||
+ | val textLayout = StaticLayout.Builder.obtain(text, | ||
+ | .setLineSpacing(0f, | ||
+ | |||
+ | canvas.save() | ||
+ | canvas.translate(100f, | ||
+ | |||
+ | textLayout.draw(canvas) | ||
+ | canvas.restore() | ||
+ | |||
+ | currentPOS.Y+= textLayout.height + 20 | ||
+ | } | ||
+ | |||
+ | </ | ||
+ | |||
+ | {{: |
android/pdfdocument/multiline.1733931830.txt.gz · 마지막으로 수정됨: 2024/12/12 00:43 저자 이거니맨