論壇問題,基本上是在 SSRS 上顯示 QRCode,剛好可以拿來練習影像控件 (Image) 顯示圖檔。
- 外部 (External):[RV] 顯示外部圖片
- 內崁 (Embedded):[SSRS] 格式化條件 - 顯示圖片
- 資料庫 (data-bound)
該筆記是使用 [資料庫 (data-bound)] ,來製作財產標籤,標籤內包含 QRCode
資料來源
USE [AdventureWorks2022]
GO
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
CREATE TABLE [dbo].[Asset](
[ID] [int] IDENTITY(1,1) NOT NULL,
[NO] [char](5) NOT NULL,
[Name] [nvarchar](100) NOT NULL,
[PurchDate] [date] NULL,
[Location] [nvarchar](20) NOT NULL,
[Department] [nvarchar](20) NOT NULL,
CONSTRAINT [PK_Asset] PRIMARY KEY CLUSTERED
(
[ID] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON, OPTIMIZE_FOR_SEQUENTIAL_KEY = OFF) ON [PRIMARY]
) ON [PRIMARY]
GO
ALTER TABLE [dbo].[Asset] ADD CONSTRAINT [DF_Asset_NO] DEFAULT ('') FOR [NO]
GO
ALTER TABLE [dbo].[Asset] ADD CONSTRAINT [DF_Asset_Name] DEFAULT (N'') FOR [Name]
GO
ALTER TABLE [dbo].[Asset] ADD CONSTRAINT [DF_Asset_Location] DEFAULT (N'') FOR [Location]
GO
ALTER TABLE [dbo].[Asset] ADD CONSTRAINT [DF_Asset_Department] DEFAULT (N'') FOR [Department]
GO
-- 建立假資料
INSERT INTO [dbo].[Asset] ([NO],[Name],[PurchDate],[Location],[Department]) VALUES
('A0001' , N'商用電腦' , '20240101' , N'職員一' , N'行政') ,
('A0002' , N'事務機' , '20230707' , N'職員一' , N'行政') ,
('A0003' , N'油壓台車' , '20200820' , N'職員二' , N'運輸') ,
('A0004' , N'貨車' , '20190505' , N'職員二' , N'運輸') ,
('A0005' , N'手機' , '20190607' , N'職員二' , N'運輸')
GO
Model 和 ReportViewModel
使用 Entity Framework 來存取資料並建立 ReportViewModel 來呈現 QRCode
namespace ZXingQRCode
{
public class AssetReportModel : Asset
{
public byte[] QRcodeInfo { get; set; }
}
}
QRCode
使用 ZXing 套件來產生 QRCode 圖檔
using System;
using System.Drawing;
using System.Drawing.Imaging;
using System.IO;
using ZXing;
namespace ZXingQRCode
{
internal static class QRCodeGenerator
{
public static byte[] Create(string content)
{
if (string.IsNullOrWhiteSpace(content))
throw new ArgumentNullException(content);
BarcodeWriter writer = new BarcodeWriter
{
Format = BarcodeFormat.QR_CODE,
Options = new ZXing.QrCode.QrCodeEncodingOptions
{
Margin = 0,
Width = 200,
Height = 200
}
};
using (Bitmap bitmap = writer.Write(content))
using (MemoryStream stream = new MemoryStream())
{
bitmap.Save(stream, ImageFormat.Png);
return stream.ToArray();
}
}
}
}
報表設計
設計 8 X 5 cm 大小標籤,並使用清單來呈現每一筆資料,同時把自訂編號資訊轉成 QRCode 來呈現
影像控件設定 程式執行
using Microsoft.Reporting.WinForms;
using System;
using System.Data;
using System.Linq;
using System.Windows.Forms;
namespace ZXingQRCode
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
private void Form1_Load(object sender, EventArgs e)
{
var dbContext = new AdventureWorks2022Entities();
var dataSources = dbContext.Asset.ToList();
var reportSource = dataSources.Select(s => new AssetReportModel()
{
NO = s.NO,
Name = s.Name,
PurchDate = s.PurchDate,
Location = s.Location,
Department = s.Department,
QRcodeInfo = QRCodeGenerator.Create(s.NO)
}).ToList();
reportViewer1.LocalReport.DataSources.Add(new ReportDataSource(nameof(AssetReportModel), reportSource));
reportViewer1.RefreshReport();
}
}
}
- 延伸閱讀
- [SSRS] 民國日期
沒有留言:
張貼留言