비트맵 데이타를 축소혹은 확대할수 있는 알고리즘에 대해 궁금
다음과 같은 비트맵데이타를 어떤 알고리즘을 사용하면
확대 또는 축소할수 있는지 궁금합니다.
예를 들면,
char A[60] = {
0x00, 0x00, 0x00,
0x03, 0x00, 0x00,
0x03, 0x00, 0x00,
0x07, 0x80, 0x00,
0x07, 0x80, 0x00,
0x07, 0x80, 0x00,
0x0c, 0xc0, 0x00,
0x0c, 0xc0, 0x00,
0x1c, 0xe0, 0x00,
0x18, 0x60, 0x00,
0x1f, 0xe0, 0x00,
0x3f, 0xf0, 0x00,
0x30, 0x30, 0x00,
0x70, 0x38, 0x00,
0x60, 0x18, 0x00,
0x60, 0x18, 0x00,
0x00, 0x00, 0x00,
0x00, 0x00, 0x00,
0x00, 0x00, 0x00,
0x00, 0x00, 0x00
};
위의 데이타를 한라인당 3바이트씩 찍어보면 다음과 같습니다.
('-'는 빈공간입니다.)
------------------------
------##----------------
------##----------------
-----####---------------
-----####---------------
-----####---------------
----##--##--------------
----##--##--------------
---###--###-------------
---##----##-------------
---########-------------
--##########------------
--##------##------------
-###------###-----------
-##--------##-----------
-##--------##-----------
------------------------
------------------------
------------------------
------------------------
위의 데이타를 축소하고 싶은데, 어떻게 해야할가요??
그래픽 라이브러는 사용불가한 상황입니다.
image processing
http://vision.inchon.ac.kr/ipa/ipa09.php
추천 검색어 "image processing" "보간법" "vision 확대 축소" 등 찾아보시면 간단한 예제들이 꽤 많이 있을겁니다.
발 담갔다. 이제 익숙해 지는길만이..
좀 엽기적이긴 하지만,
좀 엽기적이긴 하지만
실행해 보니
g1.gz의 용량이 85바이트 나왔습니다.
헤헤...
앞의 0x빼고 다 2글자니 컴마 빼버리고,
해보면 67바이트 나옵니다.
No Pain, No Gain.
답변해주셔셔 감사합니다.
제가 질문의 요지를 잘못 말한것 같네요.
데이타 자체의 크기를 줄이는것이 아니고,
'A'라는 글자자체의 크기를 축소하는것인데 제가 잘못 말했네요.
음..잘 안되네요...
열씨미!
Re: 답변해주셔셔 감사합니다.
beta 님께서 링크해주신 문서를 참조하시면 됩니다.
보니까 최적화된 루틴은 아니지만, bilinear interpolation 까지
망라돼 있는 문서네요.
그런데 지금 예로 제시한 문자 비트맵을 확대,축소하는 경우,
문자를 잘 알아보기 어렵게 될 수 있습니다. 목적이 문자를
확대 축소하는 것이면, 트루타입 폰트처럼 확대 축소가
자유롭도록 구현하는 것이 필요할 수도 있죠.
Orion Project : http://orionids.org
댓글 달기