web-dev-qa-db-ja.com

ロゴ付きのQRコードを生成するにはどうすればよいですか?

Androidデバイス用のアプリケーションを開発しています。ロゴが入ったQRコードを生成したいと思います。

ZXingを使用すると、次のような単純なQRコードを生成する方法を知っています: Original

しかし、ロゴが入ったQRコードを生成したいと思います。だから私はこのようなものを手に入れたいです: With Logo

それを行う方法はありますか?どうしたらいいのかわからない。私を手伝ってくれますか?いくつかの準備ができたライブラリまたはそれを行う方法の例があるかもしれません。

ありがとうございました!

7

あなたはそれとしてあなたのロゴを追加することができます 画像オーバーレイ お気に入り

public BufferedImage getQRCodeWithOverlay(BufferedImage qrcode) 
{
    BufferedImage scaledOverlay = scaleOverlay(qrcode);

    Integer deltaHeight = qrcode.getHeight() - scaledOverlay.getHeight();
    Integer deltaWidth  = qrcode.getWidth()  - scaledOverlay.getWidth();

    BufferedImage combined = new BufferedImage(qrcode.getWidth(), qrcode.getHeight(), BufferedImage.TYPE_INT_ARGB);
    Graphics2D g2 = (Graphics2D)combined.getGraphics();
    g2.drawImage(qrcode, 0, 0, null);
    g2.setComposite(AlphaComposite.getInstance(AlphaComposite.SRC_OVER, overlayTransparency));
    g2.drawImage(scaledOverlay, Math.round(deltaWidth/2), Math.round(deltaHeight/2), null);
    return combined;
}

private BufferedImage scaleOverlay(BufferedImage qrcode)
{
    Integer scaledWidth = Math.round(qrcode.getWidth() * overlayToQRCodeRatio);
    Integer scaledHeight = Math.round(qrcode.getHeight() * overlayToQRCodeRatio);

    BufferedImage imageBuff = new BufferedImage(scaledWidth, scaledHeight, BufferedImage.TYPE_INT_ARGB);
    Graphics g = imageBuff.createGraphics();
    g.drawImage(overlay.getScaledInstance(scaledWidth, scaledHeight, BufferedImage.SCALE_SMOOTH), 0, 0, new Color(0,0,0), null);
    g.dispose();
    return imageBuff;
}

詳細については、これを参照してください postgithub

7
Let'sRefactor

次のKotlinExtentionを作成しました。これは、別のビットマップの中心にビットマップを追加します。

fun Bitmap.addOverlayToCenter(overlayBitmap: Bitmap): Bitmap {

    val bitmap2Width = overlayBitmap.width
    val bitmap2Height = overlayBitmap.height
    val marginLeft = (this.width * 0.5 - bitmap2Width * 0.5).toFloat()
    val marginTop = (this.height * 0.5 - bitmap2Height * 0.5).toFloat()
    val canvas = Canvas(this)
    canvas.drawBitmap(this, Matrix(), null)
    canvas.drawBitmap(overlayBitmap, marginLeft, marginTop, null)
    return this
}

見つけることができます ここで私の完全な解決策

0
Spipau