간단한 ID(1234, 1235, 1236...)로 수천 개의 QR 코드를 생성해야 하며 이를 사람이 읽을 수 있도록 만들고 싶습니다. qrencode
은 QR 코드를 생성하는 데 매우 유용한 도구이지만 거기에 자막을 추가할 수 있는 방법은 없습니다.
어떤 아이디어가 있나요?
답변1
텍스트가 포함된 이미지를 만들고 이미지에 추가합니다.
#!/bin/bash
txt="$1"
qrencode -o "$txt".png "$txt"
convert -pointsize 36 "label:$txt" "$txt.gif"
convert -append "$txt".png "$txt.gif" "$txt.total.gif"
답변2
Imagemagics가 convert
구출해 드립니다:
- QR 코드 생성
qrencode
(PNG 출력, SVG는 변환에 적합하지 않은 것 같습니다) - 문자열에서 png 이미지 생성
convert
- 이미지 및 변환 첨부
이에 대한 스크립트는 다음과 같습니다.
for i in $(cat ../input.csv); do
qrencode $i -t png -l H -s 10 -o $i.q.png;
convert -size 290x40 xc:white -pointsize 34 -gravity center -font /usr/share/fonts/truetype/dejavu/DejaVuSansMono.ttf -draw "text 0,0 '$i'" $i.s.png;
convert -append $i.q.png $i.s.png $i.png; rm $i.q.png; rm $i.s.png;
echo $i;
done;
DejaVuSansMono.ttf에는 0점이 있어 가독성이 좋고 다른 것들도 있을 수 있습니다. 1과 Little L도 일반적인 용의자들로부터 쉽게 식별할 수 있습니다.
답변3
<text>
svg 형식을 유지하려면 xml을 편집하여 파일 끝에 새 요소를 추가하는 것은 어렵지 않은 것 같습니다. 나는 표준 방식으로 이 작업을 수행할 만큼 svg를 잘 모르지만 svg 편집기를 사용하여 텍스트 줄을 추가할 때 파일이 어떻게 보이는지 보려면 awk
제공한 예제에 다음 스크립트로 충분할 수 있습니다.
i=1234
qrencode "$i" -t svg -l H -s 10 -o "$i.q.svg.orig"
awk <"$i.q.svg.orig" >"$i.q.svg" -v txt="$i" '
/<svg /{ match($0,"height=\"([0-9.]+)",grp)
ht = grp[1]*1.1
ht = "height=\"" ht
sub("height=\"([0-9.]+)",ht,$0)
match($0,"viewBox=\"0 0 ([0-9]+) ([0-9]+)",grp)
vb = int(grp[2]*1.1+.5)
x = int(grp[1]/2+.5)
y = grp[2]+1
vb = "viewBox=\"0 0 " grp[1] " " vb
sub("viewBox=\"0 0 ([0-9]+) ([0-9]+)",vb,$0)
}
/<rect x="0" /{
match($0,"height=\"([0-9.]+)",grp)
ht = int(grp[1]*1.1+.5)
ht = "height=\"" ht
sub("height=\"([0-9.]+)",ht,$0)
}
/<\/svg>/{
printf " <text font-family=\"Helvetica, sans-serif\" font-size=\"6\" stroke-width=\"0\" text-anchor=\"middle\" x=\"%d\" y=\"%d\" xml:space=\"preserve\">%s</text>",x,y,txt
}
{print}
'
좀 더 일반화하기 위해서는 실제로 필요한 것보다 더 복잡합니다.
초기값을 취해 <svg width="10.23cm" height="10.23cm" viewBox="0 0 29 29" ...
높이와 네 번째 viewBox 값을 10% 확대하여 가 됩니다 <svg width="10.23cm" height="11.23cm" viewBox="0 0 29 33" ...
.
그런 다음 배경의 흰색 직사각형을 가져오고 비슷한 방식으로 높이를 에서 로 늘 <rect ... height="29"
립니다 <rect ... height="33"
.
마지막으로 <text...>
viewBox에서 찾은 값을 x 및 y 위치로 사용하여 끝에 선을 추가합니다. text-anchor="middle"
텍스트는 이 좌표의 중앙에 위치합니다.