Overview
광복절을 기념해서 Flutter로 태극기를 그려봤다. (Repository)
태극기 도면을 참고했고, CustomPaint
를 사용했다.
깃면 그리기
- 태극기 깃면의 가로:세로 비율은 3:2이므로,
AspectRatio
로 3:2 비율의 widget을 만든다. DecoratedBox
를 사용해서 border를 그려준다.AspectRatio
의child
에LayoutBuilder
를 사용해서CustomPaint
의 size를 깃면 size로 설정한다.CustomPaint
는 이 수치를 기반으로 태극 문양과 괘의 layout을 계산한다.
태극 문양 그리기
태극 문양은 아래 두 단계에 걸쳐 그릴 수 있다.
- 빨간색과 파란색 반으로 나뉜 원을 그린다.
- 반지름을 지름으로 하는 빨간색, 파란색 원을 왼쪽, 오른쪽에 덮어서 그린다.
이 때, 빨간색과 파란θ색 반원은 태극기의 왼쪽 위 모서리와 오른쪽 아래 모서리로 그어지는 대각선으로 나뉜다. 따라서, drawArc로 반원을 그릴 때 시작 각도(startAngle
)는 0과 pi
에서 이 대각선의 내각을 더한 위치가 된다. 태극기의 절반인 직각 삼각형에서 밑변과 높이를 알고 있으므로, 내각은 아래와 같이 계산할 수 있다.
$\theta = \arctan(\frac{b}{a})$
위 공식에 따라 atan()
함수를 사용해서 내각을 구하고, Canvas.drawArc
에서 startAngle
에 이 내각을 더해주면 아래와 같이 그려진다.
class TaegukgiPainter extends CustomPainter {
@override
void paint(Canvas canvas, Size size) {
final angle = atan(size.height / size.width);
...
canvas.drawArc(rect, angle, pi, false, bluePaint);
canvas.drawArc(rect, pi + angle, pi, false, redPaint);
}
}
다음으로, 대각선을 축으로 하고 그려진 원의 반지름을 지름으로 하는 빨간색, 파란색 반원을 그려준다.
각 원의 색상이 기존 색상을 덮어쓰면서 아래와 같이 태극 모양으로 보이게 된다.
괘 그리기
괘는 태극기를 가로지르는 대각선에 수직 방향으로 그려진다. 위에서 계산한 대각선 사잇각과 직각 삼각형의 성질을 이용해서 아래와 같이 괘의 중심점과 양 끝점을 계산할 수 있다.
괘의 각 line의 center 좌표를 계산한 뒤, center에서 좌우로 떨어져 있는 두 point를 계산하여 drawLine으로 괘를 그려준다. 괘의 line 길이, 두께, line 간격 등을 모두 알고 있으므로 for문을 이용해서 3줄의 line을 같은 방법으로 그려준다. 아래는 곤괘를 그리는 예시이다.
괘를 그리는 전체 코드는 여기에서 확인할 수 있다.
후기
- 광복절을 맞아 태극기를 직접 그려보면서 태극기가 어떻게 구성되어 있고 어떤 수치로 그려지는지 자세하게 알아볼 수 있어서 흥미로웠다.
- 특히, 태극기에서 각 괘를 부르는 호칭과 각 괘의 위치를 정확하게 알 수 있는 좋은 기회였다.
CustomPaint
를 사용해서 비정형 UI를 그리는 것에 더 익숙해 질 수 있었다.