官方介紹
- 在ASP.NET,Windows,Reporting Service,Crystal Reports 和 RDLC Reports應用程序中輕松生成條形碼
- 生成准確的條形碼圖像,並可以保存為 C# 和 VB.NET 類中的 JPEG,GIF 或 PNG 圖像文件
- 兼容 C# 和 VB.NET
- 由 .NET 程序員廣泛使用
- 符合最新的條形碼符號體系標准,如 ISO / IEC,GS1
- 創建線性條形碼,包括 Code39,Code128,GS1-128,Interleaved 2 of 5,EAN / UPC
- 創建 2d 條形碼圖像,包括數據矩陣,PDF-417 和 QR 碼
Nuget 安裝

支持的類型
類型很多,這里演示使用的是 TYPE.CODE128B。
public enum TYPE { UNSPECIFIED = 0, UPCA = 1, UPCE = 2, UPC_SUPPLEMENTAL_2DIGIT = 3, UPC_SUPPLEMENTAL_5DIGIT = 4, EAN13 = 5, EAN8 = 6, Interleaved2of5 = 7, Standard2of5 = 8, Industrial2of5 = 9, CODE39 = 10, CODE39Extended = 11, CODE39_Mod43 = 12, Codabar = 13, PostNet = 14, BOOKLAND = 15, ISBN = 16, JAN13 = 17, MSI_Mod10 = 18, MSI_2Mod10 = 19, MSI_Mod11 = 20, MSI_Mod11_Mod10 = 21, Modified_Plessey = 22, CODE11 = 23, USD8 = 24, UCC12 = 25, UCC13 = 26, LOGMARS = 27, CODE128 = 28, CODE128A = 29, CODE128B = 30, CODE128C = 31, ITF14 = 32, CODE93 = 33, TELEPEN = 34, FIM = 35, PHARMACODE = 36 }
簡單使用
Barcode 是核心類,它擁有 3 個構造函數,並且它實現了 IDisposable 接口,所以我們應該使用 uisng 關鍵字在執行完畢后進行資源的釋放。
public Barcode(); public Barcode(string data); public Barcode(string data, TYPE iType);
Encode() 是用來進行編碼操作的方法,調用完畢后會生成一張位圖。
public Image Encode(TYPE iType, string StringToEncode); public Image Encode(TYPE iType, string StringToEncode, Color ForeColor, Color BackColor); public Image Encode(TYPE iType, string StringToEncode, int Width, int Height); public Image Encode(TYPE iType, string StringToEncode, Color ForeColor, Color BackColor, int Width, int Height);
當然,它也自帶了對應的保存到文件中的方法 SaveImage。
public void SaveImage(string Filename, SaveTypes FileType); public void SaveImage(Stream stream, SaveTypes FileType);
默認支持保存的文件類型:
public enum SaveTypes { JPG = 0, BMP = 1, PNG = 2, GIF = 3, TIFF = 4, UNSPECIFIED = 5 }
這是一個較為簡單的用法:
/// <summary> /// 生成條形碼 /// </summary> /// <param name="content">內容</param> /// <returns></returns> public static Image GenerateBarCodeBitmap(string content) { using (var barcode = new Barcode() { IncludeLabel = true, Alignment = AlignmentPositions.CENTER, Width = 250, Height = 100, RotateFlipType = RotateFlipType.RotateNoneFlipNone, BackColor = Color.White, ForeColor = Color.Black, }) { return barcode.Encode(TYPE.CODE128B, content); } }
【備注】我在 IncludeLabel 屬性中對它進行了賦值 true 操作。如果不進行參數指定的話,就只能夠生成條形碼,而不會在底部顯示數據。


