• 1나루토매니아
  • 2뱅이
  • 3푸타코타
  • 4완벽그자체
  • 5해삼
  • 1뱅이
  • 2나루토매니아
  • 3알짜배기
  • 4뱅이
  • 5빙그레우유
ZXing 바코드 스캔부분 크기 조절하기.
연속출석 :
1일 랭킹 : 399위 중장7
45%
45% (1541 /3455)
  • 댓글 0 |
  • 추천 0 |
  • 조회 5360 |
  • 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 개발 꿀팁에서 복사 됨]
    댓글을 작성하시려면 로그인을 하셔야지만 작성가능합니다. [로그인하기] [회원가입하기]
    번호 제목 글쓴이 추천 조회 작성일
    공지글 이거슨 꿀팁!! 작성 가이드 v1.1 (2013-11-13) +174 더어플 42 134697 13/03/12
    4455 알뜰폰 1Mbps 3Mbps 무제한요금제 최저가2개 iamgood 0 109 24/05/03
    4454 알뜰폰 쓸 때 인터넷과 결합하려면 iamgood 0 1835 24/04/15
    4453 해외여행 갈 때 데이터로밍 간편하고 싸게 쓰는방법 iamgood 0 2201 24/04/08
    4452 기프티콘은 컬쳐랜드 쿠폰거래소에서 이용하는 게 좋아요 리메인2 0 2305 24/04/05
    4451 클리오 루즈힐 블룸 다이아 립스틱 5종 홈쇼핑 예정 리하린 0 2596 24/04/03
    4450 데이터 10GB+1Mbps 무제한 6,500원부터 쓸수있네요 iamgood 0 2641 24/04/01
    4449 3월 알뜰폰 가성비 평생요금제 2가지 6GB 6천원과 10GB … iamgood 0 3487 24/03/18
    4448 컬쳐랜드에 쿠폰거래소가 새롭게 생겼어요 리하린 0 3909 24/03/12
    4447 3Mbps 속도 데이터무제한 최저가 검색 iamgood 0 3992 24/03/11
    4446 컬쳐랜드로 호텔 예약하면 좀 더 싸게 갈 수 있어요 리하린 0 4724 24/02/27
    4445 해외여행 데이터로밍 일본 태국 대만 최저가보장 iamgood 0 5138 24/02/19
    4444 기간통신사가 운영하는 데이터센터 MDC iamgood 0 4721 24/02/13
    4443 밀리의서재 무료 구독권 kt알뜰폰 2,200원 무제한요금제 iamgood 0 4897 24/02/02
    4442 KT 갤럭시S24 사전예약(~1/25) 라이브컬러 0 5344 24/01/25
    4441 LG유플러스 인터넷 결합 가능한 알뜰폰 iamgood 0 5368 24/01/18
    4440 데이터 20GB 추가제공이벤트 좋네요 iamgood 0 5883 24/01/08
    4439 1월 추천요금제 데이터 6기가0원과 데이터무제한 6,600… iamgood 0 5623 24/01/02
    4438 아이폰 쓰면 해외여행때 굳이 현지유심 쓸 필요없어요 iamgood 0 6835 23/12/11
    4437 넷플릭스 광고형 스탠다드 KT결제 매달 1,000원 할인 달팽ee 0 6619 23/12/11
    4436 데이터10기가 990원부터 3Mbps무제한 9,000원 iamgood 0 6907 23/12/01
    4435 아싸컴에서 천만원 이벤트 하는 거 찾았다 +1 리하린 1 7154 23/11/20
    4434 skt망 알뜰 통화 데이터 무제한 요금 7개월 5,500원부터 iamgood 0 6802 23/11/15
    4433 우체국에서 판매1위했던 알뜰폰 요금제 iamgood 0 6915 23/11/08
    4432 알리익스프레스 프로모션 기대해보세요! 최대 50% 할인! 베스토 0 6300 23/11/04
    4431 통화 데이터무제한 7개월할인 최저가 13,000원 iamgood 0 6197 23/11/02
    4430 알뜰폰 데이터10GB 12개월간 무약정 990원 iamgood 0 6273 23/10/24
    4429 스마트폰 평생 2,000원 요금제와 태블릿전용 6,560원요… iamgood 0 5993 23/10/16
    4428 skt 알뜰폰 무제한 요금제 3종 2,200원부터 1,000명 한… iamgood 0 5421 23/10/11