• 1나루토매니아
  • 2뱅이
  • 3푸타코타
  • 4완벽그자체
  • 5해삼
  • 1뱅이
  • 2나루토매니아
  • 3알짜배기
  • 4뱅이
  • 5빙그레우유
ZXing 바코드 스캔부분 크기 조절하기.
연속출석 :
1일 랭킹 : 399위 중장7
45%
45% (1541 /3455)
  • 댓글 0 |
  • 추천 0 |
  • 조회 5451 |
  • 2012-08-10 (금) 17:29
    바코드 스캐너 API로 Zxing을 많이들 사용하실거에요.
    가로모드가 기준인데다가 가로 세로 크기를 기준으로 리사이징 하고,
    ImageView를 컨트롤 하는게아니라.
    surfaceView에다가 투명 레이아웃을 drawRect라는것을 4개그려
    중복되지 않는 부분을 캡처하는 방식으로 되어 있어요.
    그래서 이부분을 수정하려면
    총 8곳을 수정해야 되죠.
    수정을 할곳은 ViewfinderView.java라는 파일이 있는 부분인데
    여기서.
    ///comgooglezxingclientandroidViewfinderView.java 입니다.
    91.
    // Draw the exterior (i.e. outside the framing rect) darkened
    paint.setColor(resultBitmap != null ? resultColor : maskColor);
    canvas.drawRect(0, 0, width, frame.top, paint); //가로 윗선
    canvas.drawRect(0, frame.top, frame.left, frame.bottom + 1, paint); //세로 왼쪽선 canvas.drawRect(frame.right + 1, frame.top, width, frame.bottom + 1, paint); //세로 오른쪽선 canvas.drawRect(0, frame.bottom + 1, width, height, paint); //가로 아랫선
    이부분은 화면 전체 뒷배경에 마스크를 씌우는 작업이에요.
    =============
    ==== === 이렇게 검은색으로 칠해진 부분을 처리하는 거죠.
    =============
    canvas.drawRect(0, 0, width, frame.top, paint);
    --->> 이부분은 0,0 < 화면의 가장 최상위의 왼쪽부분을 시작으로 기준점을 잡고
    width < 화면의 최대 가로 길이 입니다.
    frame.top <- 이부분은 사각형의 Y좌표인데. 보통 화면 최대 Y좌표에서 50~60dp
    정도에 위치해 있습니다.
    이부분은 아까 위의 ================== 이부분을 채색하는겁니다.
    그리고 아래 부분은 canvas.drawRect(0, frame.top, frame.left, frame.bottom + 1, paint);
    .left .bottom 이렇게 되어 있는데
    left는 화면기준으로 세로의 길이를 받아옵니다.(Top과 마찬가지로 최대치에서
    50~60dp 정도 의 위치를 기준으로 잡습니다.)
    bottom은 y좌표에서 하단을 가리키며, 이 좌표 역시 가장 하단에서 일정수치
    떨어져잇습니다.
    예를들어 나는 스캔되는 부분을 가로모드 기준으로 반으로 줄이고 싶다.(가로길이를)
    세로 왼쪽/오른쪽선의 위치를 안쪽으로 땡기면 되겠죠?
    frame.left, frame.right가 x좌표가 되므로 이부분을 각각 /2로 줄이고 여기에 늘리고 싶은 만큼의
    픽셀치를 추가합니다. /2가 되면 마스크 크기에서 반정도 줄어드는데, 이게 너무 작다고 느껴지면
    + 픽셀 값을 해주시면됩니다.
    왼쪽은 -값 오른쪽은 +값입니다.
    반대로 세로 크기를 수정하려면 역시 top과 bottom을 수정하시면되고
    여기에도 위쪽값은 -, 아래쪽값은 +가 됩니다.
    103.
    // Draw a two pixel solid black border inside the framing rect
    paint.setColor(frameColor);
    canvas.drawRect(frame.left, frame.top, frame.right + 1, frame.top + 2, paint);
    canvas.drawRect(frame.left, frame.top + 2, frame.left + 2, frame.bottom - 1, paint);
    canvas.drawRect(frame.right - 1, frame.top, frame.right + 1, frame.bottom - 1, paint);
    canvas.drawRect(frame.left, frame.bottom - 1, frame.right + 1, frame.bottom + 1, paint);
    이부분은 안쪽의 스캔되는 영역을 설정하는건데.
    zxing의 스캐너를 잘보시면 스캔되는영역 바깥쪽에 얇은 검은색 선이 있습니다.
    그 선들이 바로 위의 값들이죠. 선처럼 보이지만 사실 사각형을 이어 붙힌 거죠.
    각각의 선들은 위의 마스크들의 값들과 같고.값들도 역시 같습니다.
    주의할점은 선의 굵기인데 크기 조절을 위해 +한다고 하셨을 때 이값들이 경계가 되는 점들에서
    +1~+2정도 차이나게 해주셔야됩니다. 그렇지 않으면 상당히 굵은 선이 생기면서
    그부분을 스켄하지 않게 됩니다.
    110.
    // Draw a red "laser scanner" line through the middle to show decoding is active
    paint.setColor(laserColor);
    paint.setAlpha(SCANNER_ALPHA[scannerAlpha]);
    scannerAlpha = (scannerAlpha + 1) % SCANNER_ALPHA.length;
    int middle = frame.height() / 2 + frame.top;
    canvas.drawRect(frame.left + 2, middle - 1, frame.right - 1, middle + 2, paint);
    이부분은 레이져선... 을 표현하는 부분인데 저는 필요가 없는거 같아서 빼두긴했습니다.
    이부분은 화면을 기준으로 중앙값을 잡고 그 중앙값에 반짝이는 에니메이션이 들어가는
    사각형을 넣습니다. ----------------------이런정도의 굵기의..
    길이변경은 위와 같습니다.
    변경을 하는건 여기까지이고 레이아웃은 이 클레스를 draw 로 받아오기 때문에 따로 수정할건
    없습니다.
    그럼 즐코딩 되시길.


    [이 게시물은 더어플님에 의해 2016-07-12 15:23:56 개발 꿀팁에서 복사 됨]
    댓글을 작성하시려면 로그인을 하셔야지만 작성가능합니다. [로그인하기] [회원가입하기]
    번호 제목 글쓴이 추천 조회 작성일
    188 갤스2 CM9 MOD - 중앙시계 및 상태바 기능 확장 GNCkorea 0 6471 12/08/04
    187 갤럭시S II, 테이크 야누스, 이보 4G+, 아트릭스 - 무선… +2 GNCkorea 1 6402 12/08/01
    186 Android Virtual Device(AVD) 사용법 GNCkorea 1 6381 12/08/09
    185 패턴암호 등 잃어버렸을때 해제하는 방법(팁) GNCkorea 0 6360 12/08/05
    184 스마트빔은 안드로이드빔과 다른 기능인가요? +13 GNCkorea 4 6293 13/03/18
    183 아이폰에서 아이폰 5까지… 한 눈에 보는 요소별 사양 진화 +3 GNCkorea 0 6203 12/09/16
    182 [삼성갤럭시 ]갤럭시 노트의 숨겨진 기능 10가지 (NEW) +6 GNCkorea 3 6016 12/09/16
    181 갤럭시S3 LTE - 동영상 및 전면 카메라 기능 보기 +1 GNCkorea 1 5995 12/07/31
    180 갤럭시S3 번인현상 확인하는 방법 - 단점, 오류, 불량 +1 GNCkorea 1 5947 12/07/31
    179 팬택 스카이 베가 레이서2 - 베가 레이서2에 들어간 스… +2 GNCkorea 2 5563 12/08/01
    178 ZXing 바코드 스캔부분 크기 조절하기. GNCkorea 0 5454 12/08/10
    177 OS X 10.8 마운틴 라이온을 손쉽게 USB 드라이브 또는 D… +1 GNCkorea 1 5358 12/07/27
    176 갤럭시S3 LTE - 그래픽 및 배터리 시간 테스트 +2 GNCkorea 1 5272 12/07/31
    175 아이패드 충전/데이터 케이블 구입시 주의사항 GNCkorea 0 5247 12/08/01
    174 폰의 하드웨어 제어관련 혹은 하드웨어접근관련 앱 제작… GNCkorea 1 5240 12/08/10
    173 이클립스 내에서 안드로이드 제공하는 소스 난독화(ProG… GNCkorea 0 5227 12/08/07
    172 LG 옵티머스 LTE2 - 기기정보 +1 GNCkorea 1 5191 12/07/31
    171 팬택 스카이 베가 레이서2 - 음성인식 기능과 베가 클라… +2 GNCkorea 2 5171 12/08/01
    170 ViewPager의 아이템 얻어오기. GNCkorea 1 5153 12/08/10
    169 스마트폰을 더 스마트하게 사용하는 방법 4가지 +21 GNCkorea 13 5116 13/03/18
    168 윈도우에서 사진스트림 업로드가 안되는 이유와 간단한 … +3 GNCkorea 1 5083 12/07/29
    167 안드로이드 강좌 5 - XML에서의 TextView, ImageView, L… GNCkorea 1 5074 12/08/09
    166 데이터 네트워크(3G, 4G)로 셀프 업그레이드 하는 방법 +14 GNCkorea 5 5044 13/03/18
    165 안드로이드 강좌 4 - 액티비티(Activity), 뷰(View), 레… GNCkorea 1 5022 12/08/09
    164 안드로이드 개발 시, Selector XML을 편하게 만들어봅시… GNCkorea 1 5015 12/08/10
    163 갤럭시S3 LTE SKT 대기상태표기버그 수정본 + 소프트키 … GNCkorea 0 5011 12/08/08
    162 GPS 휴대폰, 활용하는 방법 +15 GNCkorea 4 4967 13/03/18
    161 스마트폰, 구글 기본 서비스 110% 활용하기 +17 GNCkorea 6 4947 13/03/18