ライブ環境でテストする
ウォーターマークなしで本番環境でテストしてください。
必要な場所でいつでも動作します。
モバイルコンピューティングが普及した今、QRコードはスムーズで迅速な情報共有のために必要なツールになりつつある。 QRコードは、デジタル決済から製品パッケージまで、あらゆるものに使われている。 開発者としてモバイルアプリケーションにQRコードスキャン機能を追加することは、ユーザーエクスペリエンスを向上させ、多くのチャンスにつながります。 この投稿では、IronQRを使用して .NET MAUI のバーコードスキャナーおよび QR コードリーダーを作成する方法を説明します。
.NET MAUIとIronQR NuGetパッケージのインストール
メインページのレイアウトを作成する
カメラの初期化
キャプチャ画像
QRコードを読む
表示結果
.NET Multi-platform App UIと呼ばれるフレームワーク(.NET MAUI)により、C#(シーシャープ)とXAMLを使用してネイティブのクロスプラットフォームアプリケーションを作成できます。 1つのコードベースだけで、開発者はWindows、macOS、iOS、Android向けのアプリを制作できるようになった。 .NET MAUIは、ネイティブデバイスの機能にアクセスするための統一されたAPIを提供し、クロスプラットフォームアプリケーションの作成プロセスを容易にします。 .NET MAUIを開発者にとって効果的なツールにしている主な要素を以下に挙げる:
プラットフォーム固有のプロジェクトは、.NET MAUIを使用して統一されたプロジェクト構造にまとめられます。 この統合により、開発者はすべてのプラットフォーム固有のリソースとコードを1つのプロジェクトで扱うことができ、開発プロセスが合理化される。
単一のユーザーインターフェイスをデザインすることもできます。(ユーザーインターフェース (UI)).NETのMAUIで複数のプラットフォームで動作する。 このフレームワークは、Windows、macOS、iOS、Androidと互換性のあるレイアウトとコントロールのコレクションを提供する。
.NET MAUIの助けを借りて、開発者はネイティブAPIとプラットフォーム固有の機能を利用することができ、センサー、カメラ、GPS、その他のデバイス機能を使用することができます。 こうすることで、アプリはコードベースの多くをプラットフォーム間で共有しながら、ネイティブなユーザー体験を提供することができる。
.NET MAUIはXAMLとC#(シーシャープ)のホットリロードをサポートします。 この機能を使えば、開発者はプログラムを再起動することなく、UIの変更を瞬時に確認することができる。 ホット・リロードは、迅速な反復と即時のフィードバックを促進し、開発プロセスをスピードアップします。
Blazorと.NET MAUI間の統合により、開発者はBlazorコンポーネントを使用してハイブリッドアプリを作成することができます。この統合により、Blazorのウェブ開発能力とMAUIのネイティブモバイル開発の専門知識を組み合わせることで、最新のアプリケーションの作成が柔軟になります。
.NET MAUIによって、複数のプラットフォームにまたがる画像、フォント、スタイルなどのリソースの管理が容易になる。 リソースを一度だけ定義することで、開発者はすべてのターゲット・プラットフォームでリソースを利用することができ、冗長性を最小限に抑え、一貫した外観と感触を保証することができる。
依存性注入は、.NET MAUIですぐにサポートされ、開発者がよりテストされ保守可能なコードを構築するのに役立ちます。 明確な役割分担とモジュラー・アーキテクチャーを必要とする複雑なアプリケーションの構築には、この機能が必要だ。
QRコードを作成し読み取るための堅牢で適応性の高い.NET用ライブラリがIronQRです。 QRコードの作成と読み取りの両方に信頼性が高く使いやすい機能を提供することで、.NETアプリケーションでQRコードを利用するプロセスを合理化します。 IronQRを含むIronソフトウェアパッケージは、.NETプログラミングを改善するために設計されたライブラリのコレクションである。
IronQRはQRコードを扱う開発者にとって便利なツールです。 ここでは、その主な特徴をいくつか紹介しよう:
IronQRはQRコードを簡単に作成できます。 開発者は、テキスト、URL、その他の種類のデータからQRコードを迅速かつ効果的に生成することができます。
IronQRは、画像やストリームからQRコードを読み取るための強力な機能を提供します。
IronQRが提供する幅広いカスタマイズの可能性により、開発者はニーズに合わせたQRコードを作成、解釈することができます。
IronQRはバッチ処理に対応しており、同時に複数のQRコードの作成と読み取りが可能です。 大量のQRコードを効率的に処理する必要があるアプリケーションでは、この機能が特に役立つだろう。
ライブラリーの高性能設計により、QRコードの作成と読み取りが迅速に行える。 QRコードをリアルタイムで処理する必要があるアプリにとって、これは極めて重要だ。
IronQRは、.NET環境とのスムーズな統合により、ASP.NET、Windowsフォーム、WPF、Xamarinなどの.NETアプリケーションで簡単に使用できます。
C#.NET MAUIアプリケーションを作成するには、Visual Studio 2022と.NET 6フレームワークのインストールが必要です。 そして、.NET MAUIアプリを構築するために、次のステップに進みます。
Visual Studioを開いたら「新規プロジェクトの作成」ボタンをクリックします。 次に、検索バーで".NET MAUI project "を検索する。
Visual Studioの検索結果から.NET MAUIアプリ・テンプレートを選択します。 それが決まったら、それにふさわしい名前をつけ、プロジェクトの開催場所を決める。 設定後、「次へ」ボタンを押す。
必要なフレームワークを選択してください。 とはいえ、.NETフレームワークの最新版を使用することをお勧めします。 Visual Studioでフレームワークのバージョンを選択したら、「作成」をクリックします。
ツール -> NuGetパッケージマネージャ`の下にあるパッケージマネージャコンソールに移動します。 表示されたコマンドライン・パネルで、以下のコマンドを入力し、ENTERを押す:
Install-Package IronQR
前述のコマンドは、実行中のプロジェクトにライブラリをインストールし、ダウンロードする。
ユーザーインターフェースの作成は、QRコードスキャナー開発の初期段階である。 QRコードのスキャンプロセスを開始するボタンと、スキャンされたQRコードを表示する画像は、基本的なユーザーインターフェースの一部となります。(ユーザーインターフェース (UI))XAMLを使って構築します。
<ContentPage xmlns="http://schemas.microsoft.com/dotnet/2021/maui"
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
x:Class="MauiQrScanner.MainPage">
<StackLayout Padding="20" VerticalOptions="Center">
<Button Text="Scan QR Code" Clicked="OnScanButtonClicked"/>
<Image x:Name="QrCodeImage" WidthRequest="200" HeightRequest="200" VerticalOptions="CenterAndExpand"/>
<Label x:Name="QrCodeResult" Text="Scan Result" HorizontalOptions="Center" VerticalOptions="CenterAndExpand"/>
</StackLayout>
</ContentPage>
そして、IronQRを使ってQRコードを読み取る機能を実装しなければならない。 ボタンをクリックするイベントを処理する関数を書いて、QRコードをデバイスのカメラで撮影する。
MainPage.xaml.csを開いたら、以下のコードを追加する:
using IronQr;
using IronSoftware.Drawing;
using Microsoft.Maui.Controls;
using System;
using System.IO;
using System.Threading.Tasks;
namespace MauiAppQR
{
public partial class MainPage : ContentPage
{
public MainPage()
{
InitializeComponent();
}
private async void OnScanButtonClicked(object sender, EventArgs e)
{
var result = await CaptureAndScanQrCode();
QrCodeResult.Text = result ?? "No QR code found.";
}
private async Task<string> CaptureAndScanQrCode()
{
try
{
var photo = await MediaPicker.CapturePhotoAsync();
if (photo == null)
return null;
using var stream = await photo.OpenReadAsync();
using var memoryStream = new MemoryStream();
await stream.CopyToAsync(memoryStream);
var imageData = memoryStream.ToArray();
QrReader reader = new QrReader();
var inputBmp = AnyBitmap.FromBytes(imageData);
QrImageInput imageInput = new QrImageInput(inputBmp);
var barcodeResult = reader.Read(imageInput);
if (barcodeResult?.Count > 0)
{
QrCodeImage.Source = ImageSource.FromStream(() => new MemoryStream(imageData));
return barcodeResult.First().Value;
}
}
catch (Exception ex)
{
Console.WriteLine($"Error scanning QR code: {ex.Message}");
}
return null;
}
}
}
using IronQr;
using IronSoftware.Drawing;
using Microsoft.Maui.Controls;
using System;
using System.IO;
using System.Threading.Tasks;
namespace MauiAppQR
{
public partial class MainPage : ContentPage
{
public MainPage()
{
InitializeComponent();
}
private async void OnScanButtonClicked(object sender, EventArgs e)
{
var result = await CaptureAndScanQrCode();
QrCodeResult.Text = result ?? "No QR code found.";
}
private async Task<string> CaptureAndScanQrCode()
{
try
{
var photo = await MediaPicker.CapturePhotoAsync();
if (photo == null)
return null;
using var stream = await photo.OpenReadAsync();
using var memoryStream = new MemoryStream();
await stream.CopyToAsync(memoryStream);
var imageData = memoryStream.ToArray();
QrReader reader = new QrReader();
var inputBmp = AnyBitmap.FromBytes(imageData);
QrImageInput imageInput = new QrImageInput(inputBmp);
var barcodeResult = reader.Read(imageInput);
if (barcodeResult?.Count > 0)
{
QrCodeImage.Source = ImageSource.FromStream(() => new MemoryStream(imageData));
return barcodeResult.First().Value;
}
}
catch (Exception ex)
{
Console.WriteLine($"Error scanning QR code: {ex.Message}");
}
return null;
}
}
}
Imports IronQr
Imports IronSoftware.Drawing
Imports Microsoft.Maui.Controls
Imports System
Imports System.IO
Imports System.Threading.Tasks
Namespace MauiAppQR
Partial Public Class MainPage
Inherits ContentPage
Public Sub New()
InitializeComponent()
End Sub
Private Async Sub OnScanButtonClicked(ByVal sender As Object, ByVal e As EventArgs)
Dim result = Await CaptureAndScanQrCode()
QrCodeResult.Text = If(result, "No QR code found.")
End Sub
Private Async Function CaptureAndScanQrCode() As Task(Of String)
Try
Dim photo = Await MediaPicker.CapturePhotoAsync()
If photo Is Nothing Then
Return Nothing
End If
Dim stream = Await photo.OpenReadAsync()
Dim memoryStream As New MemoryStream()
Await stream.CopyToAsync(memoryStream)
Dim imageData = memoryStream.ToArray()
Dim reader As New QrReader()
Dim inputBmp = AnyBitmap.FromBytes(imageData)
Dim imageInput As New QrImageInput(inputBmp)
Dim barcodeResult = reader.Read(imageInput)
If barcodeResult?.Count > 0 Then
QrCodeImage.Source = ImageSource.FromStream(Function() New MemoryStream(imageData))
Return barcodeResult.First().Value
End If
Catch ex As Exception
Console.WriteLine($"Error scanning QR code: {ex.Message}")
End Try
Return Nothing
End Function
End Class
End Namespace
:ユーザが "Scan QR Code "ボタンを押すと、このメソッドが呼び出される。 デバイスのカメラを使って写真を撮り、QRコードを検索するには、
CaptureAndScanQrCode`関数を呼び出す。CaptureAndScanQrCode`:このメソッドはデバイスのカメラを使って写真を撮り、IronQR を使って写真からQRコードを読み取る。
MediaPicker.CapturePhotoAsync`:このAPIはデバイスのカメラを使って写真を撮る。
MemoryStreamを使う:IronQRが読みやすいように、キャプチャした画像は
MemoryStream` にロードされる。
QrReader.Read
:IronQR メソッドは画像情報からQRコードを読み込む。
を指定する:QRコードが見つかった場合、QRコードのテキストが
QrCodeResultラベルに表示され、画像が
QrCodeImage` 要素に表示される。デバイスのカメラにアクセスするには、正しい認証が必要です。 iOSとAndroidのプロジェクトファイルを更新して、必要なパーミッション要求を行う。
**アンドロイド
AndroidManifest.xml`にアクセスし、認可を含める:
<uses-permission android:name="android.permission.CAMERA" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
MainActivity.cs`でパーミッションを要求する:
protected override void OnCreate(Bundle savedInstanceState)
{
base.OnCreate(savedInstanceState);
Platform.Init(this, savedInstanceState);
Xamarin.Essentials.Platform.RequestPermissions(this, new string[]
{
Android.Manifest.Permission.Camera,
Android.Manifest.Permission.WriteExternalStorage,
Android.Manifest.Permission.ReadExternalStorage
});
}
protected override void OnCreate(Bundle savedInstanceState)
{
base.OnCreate(savedInstanceState);
Platform.Init(this, savedInstanceState);
Xamarin.Essentials.Platform.RequestPermissions(this, new string[]
{
Android.Manifest.Permission.Camera,
Android.Manifest.Permission.WriteExternalStorage,
Android.Manifest.Permission.ReadExternalStorage
});
}
Protected Overrides Sub OnCreate(ByVal savedInstanceState As Bundle)
MyBase.OnCreate(savedInstanceState)
Platform.Init(Me, savedInstanceState)
Xamarin.Essentials.Platform.RequestPermissions(Me, New String() { Android.Manifest.Permission.Camera, Android.Manifest.Permission.WriteExternalStorage, Android.Manifest.Permission.ReadExternalStorage })
End Sub
以下は、Windowsマシン環境から生成された出力である。
スキャン後、完了した結果がラベルに表示されます。
.NET MAUIとIronQRを使用して.NET MAUI QRコードスキャナーを作成するのは簡単なプロセスですが、モバイルアプリの機能を大幅に向上させることができます。IronQRのQRコード処理用の強力な機能と.NET MAUIのクロスプラットフォーム機能により、Windows、iOS、macOS、Android用の効果的で信頼性の高いQRコードスキャナーを構築することができます。
IronQRと.NET用IronQR(MAUI)を組み合わせることで、スムーズな開発プロセスを提供し、最先端機能の作成と一流のアプリケーションの作成に集中することができます。 このチュートリアルでは、簡単なQRコードスキャナーから最先端のQRコード機能を備えた高度なアプリケーションまで、どのようなアプリケーションを作成する場合でも、簡単に始めることができる強力な基礎を提供します。
開発プロセスをさらに合理化したい場合は、QRコードの要件にIronQRを使用することをご検討ください。 IronQRは困難な状況下でも、鮮明で拡張性のあるQRコードを作成し、強力な読み取り能力を発揮します。 IronQRは、個人開発者、小規模チーム、大企業向けにカスタマイズ可能なライセンス形態で、お客様独自のニーズに合ったソリューションを提供します。 Iron SoftwareIronQRは、あなたのアプリケーションをさらに進化させます。
Iron Software Suiteの他の類似製品では、IronBarcodeがバーコードをスキャンするカウンターパートとなります。 IronBarcodeを使用すると、高性能なバーコードスキャン機能をアプリケーションにシームレスに統合することができます。
9つの .NET API製品 オフィス文書用