MAUI 本身不内置二维码生成能力,需借助第三方库 QRCoder 实现;通过生成 PNG 字节数组并转为 MemoryStream,再赋值给 Image.Source 即可跨平台显示,注意避免使用依赖 System.Drawing 的渲染器。
MAUI 本身不内置二维码生成能力,但可以通过第三方库轻松实现,最常用的是 QRCoder(兼容 .NET Standard / .NET 6+),配合 MAUI 的 Image 控件显示。
在你的 MAUI 项目(通常是 Shared 项目或平台项目)中安装 NuGet 包:
QRCoder
Install-Package QRCoder
QRCoder 默认输出为 Bitmap(仅支持 Windows)或 byte[](PNG 数据),而 MAUI 的 Image 控件需要 StreamImageSource 或 Base64 字符串。推荐方式是生成 PNG 字节数组,再转为 MemoryStream:
QRCodeGenerator 实例,调用 CreateQrCode() 得到 QRCodeData
PngByteQRCode 渲染为 byte[]
MemoryStream,赋给 Image.Source
示例代码(C# 后台):
var qrGenerator = new QRCodeGenerator();
var qrData = qrGenerator.CreateQrCode("https://maui.dev", QRCodeGenerator.ECCLevel.Q);
var qrCode = new PngByteQRCode(qrData);
byte[] qrBytes = qrCode.GetQRCodeByteArray(10); // 10px 每模块,可调
// 绑定到 Image 控件(XAML 中 x:Name="QrImage")
QrImage.Source = ImageSource.FromStream(() => new MemoryStream(qrBytes));
QRCoder 在所有 MAUI 支持平台(Android、iOS、Windows、macOS)上均可运行,但要注意:
System.Drawing.Bitmap,务必使用 PngByteQRCode 而非 BitmapByteQRCode
为复用方便,可封装一个静态方法:
public staticImageSource GenerateQr(string content, int pixelsPerModule = 8) { var data = new QRCodeGenerator().CreateQrCode(content, QRCodeGenerator.ECCLevel.M); var bytes = new PngByteQRCode(data).GetQRCodeByteArray(pixelsPerModule); return ImageSource.FromStream(() => new MemoryStream(bytes)); }
然后在页面中直接调用:QrImage.Source = Utils.GenerateQr("Hello MAUI");
基本上就这些。不复杂但容易忽略平台兼容性细节,用对渲染器就能稳定跑起来。