バージョン 1.0 — 2026年2月
有限会社 パオ・アット・オフィス
https://www.pao.ac/
Barcode.Swift は、Swift で書かれた Pure Swift バーコード生成ライブラリです。C++やその他の外部依存を必要とせず、Swift Package Manager で導入するだけですぐに18種類のバーコードを生成できます。
サーバーサイド Swift(Vapor など)でバーコード画像を動的に生成し、Web アプリケーションや帳票出力に活用できます。
import BarcodePao
let qr = QRCode(outputFormat: BarcodeBase.FORMAT_PNG)
try qr.draw(code: "https://www.pao.ac/", size: 300)
let base64 = try qr.getImageBase64()
// → "..." をそのまま <img src="..."> に使えます
| 特長 | 説明 |
|---|---|
| Pure Swift | C/C++ 依存なし。Swift Package Manager だけで完結 |
| 18種対応 | 1D/2D バーコード 18種をすべてサポート |
| 3形式出力 | PNG、JPEG、SVG いずれの形式でも出力可能 |
| カスタマイズ | 色、テキスト表示、均等配置など細かく制御 |
| サーバー対応 | Vapor、Hummingbird など主要フレームワークに対応 |
| クロスプラットフォーム | macOS / Linux で動作 |
| カテゴリ | バーコード |
|---|---|
| 1D 工業用 | Code39, Code93, Code128, NW-7 (Codabar) |
| 1D 物流用 | ITF, Matrix 2of5, NEC 2of5 |
| GS1 系 | GS1-128, GS1 DataBar 標準型/限定型/拡張型 |
| 商品コード | JAN-8 (EAN-8), JAN-13 (EAN-13), UPC-A, UPC-E |
| 郵便 | 郵便カスタマバーコード |
| 2D | QRコード, DataMatrix, PDF417 |
PNG 画像を Base64 エンコードした文字列(Data URI)で取得できます。HTML の <img> タグにそのまま埋め込むことが可能です。
let bc = Code128(outputFormat: BarcodeBase.FORMAT_PNG)
bc.showText = true
try bc.draw(code: "Hello-2026", width: 400, height: 100)
let dataUri = try bc.getImageBase64()
// → "..."
SVG 形式で出力すればベクターなので、拡大しても劣化しません。
let bc = Code39(outputFormat: BarcodeBase.FORMAT_SVG)
try bc.draw(code: "HELLO", width: 300, height: 80)
let svg = try bc.getSVG()
// → "<svg xmlns=..."
getImageMemory() でバイト列 [UInt8] を取得し、ファイルに保存したり HTTP レスポンスとして直接返したりできます。
let qr = QRCode(outputFormat: BarcodeBase.FORMAT_PNG)
try qr.draw(code: "Test", size: 200)
let bytes = try qr.getImageMemory()
try Data(bytes).write(to: URL(fileURLWithPath: "qr.png"))
前景色・背景色の変更、テキスト表示のON/OFF、テキストの均等配置など、さまざまなカスタマイズが可能です。
let bc = Code128(outputFormat: BarcodeBase.FORMAT_PNG)
bc.showText = true
bc.textEvenSpacing = true
bc.setForegroundColor(0, 0, 128, 255) // 紺色
bc.setBackgroundColor(255, 255, 240, 255) // アイボリー
try bc.draw(code: "Custom", width: 400, height: 120)
製品サイトからサンプルプロジェクトを含む ZIP ファイルをダウンロードしてください。
https://www.pao.ac/barcode.swift/
Package.swift の dependencies に追加します:
dependencies: [
.package(url: "https://github.com/pao-company/barcode-swift.git", from: "1.0.0"),
]
ターゲットの dependencies にも追加します:
.target(name: "YourApp", dependencies: [
.product(name: "BarcodePao", package: "barcode-swift"),
]),
barcode-pao/
├── Package.swift
├── Roboto-Regular.ttf ← 組み込みフォント
└── Sources/BarcodePao/
├── BarcodeBase.swift ← 全バーコードの基底クラス
├── BarcodeBase1D.swift ← 1Dバーコード基底
├── BarcodeBase2D.swift ← 2Dバーコード基底
├── RenderPNG.swift ← PNG/JPEG描画エンジン
├── RenderSVG.swift ← SVG描画エンジン
├── Font.swift ← TTFフォント解析
├── Code39.swift ← Code39エンコーダ
├── QR.swift ← QRコードエンコーダ
└── ... (全18種)
import BarcodePao
// ステップ1: バーコードオブジェクトを作成
let qr = QRCode(outputFormat: BarcodeBase.FORMAT_PNG)
// ステップ2: バーコードを描画 → 出力を取得
try qr.draw(code: "https://www.pao.ac/", size: 300)
let base64 = try qr.getImageBase64()
// HTMLに埋め込み可能な data URI
print("<img src=\"\(base64)\">")
import BarcodePao
let c128 = Code128(outputFormat: BarcodeBase.FORMAT_SVG)
c128.showText = true
try c128.draw(code: "SWIFT-2026", width: 400, height: 100)
let svg = try c128.getSVG()
Vapor を使って QR コードを返す簡単なエンドポイント:
import Vapor
import BarcodePao
app.get("qr") { req -> Response in
let code = req.query[String.self, at: "code"] ?? "Hello"
let qr = QRCode(outputFormat: BarcodeBase.FORMAT_PNG)
try qr.draw(code: code, size: 300)
let bytes = try qr.getImageMemory()
var headers = HTTPHeaders()
headers.add(name: .contentType, value: "image/png")
return Response(status: .ok, headers: headers,
body: .init(data: Data(bytes)))
}
// Code39 — 英数字 + 記号
let c39 = Code39(outputFormat: BarcodeBase.FORMAT_PNG)
c39.showText = true
try c39.draw(code: "HELLO-123", width: 400, height: 100)
// Code93 — Code39より高密度
let c93 = Code93(outputFormat: BarcodeBase.FORMAT_PNG)
try c93.draw(code: "TEST-93", width: 400, height: 100)
// Code128 — ASCII全域
let c128 = Code128(outputFormat: BarcodeBase.FORMAT_PNG)
c128.showText = true
try c128.draw(code: "Hello-2026", width: 400, height: 100)
// NW-7 (Codabar)
let nw7 = NW7(outputFormat: BarcodeBase.FORMAT_PNG)
try nw7.draw(code: "A12345B", width: 400, height: 100)
// ITF (Interleaved 2 of 5) — 偶数桁の数字
let itf = ITF(outputFormat: BarcodeBase.FORMAT_PNG)
try itf.draw(code: "1234567890", width: 400, height: 100)
// QR コード
let qr = QRCode(outputFormat: BarcodeBase.FORMAT_PNG)
qr.errorCorrectionLevel = QR_ECC_H // 高耐久
try qr.draw(code: "https://www.pao.ac/", size: 300)
// DataMatrix — 工業用途に最適
let dm = DataMatrix(outputFormat: BarcodeBase.FORMAT_PNG)
try dm.draw(code: "Hello DataMatrix", size: 300)
// PDF417 — 運転免許証などに使用
let pdf = PDF417(outputFormat: BarcodeBase.FORMAT_PNG)
try pdf.draw(code: "Hello PDF417", width: 400, height: 200)
// GS1-128 — AI付きバーコード
let gs1 = GS1_128(outputFormat: BarcodeBase.FORMAT_PNG)
try gs1.draw(code: "(01)04912345123459(10)ABC123", width: 500, height: 100)
// GS1 DataBar 標準型
let db14 = GS1DataBar14(outputFormat: BarcodeBase.FORMAT_PNG)
try db14.draw(code: "0112345678901231", width: 400, height: 80)
// GS1 DataBar 限定型
let dbl = GS1DataBarLimited(outputFormat: BarcodeBase.FORMAT_PNG)
try dbl.draw(code: "0100012345678905", width: 400, height: 80)
// GS1 DataBar 拡張型
let dbe = GS1DataBarExpanded(outputFormat: BarcodeBase.FORMAT_PNG)
try dbe.draw(code: "(01)00012345678905(10)ABC123", width: 500, height: 80)
// JAN-8 (EAN-8)
let j8 = JAN8(outputFormat: BarcodeBase.FORMAT_PNG)
j8.showText = true
try j8.draw(code: "1234567", width: 200, height: 100)
// JAN-13 (EAN-13) — 日本のPOSで最も使われる
let j13 = JAN13(outputFormat: BarcodeBase.FORMAT_PNG)
j13.showText = true
try j13.draw(code: "490123456789", width: 300, height: 120)
// UPC-A — 北米向け
let upca = UPC_A(outputFormat: BarcodeBase.FORMAT_PNG)
upca.showText = true
try upca.draw(code: "01234567890", width: 300, height: 120)
// 郵便カスタマバーコード — 日本郵便
let yubin = YubinCustomer(outputFormat: BarcodeBase.FORMAT_PNG)
try yubin.draw(code: "10200091-13-2-3", height: 50)
| メソッド | 説明 |
|---|---|
init(outputFormat: String) |
バーコードオブジェクトを作成 |
getImageBase64() throws -> String |
Base64 Data URI を返す(PNG/JPEG) |
getSVG() throws -> String |
SVG 文字列を返す |
getImageMemory() throws -> [UInt8] |
バイト列を返す(PNG/JPEG) |
setForegroundColor(_ r: Int, _ g: Int, _ b: Int, _ a: Int) |
前景色を設定 |
setBackgroundColor(_ r: Int, _ g: Int, _ b: Int, _ a: Int) |
背景色を設定 |
出力フォーマット定数:
| 定数 | 値 |
|---|---|
BarcodeBase.FORMAT_PNG |
"png" |
BarcodeBase.FORMAT_JPEG |
"jpeg" |
BarcodeBase.FORMAT_SVG |
"svg" |
| プロパティ | 型 | 説明 |
|---|---|---|
showText |
Bool |
テキスト表示 ON/OFF(デフォルト: false) |
textEvenSpacing |
Bool |
テキストの均等配置(デフォルト: false) |
let bc = Code39(outputFormat: format)
bc.showStartStop = true // スタート/ストップ文字の表示
try bc.draw(code: "HELLO-123", width: 400, height: 100)
使用可能文字: 0-9, A-Z, -, ., , $, /, +, %
let bc = Code93(outputFormat: format)
try bc.draw(code: "TEST-93", width: 400, height: 100)
let bc = Code128(outputFormat: format)
bc.showText = true
try bc.draw(code: "Hello-2026", width: 400, height: 100)
ASCII 全域(0x00-0x7F)に対応。
let bc = GS1_128(outputFormat: format)
try bc.draw(code: "(01)04912345123459(10)ABC123", width: 500, height: 100)
AI(Application Identifier)を括弧で囲んで指定。
let bc = NW7(outputFormat: format)
try bc.draw(code: "A12345B", width: 400, height: 100)
スタート/ストップ文字: A, B, C, D
let bc = ITF(outputFormat: format)
try bc.draw(code: "1234567890", width: 400, height: 100)
数字のみ、偶数桁。
let bc = Matrix2of5(outputFormat: format)
try bc.draw(code: "12345", width: 400, height: 100)
let bc = NEC2of5(outputFormat: format)
try bc.draw(code: "12345", width: 400, height: 100)
let bc = JAN8(outputFormat: format)
bc.showText = true
try bc.draw(code: "1234567", width: 200, height: 100)
7桁 + チェックデジット自動計算。
let bc = JAN13(outputFormat: format)
bc.showText = true
try bc.draw(code: "490123456789", width: 300, height: 120)
12桁 + チェックデジット自動計算。
let bc = UPC_A(outputFormat: format)
bc.showText = true
try bc.draw(code: "01234567890", width: 300, height: 120)
let bc = UPC_E(outputFormat: format)
bc.showText = true
try bc.draw(code: "0123456", width: 200, height: 100)
let bc = GS1DataBar14(outputFormat: format)
try bc.draw(code: "0112345678901231", width: 400, height: 80)
let bc = GS1DataBarLimited(outputFormat: format)
try bc.draw(code: "0100012345678905", width: 400, height: 80)
let bc = GS1DataBarExpanded(outputFormat: format)
try bc.draw(code: "(01)00012345678905(10)ABC123", width: 500, height: 80)
let bc = YubinCustomer(outputFormat: format)
try bc.draw(code: "10200091-13-2-3", height: 50)
幅は自動計算されます。
let qr = QRCode(outputFormat: format)
qr.errorCorrectionLevel = QR_ECC_M // L, M, Q, H
qr.version = 0 // 0 = 自動, 1-40
try qr.draw(code: "Hello", size: 300)
| 定数 | 値 | 誤り訂正能力 |
|---|---|---|
QR_ECC_L |
0 | 約7% |
QR_ECC_M |
1 | 約15% |
QR_ECC_Q |
2 | 約25% |
QR_ECC_H |
3 | 約30% |
let dm = DataMatrix(outputFormat: format)
dm.stringEncoding = "gs1" // GS1 DataMatrix にも対応
try dm.draw(code: "Hello DataMatrix", size: 300)
let pdf = PDF417(outputFormat: format)
try pdf.draw(code: "Hello PDF417", width: 400, height: 200)
| 項目 | 要件 |
|---|---|
| Swift | 5.10 以上 |
| OS | macOS 14+, Linux (Ubuntu 22.04+, CentOS Stream 9+) |
| 依存 | swift-png (tayloraswift) |
本ソフトウェアは商用ライセンスです。ご購入いただいたライセンスに基づき、お客様の開発プロジェクトでご利用いただけます。
| プラン | 価格(税込) | 内容 |
|---|---|---|
| 通常ライセンス | ¥22,000 | 1開発者、無制限プロジェクト |
| 3年サポート | ¥9,900 | メールサポート + アップデート |
| 5年サポート | ¥13,750 | メールサポート + アップデート |
お問い合わせ:
Copyright (c) 2026 有限会社 パオ・アット・オフィス. All rights reserved.