專業二維碼生成器
在瀏覽器本地生成二維碼,支援樣式(形狀/定位點)、漸變、Logo、外框與分享。資料不上傳,永久免費、無水印。
永久免費
無水印
純本地生成
PNG / SVG
使用方法
- 選擇類型(URL、文本、WiFi、vCard、短信、郵件),輸入或貼上內容
- 調整尺寸、邊距、顏色、糾錯級別,以及樣式(形狀/定位點)、漸變、Logo、外框等
- 選擇 PNG 或 SVG 格式
- 二維碼將自動生成;準備就緒後可“下載”或“複製”
- 使用 Logo 或複雜樣式時,建議將糾錯提升至 H,並預留足夠的安靜區(空白邊)
- 用於印刷/展示時,保證前景-背景高對比,避免過小尺寸及過度失真
功能特性
- 純前端生成(不上傳)
- 支援 PNG 與 SVG 輸出
- 樣式可自訂:形狀、定位點、圓角、間隙
- 漸變(多色、多方向)
- Logo 疊加(可選自動提升糾錯級別)
- 外框與描邊(圓角卡片風格)
- 分享與剪貼簿(連結/圖片)
- 多語言與主題支援
什麼是定位點(Finder)?
二維碼四角中的三個大方塊叫做 定位點(Finder),用於幫助相機快速找到二維碼的位置與角度,從而實現糾偏與解碼。它們通常是黑白相間的 7×7 模組結構(外黑、內白、中心黑)。
- 作用:快速定位、抗旋轉、抗透視。
- 樣式:本工具支援方形、圓角以及“圓點風格”的定位點渲染(樣式 → Finder 中選擇)。
二維碼是誰發明的?
二維碼(QR Code)由日本 Denso Wave 公司的工程師 原昌宏(Masahiro Hara) 於 1994 年發明。QR 是 “Quick Response(快速回應)” 的縮寫。
- 發明動機:提升汽車零部件生產線的識別效率,突破一維碼容量與讀取速度的限制。
- 設計靈感:圍棋黑白棋子與矩陣圖案,啟發了“模組化 + 定位圖形”的高魯棒設計。
- 為何不用付專利費:Denso Wave 持有商標與部分專利,但明確免費開放使用,以促進生態普及(支援商用,不收授權費)。
標準規範與使用建議
- 國際標準:ISO/IEC 18004(QR Code 2D 符號規範),定義版本、遮罩、糾錯、圖形結構等。
- 容錯等級:L/M/Q/H 四級(約 7%/15%/25%/30% 可恢復),Logo 疊加建議使用更高等級。
- 編碼內容:文本、URL、vCard、Wi‑Fi 等,建議遵循相應 URI/數據格式規範(如
WIFI:T:WPA;S:SSID;P:PASS;;)。 - 印刷與顯示:保證前景/背景對比與安靜區大小;避免過度失真、過小尺寸與過密紋理干擾。
- 可存取性:關鍵場合建議提供備用文本/連結,避免僅以二維碼作為唯一入口。
透過程式語言生成二維碼
下面給出常用語言的最簡示例,適合入門與腳手架使用:
JavaScript(Node/Browser)
// Node: npm i qrcode
const QRCode = require('qrcode');
QRCode.toFile('qrcode.png', 'https://example.com', { errorCorrectionLevel: 'M' });
// Browser (Canvas):
// <script src="https://cdn.jsdelivr.net/npm/[email protected]/lib/browser.min.js"></script>
QRCode.toCanvas(document.getElementById('canvas'), 'Hello QR', { width: 256 });
Python
# pip install qrcode[pil]
import qrcode
img = qrcode.make('https://example.com')
img.save('qrcode.png')
PHP
// composer require endroid/qr-code
use Endroid\QrCode\QrCode;
use Endroid\QrCode\Writer\PngWriter;
$qr = QrCode::create('https://example.com');
$writer = new PngWriter();
$result = $writer->write($qr);
$result->saveToFile(__DIR__.'/qrcode.png');
Go
// go get -u github.com/skip2/go-qrcode
package main
import "github.com/skip2/go-qrcode"
func main() {
qrcode.WriteFile("https://example.com", qrcode.Medium, 256, "qrcode.png")
}
Java
// Maven: com.google.zxing:core, com.google.zxing:javase
// Minimal ZXing example
import com.google.zxing.BarcodeFormat;
import com.google.zxing.common.BitMatrix;
import com.google.zxing.qrcode.QRCodeWriter;
import com.google.zxing.client.j2se.MatrixToImageWriter;
import java.awt.image.BufferedImage;
import java.io.File;
import javax.imageio.ImageIO;
public class Main {
public static void main(String[] args) throws Exception {
QRCodeWriter writer = new QRCodeWriter();
BitMatrix matrix = writer.encode("https://example.com", BarcodeFormat.QR_CODE, 256, 256);
BufferedImage image = MatrixToImageWriter.toBufferedImage(matrix);
ImageIO.write(image, "png", new File("qrcode.png"));
}
}
Rust
// Cargo.toml
// qrcode = "0.13"
// image = "0.24"
use qrcode::QrCode;
use image::Luma;
fn main() {
let code = QrCode::new("https://example.com").unwrap();
let image = code.render<Luma<u8>>().min_dimensions(256, 256).build();
image.save("qrcode.png").unwrap();
}
提示:不同庫支援的樣式能力差異較大。如需高級樣式(圓點、漸變、定位點風格、外框等),可在本工具中生成 PNG/SVG 後直接使用。