android:pdfdocument:measuringparagraph
measuringparagraph
차이
문서의 선택한 두 판 사이의 차이를 보여줍니다.
양쪽 이전 판이전 판다음 판 | 이전 판 | ||
android:pdfdocument:measuringparagraph [2024/12/07 21:50] – 이거니맨 | android:pdfdocument:measuringparagraph [2024/12/09 23:31] (현재) – 이거니맨 | ||
---|---|---|---|
줄 147: | 줄 147: | ||
위의 getTextBounds를 통해 다음과 같이 상자와 선을 그려 보았다. | 위의 getTextBounds를 통해 다음과 같이 상자와 선을 그려 보았다. | ||
+ | === 가. 상자와 선을 그리는 함수 === | ||
+ | 다음과 같이 상자와 선을 그리는 함수를 만들었다. | ||
- | 아래 그림은 각각 김정철명조체와 고령딸기체로 그린 글자에 대하여 경계썬을 나타낸 것이다. | + | <code kotlin> |
+ | // Text with underline, rectangle, outline | ||
+ | fun richText(text : String, canvas: Canvas, switch : String) { | ||
+ | title.setTypeface(fontStrawberry) | ||
+ | title.color = ContextCompat.getColor(context, | ||
+ | title.textSize = 16f | ||
+ | title.textAlign = Paint.Align.LEFT | ||
- | {{: | + | // Draw Text |
+ | canvas.drawText(text, | ||
+ | // Font Effect | ||
+ | when (switch) { | ||
+ | " | ||
+ | val bounds = Rect() | ||
+ | title.getTextBounds(text, | ||
+ | val rc = Rect(currentPOS.X, | ||
+ | canvas.drawRect(rc, | ||
+ | } | ||
+ | " | ||
+ | val bounds = Rect() | ||
+ | title.getTextBounds(text, | ||
+ | canvas.drawLine(currentPOS.X.toFloat(), | ||
+ | canvas.drawText(" | ||
+ | } | ||
+ | " | ||
+ | val bounds = Rect() | ||
+ | title.getTextBounds(text, | ||
+ | canvas.drawLine(currentPOS.X.toFloat(), | ||
+ | |||
+ | canvas.drawText(" | ||
+ | } | ||
+ | " | ||
+ | val bounds = Rect() | ||
+ | title.getTextBounds(text, | ||
+ | canvas.drawLine(currentPOS.X.toFloat(), | ||
+ | |||
+ | canvas.drawText(" | ||
+ | } | ||
+ | |||
+ | } | ||
+ | |||
+ | } | ||
+ | </ | ||
+ | |||
+ | getTextBounds에서 top과 bottom, 그리고 줄의 높이인 height()가 어떻 결과값을 나타내는지 확인하게 만들었다. | ||
+ | |||
+ | |||
+ | === 나. 호출하기 === | ||
+ | |||
+ | |||
+ | 다음과 같이 호출하였다. | ||
+ | |||
+ | <code kotlin> | ||
+ | // 상자만들기 | ||
+ | pdfUtil.linefeed() | ||
+ | pdfUtil.titleText(" | ||
+ | |||
+ | pdfUtil.space() | ||
+ | // 선을 그리기 | ||
+ | pdfUtil.linefeed() | ||
+ | pdfUtil.richText(" | ||
+ | |||
+ | pdfUtil.linefeed() | ||
+ | pdfUtil.richText(" | ||
+ | |||
+ | pdfUtil.linefeed() | ||
+ | pdfUtil.richText(" | ||
+ | |||
+ | pdfUtil.linefeed() | ||
+ | pdfUtil.richText(" | ||
+ | |||
+ | pdfUtil.linefeed() | ||
+ | pdfUtil.richText(" | ||
+ | |||
+ | pdfUtil.linefeed() | ||
+ | pdfUtil.richText(" | ||
+ | |||
+ | </ | ||
+ | |||
+ | |||
+ | 아래 그림은 각각 [[http:// | ||
+ | |||
+ | |||
+ | ^ 고령딸기체 | ||
+ | | {{: | ||
+ | |||
+ | |||
+ | LineHeight()로 줄의 높이를 정하는게 가장 시인성 있는 것을 알 수 있다. 따라서 앞으로는 이를 기준으로 글자의 높이를 정하겠다. | ||
+ | |||
+ | |||
+ | ===== 결론 ===== | ||
+ | |||
+ | ==== 1. Rich Text ==== | ||
+ | |||
+ | 다음과 같이 Rich Text를 구현할 수 있다. | ||
+ | |||
+ | <code kotlin> | ||
+ | // Text with underline, rectangle, outline, shadow | ||
+ | fun richText(text : String, canvas: Canvas, switch : String) { | ||
+ | title.setTypeface(fontKJCMyungjo) | ||
+ | title.color = ContextCompat.getColor(context, | ||
+ | title.textSize = 16f | ||
+ | title.textAlign = Paint.Align.LEFT | ||
+ | |||
+ | // Font Effect | ||
+ | when (switch) { | ||
+ | " | ||
+ | // Draw Text | ||
+ | canvas.drawText(text, | ||
+ | |||
+ | val bounds = Rect() | ||
+ | title.getTextBounds(text, | ||
+ | val offset = 2 | ||
+ | val rc = Rect(currentPOS.X - offset, currentPOS.Y - bounds.height() + offset, currentPOS.X + bounds.right + offset, currentPOS.Y + bounds.bottom + offset) | ||
+ | |||
+ | canvas.drawRect(rc, | ||
+ | } | ||
+ | " | ||
+ | // Draw Text | ||
+ | canvas.drawText(text, | ||
+ | val bounds = Rect() | ||
+ | title.getTextBounds(text, | ||
+ | val offset = 2f | ||
+ | canvas.drawLine(currentPOS.X.toFloat() - offset, currentPOS.Y.toFloat() + bounds.bottom + offset, currentPOS.X + bounds.right.toFloat() + offset, currentPOS.Y + bounds.bottom + offset, linePaint) | ||
+ | |||
+ | canvas.drawText(" | ||
+ | } | ||
+ | " | ||
+ | // Draw Text | ||
+ | canvas.drawText(text, | ||
+ | |||
+ | val bounds = Rect() | ||
+ | title.getTextBounds(text, | ||
+ | val offset = 2f | ||
+ | canvas.drawLine(currentPOS.X.toFloat() - offset, currentPOS.Y.toFloat() - (bounds.height() / 2).toFloat() + bounds.bottom, | ||
+ | |||
+ | canvas.drawText(" | ||
+ | } | ||
+ | " | ||
+ | // draw outline of text | ||
+ | title.style = Paint.Style.FILL_AND_STROKE | ||
+ | title.strokeWidth = 1f | ||
+ | title.color = ContextCompat.getColor(context, | ||
+ | |||
+ | canvas.drawText( text, currentPOS.X.toFloat(), | ||
+ | } | ||
+ | " | ||
+ | // draw outline of text | ||
+ | title.style = Paint.Style.STROKE | ||
+ | title.strokeWidth = 0.5f | ||
+ | title.color = ContextCompat.getColor(context, | ||
+ | |||
+ | canvas.drawText( text, currentPOS.X.toFloat(), | ||
+ | } | ||
+ | " | ||
+ | title.style = Paint.Style.FILL | ||
+ | title.strokeWidth = 1f | ||
+ | title.setShadowLayer(1f, | ||
+ | canvas.drawText( text, currentPOS.X.toFloat(), | ||
+ | } | ||
+ | |||
+ | } | ||
+ | |||
+ | } | ||
+ | |||
+ | </ | ||
+ | |||
+ | |||
+ | ==== 2. 예시 ==== | ||
+ | |||
+ | 위의 글자꾸미기는 다음과 같이 PDF로 인쇄된다. | ||
+ | |||
+ | {{: | ||
+ | |||
+ | |||
+ | <code kotlin> | ||
+ | pdfUtil.space() | ||
+ | // 선을 그리기 | ||
+ | pdfUtil.linefeed() | ||
+ | pdfUtil.richText(" | ||
+ | |||
+ | pdfUtil.linefeed() | ||
+ | pdfUtil.richText(" | ||
+ | |||
+ | pdfUtil.linefeed() | ||
+ | pdfUtil.richText(" | ||
+ | |||
+ | pdfUtil.linefeed() | ||
+ | pdfUtil.richText(" | ||
+ | |||
+ | pdfUtil.linefeed() | ||
+ | pdfUtil.richText(" | ||
+ | |||
+ | pdfUtil.linefeed() | ||
+ | pdfUtil.richText(" | ||
+ | |||
+ | </ |
android/pdfdocument/measuringparagraph.1733575811.txt.gz · 마지막으로 수정됨: 2024/12/07 21:50 저자 이거니맨