C# QR-Code Generator Anwendung

This article was translated from English: Does it need improvement?
Translated
View the article in English

Willkommen bei unserem Leitfaden zur Erstellung vonQR-Codes mit C#! QR-Codes und .NET Barcode DLL sind zu beliebten Mitteln geworden, um Informationen schnell und effizient weiterzugeben. Ganz gleich, ob Sie eine App entwickeln, eine Website verwalten oder einfach nur nach einer Möglichkeit suchen, Links zu teilen - diese Codes können unglaublich nützlich sein. In dieser Anleitung zeigen wir Ihnen, wie Sie QR-Codes effizient mitIronQRso können Sie einen auf Ihre Bedürfnisse zugeschnittenen QR-Code erstellen. Diese Bibliothek macht es für jeden, der mit C# arbeitet, einfach, QR-Codes zu erstellen, ohne sich mit komplexer Logik auseinandersetzen zu müssen. Wir führen Sie durch die einzelnen Schritte und stellen sicher, dass Sie alles haben, was Sie brauchen, um loszulegen. Egal, ob Sie Ihrer App die Funktion eines QR-Code-Generators hinzufügen möchten oder einfach nur neugierig sind, wie das geht - hier sind Sie richtig. Fangen wir an.

QR Code Generator Bibliothek in C# installieren;

Beginnen Sie noch heute mit der Verwendung von IronQR in Ihrem Projekt mit einer kostenlosen Testversion.

Erster Schritt:
green arrow pointer


Bevor wir beginnen, müssen wir die IronQR NuGet-Paket.

Install-Package IronQR

IronQR: C# QR-Bibliothek

IronQR ist eine C# QR-Code-Bibliothek zur Integration von QR-Code-Funktionen in .NET-Anwendungen. IronQR unterstützt eine Vielzahl von .NET-Versionen und -Projekttypen, einschließlich C#, VB.NET, F#, .NET Core, .NET-Standard, .NET-Framework und mehr, und gewährleistet so die Kompatibilität mit verschiedenen Entwicklungsumgebungen wie Windows, Linux, macOS, iOS und Android.

IronQR zeichnet sich durch seine fortschrittlichen Funktionen aus, darunter die MöglichkeitqR-Codes lesen undqR-Codes erzeugenunterstützung für mehrere Bildformate und Anpassungsoptionen wie Größenänderung, Styling und Hinzufügen von Logos zu QR-Codes.

Einige Hauptmerkmale von IronQR

IronQR geht in seiner Funktionalität über die einfache QR-Code-Generierung hinaus und bietet mehrere Funktionen, die für eine Vielzahl von QR-Code-bezogenen Aufgaben entwickelt wurden. Schauen wir uns diese Funktionen an und prüfen Sie die Beispielcodes, die Sie in jede Art von .NET-Anwendungsvorlage wie Konsolenanwendungen integrieren können.

QR-Codes lesen

IronQR zeichnet sich durch die Dekodierung von QR-Codes aus und bietet den Benutzern eine einfache Möglichkeit, auf die in QR-Codes eingebetteten Informationen zuzugreifen. Sie können schnell und präzise Daten aus QR-Codes extrahieren, von einfachen URLs bis hin zu komplexen eingebetteten Informationen.

:path=/static-assets/qr/content-code-examples/tutorials/csharp-qr-code-generator-application-1.cs
using IronQr;
using IronSoftware.Drawing;
using System;
using System.Collections.Generic;

IronQr.License.LicenseKey = "License-Key";

// Load the image file that contains the QR Code
var inputImage = AnyBitmap.FromFile("QRCode.png");

// Prepare the image for QR code detection
QrImageInput qrInput = new QrImageInput(inputImage);

// Initialize the QR Code reader
QrReader qrReader = new QrReader();

// Execute QR Code reading on the provided image
IEnumerable<QrResult> qrResults = qrReader.Read(qrInput);

// Assuming you have the QR results in qrResults as before
foreach (var result in qrResults)
{
    Console.WriteLine(result.Value); // Print the QR code content to the console
}
Imports IronQr
Imports IronSoftware.Drawing
Imports System
Imports System.Collections.Generic

IronQr.License.LicenseKey = "License-Key"

' Load the image file that contains the QR Code
Dim inputImage = AnyBitmap.FromFile("QRCode.png")

' Prepare the image for QR code detection
Dim qrInput As New QrImageInput(inputImage)

' Initialize the QR Code reader
Dim qrReader As New QrReader()

' Execute QR Code reading on the provided image
Dim qrResults As IEnumerable(Of QrResult) = qrReader.Read(qrInput)

' Assuming you have the QR results in qrResults as before
For Each result In qrResults
	Console.WriteLine(result.Value) ' Print the QR code content to the console
Next result
VB   C#

Wir verwenden den folgenden QR-Code zum Scannen:

C# QR Code Bild erstellen

Und wir erhielten diese Ausgabe:

C# QR-Wert

Der Prozess beginnt mit der Einbindung der erforderlichen Namespaces, IronQR und IronSoftware.Drawing, mit einer besonderen Erwähnung von Color aus dem IronSoftware.Drawing-Namespace zur Handhabung von Bildmanipulationen.

Bevor Sie mit dem Lesen des QR-Codes beginnen, müssen Sie die Software mit Ihrem Lizenzschlüssel aktivieren, indem Sie ihn IronQR.License.LicenseKey zuweisen. Der Code lädt dann das QR-Code-Bild aus einer Datei mit AnyBitmap.FromFile("QRCode.png").

Nachdem das Bild geladen wurde, muss es im nächsten Schritt für die QR-Code-Erkennung vorbereitet werden. Diese Vorbereitung erfolgt durch die Erstellung eines QrImageInput-Objekts, das als Container für das Bild dient.

Der Kern dieser Funktion liegt in der Klasse QrReader, die instanziiert und für das Lesen von QR-Codes verwendet wird. Das Lesegerät analysiert das vorbereitete Bild, qrInput, und sucht nach den darin enthaltenen QR-Codes. Das Ergebnis dieses Vorgangs ist eine Sammlung von QrResult-Objekten, die jeweils einen erkannten QR-Code im Bild darstellen.

Um auf die in den QR-Codes kodierten Daten zuzugreifen und sie zu nutzen, iteriert der Code mit einer foreach-Schleife über die Sammlung der Ergebnisse. Jedes QrResult-Objekt enthält Eigenschaften wie den Wert des QR-Codes, auf den zugegriffen und der angezeigt werden kann.

Benutzerdefinierte QR-Lesemodus-Optionen

IronQR bietet Ihnen verschiedene Möglichkeiten, QR-Codes aus Bildern zu lesen, und ist somit vielseitig einsetzbar. Eine Option ist der gemischte Scanmodus, der ein Gleichgewicht zwischen Geschwindigkeit und Genauigkeit herstellt und nützlich ist, wenn QR-Codes nicht eindeutig oder teilweise verdeckt sind.

Eine andere ist das maschinelle Lernen(ML) Scan-Modus, der intelligente Technologie verwendet, um QR-Codes zu lesen, die beschädigt oder nicht leicht zu lesen sind. Dieser Modus ist ideal für schwierige Situationen, in denen QR-Codes schwer zu erkennen sind.

Schließlich gibt es noch den einfachen Scan-Modus, der die schnellste und einfachste Art ist, klare und einfache QR-Codes zu scannen. Es ist am besten, wenn Sie schnelle Ergebnisse benötigen und die QR-Codes leicht zu lesen sind.

:path=/static-assets/qr/content-code-examples/tutorials/csharp-qr-code-generator-application-2.cs
using IronQr;
using IronQr.Enum;
using IronSoftware.Drawing;
using System.Collections.Generic;

IronQr.License.LicenseKey = "License-Key";

// Load the image file that contains the QR Code
var inputImage = AnyBitmap.FromFile("QRCode.png");

QrImageInput mixedScanInput = new QrImageInput(inputImage, QrScanMode.OnlyDetectionModel);
IEnumerable<QrResult> mixedScanResults = new QrReader().Read(mixedScanInput);

QrImageInput mlScanInput = new QrImageInput(inputImage, QrScanMode.OnlyDetectionModel);
IEnumerable<QrResult> mlScanResults = new QrReader().Read(mlScanInput);

QrImageInput basicScanInput = new QrImageInput(inputImage, QrScanMode.OnlyBasicScan);
IEnumerable<QrResult> basicScanResults = new QrReader().Read(basicScanInput);
Imports IronQr
Imports IronQr.Enum
Imports IronSoftware.Drawing
Imports System.Collections.Generic

IronQr.License.LicenseKey = "License-Key"

' Load the image file that contains the QR Code
Dim inputImage = AnyBitmap.FromFile("QRCode.png")

Dim mixedScanInput As New QrImageInput(inputImage, QrScanMode.OnlyDetectionModel)
Dim mixedScanResults As IEnumerable(Of QrResult) = (New QrReader()).Read(mixedScanInput)

Dim mlScanInput As New QrImageInput(inputImage, QrScanMode.OnlyDetectionModel)
Dim mlScanResults As IEnumerable(Of QrResult) = (New QrReader()).Read(mlScanInput)

Dim basicScanInput As New QrImageInput(inputImage, QrScanMode.OnlyBasicScan)
Dim basicScanResults As IEnumerable(Of QrResult) = (New QrReader()).Read(basicScanInput)
VB   C#

QR-Codes im Voraus lesen

Die fortschrittlichen QR-Code-Lesefunktionen von IronQR sind so konzipiert, dass sie einen umfassenden und differenzierten Ansatz für das Scannen und Dekodieren von QR-Codes bieten. Dieser Funktionsumfang geht über die grundlegenden QR-Code-Lesefunktionen hinaus und bietet eine tiefere Ebene der Interaktion und Datenextraktion.

:path=/static-assets/qr/content-code-examples/tutorials/csharp-qr-code-generator-application-3.cs
using IronQr;
using IronSoftware.Drawing;
using System;
using System.Collections.Generic;

IronQr.License.LicenseKey = "License-Key";

var imageToScan = AnyBitmap.FromFile("QRCode.png");

QrImageInput qrInput = new QrImageInput(imageToScan);

QrReader qrScanner = new QrReader();

IEnumerable<QrResult> scanResults = qrScanner.Read(qrInput);

foreach (QrResult qrResult in scanResults)
{

    Console.WriteLine(qrResult.Value);

    Console.WriteLine(qrResult.Url);

    foreach (IronSoftware.Drawing.PointF coordinate in qrResult.Points)
    {
        Console.WriteLine($"{coordinate.X}, {coordinate.Y}");
    }
}
Imports IronQr
Imports IronSoftware.Drawing
Imports System
Imports System.Collections.Generic

IronQr.License.LicenseKey = "License-Key"

Dim imageToScan = AnyBitmap.FromFile("QRCode.png")

Dim qrInput As New QrImageInput(imageToScan)

Dim qrScanner As New QrReader()

Dim scanResults As IEnumerable(Of QrResult) = qrScanner.Read(qrInput)

For Each qrResult As QrResult In scanResults

	Console.WriteLine(qrResult.Value)

	Console.WriteLine(qrResult.Url)

	For Each coordinate As IronSoftware.Drawing.PointF In qrResult.Points
		Console.WriteLine($"{coordinate.X}, {coordinate.Y}")
	Next coordinate
Next qrResult
VB   C#

Dies ist die Ausgabe, wenn wir den QR-Code mit IronQR scannen:

C# QR Code Ergebnis lesen

Wir verwenden den folgenden QR-Code:

C# QR Code Bild erstellen

Jedes QrResult-Objekt ermöglicht den Zugriff auf die dekodierten Daten(Wert)alle eingebetteten URLs(Url)und die Raumkoordinaten(Punkte) des QR-Codes innerhalb des Bildes.

Für jeden erkannten QR-Code bietet IronQR detaillierte Informationen, einschließlich des genauen Inhalts und aller im QR-Code enthaltenen URLs. Außerdem liefert die Bibliothek die genauen Koordinaten der Ecken des QR-Codes im Bild(durch die Eigenschaft Punkte).

Um einen QR-Code-Generator mit der IronQR-Bibliothek für QR-Codes in einer C#-Anwendung zu erstellen, befolgen Sie diese Schritte sorgfältig. Dieser Leitfaden führt Sie durch das Einrichten einer Windows-Formularanwendung, die Installation der IronQR-Bibliothek, das Schreiben des Codes zum Generieren eines QR-Codes und das Verstehen der Ausgabe.

Schritt 1: Erstellen einer Windows-Anwendung in Visual Studio

  • Starten Sie zunächst Visual Studio auf Ihrem Computer.
  • Klicken Sie auf die Schaltfläche "Ein neues Projekt erstellen".
  • Wählen Sie als Projekttyp Windows Forms App. Stellen Sie sicher, dass Sie C# als Sprache wählen.
    Windows Forms-Anwendung

    Geben Sie einen Namen für Ihr Projekt ein und wählen Sie den Speicherort. Wählen Sie dann auf dem nächsten Bildschirm .NET-Framework aus. Klicken Sie dann auf Erstellen.

    Projekt-Konfiguration

    Es wird eine Windows Forms-Anwendung in Visual Studio erstellt und geöffnet.

Schritt 2: IronQR-Bibliothek installieren

Nun ist es an der Zeit, die IronQR-Bibliothek in das Projekt zu installieren. Sie können die IronQR-Bibliothek mit verschiedenen Methoden installieren. Wählen Sie eine, die Ihren Vorlieben entspricht:

Installation mit NuGet Package Manager

  • Klicken Sie mit der rechten Maustaste auf Ihr Projekt im Projektmappen-Explorer und wählen Sie NuGet-Pakete verwalten.
  • Geben Sie IronQR in das Suchfeld ein und drücken Sie die Eingabetaste.
    Verwalten von NuGet-Paketen

    Suchen Sie IronQR in der Liste und klicken Sie daneben auf Installieren.

    IronQR installieren

Installation über die NuGet-Paketmanager-Konsole

Gehen Sie zu Tools > NuGet Package Manager > Package Manager Console.

NuGet-Paketmanager

Geben Sie Install-Package IronQR ein und drücken Sie die Eingabetaste.

IronQR installieren

Schritt 3: Frontend gestalten

QR-Code-Generator

3.1 Titel Kopfzeile

Einen QR-Code generieren

Beim Starten der QR-Code-Generator-Anwendung wird dem Benutzer sofort eine auffällige Kopfzeile mit dem Titel "QR Generator IronQR" angezeigt, die in einer fetten und maßgeblichen Schriftart gehalten ist. Die Schrift Agency FB wurde aufgrund ihrer klaren, modernen Linien ausgewählt, die ein Gefühl von Effizienz und Präzision vermitteln. Mit einer Schriftgröße von 48 Punkt ist der Titel sowohl auffällig als auch aussagekräftig und zieht die Aufmerksamkeit des Benutzers auf sich, so dass die Identität der Anwendung klar erkennbar ist.

3.2 Eingangsbereich

Texteingabe für QR-Code

QR-Code Texteingabe

Das Herzstück des Eingabebereichs ist eine einfache, aber grundlegende Komponente: das Texteingabefeld. Hier können die Nutzer die Daten eingeben, die sie in ihrem QR-Code kodieren möchten. Der Kasten ist geräumig, bietet Platz für eine große Menge Text und ist an prominenter Stelle im oberen Bereich platziert.

Logo-Auswahl

Logo auswählen

Unterhalb der Texteingabe ermöglicht der Bereich "Logo auswählen" eine zusätzliche Ebene der Anpassung. Benutzer können ein Logo hochladen, das in den QR-Code eingebettet wird, um die Markenerkennung zu verbessern oder den Code zu personalisieren. Das nebenstehende Bildfeld zeigt eine Vorschau des ausgewählten Logos und bietet ein unmittelbares visuelles Feedback.

Farbe Konfiguration

Hintergrundfarbe

Auf der rechten Seite finden Sie die Optionen für die Farbauswahl. Zwei Schaltflächen, eine für die Farbe des QR-Codes und eine weitere für die Hintergrundfarbe, ermöglichen es dem Benutzer, die Palette seines QR-Codes anzupassen. Die Textfelder neben diesen Schaltflächen zeigen die aktuell ausgewählte Farbe an.

Das durchdachte Layout des Eingabebereichs mit seinen Text-, Logo- und Farboptionen spiegelt ein klares Verständnis der Benutzerprioritäten bei der Erstellung eines QR-Codes wider. Es verbindet Funktionalität mit Flexibilität und ermöglicht es den Benutzern, die erforderlichen Informationen schnell und effizient einzugeben, bietet aber auch Raum für Kreativität.

3.3 Parameter für die Gestaltung

Styling

Maßeinstellungen

Neben den Werkzeugen zur Farbanpassung finden die Benutzer die Eingabe für "Abmessungen" Diese numerische Einstellung ist entscheidend, da sie die Gesamtgröße des QR-Codes bestimmt und sicherstellt, dass er perfekt in den vorgesehenen Anzeigekontext passt, sei es eine Visitenkarte, ein Flyer oder ein digitaler Bildschirm.

Margin-Einstellungen

Neben der Dimensionseingabe ermöglicht das Feld "Ränder" die Angabe des Leerraums, der den QR-Code umgibt. Die Ränder sind nicht nur eine ästhetische Entscheidung, sondern auch ein funktionales Element, das die Lesbarkeit des QR-Codes durch Scanner beeinflussen kann. Die Anwendung bietet eine numerische Aufwärts-/Abwärtssteuerung, mit der der Benutzer diesen Parameter leicht einstellen kann.

3.4 Ausgabevorschau

QR-Ausgang

Sobald der Benutzer die QR-Code-Generierung initiiert hat, rückt das große Bildfeld auf der linken Seite des Formulars, das mit "Output" beschriftet ist, in den Mittelpunkt. Sie dient als dynamische Anzeige, die eine Echtzeit-Vorschau des generierten QR-Codes bietet. Dieses unmittelbare visuelle Feedback ist für die Nutzer wichtig, um ihre Designentscheidungen zu überprüfen und sicherzustellen, dass der QR-Code ihren Erwartungen entspricht, bevor sie ihn speichern.

3.5 Aktionsschaltflächen

QR generieren

QR-Code in C#

Die Schaltfläche "QR generieren" ist ein zentrales Bedienelement in der Anwendungsoberfläche. Diese Schaltfläche ist strategisch innerhalb des Formulars positioniert und dient als Katalysator für den Erstellungsprozess des QR-Codes. Wenn Sie auf diese Schaltfläche klicken, übernimmt die Anwendung alle vom Benutzer definierten Eingabedaten und Styling-Parameter und beginnt mit der Erstellung eines benutzerdefinierten QR-Codes.

QR-Code speichern

Sparen

Sobald ein QR-Code generiert wurde und im Ausgabevorschaubereich angezeigt wird, kommt die Schaltfläche "QR speichern" ins Spiel. Wenn Sie darauf klicken, öffnet sich ein Speicherdialog, in dem der Benutzer das gewünschte Dateiformat und den Speicherort auswählen kann.

Formular zurücksetzen

Zurücksetzen

Mit einem einzigen Klick auf diese Schaltfläche werden alle vorherigen Eingaben und Auswahlen gelöscht und alle Einstellungen auf ihre Standardwerte zurückgesetzt. Es ist ein wichtiger Aspekt des Formulars, da es eine schnelle Möglichkeit bietet, die Anwendung neu zu initialisieren, ohne jede Option manuell anpassen zu müssen.

Schritt 4: Backend-Logik schreiben

4.1 Einrichtung und Initialisierung

Zunächst beginnt die Anwendung mit der Aufnahme der erforderlichen Namespaces: IronQR und IronSoftware.Drawing. Diese Namespaces sind unerlässlich, da sie die Funktionen bereitstellen, die zur Erzeugung und Bearbeitung von QR-Codes und Farben innerhalb der Anwendung erforderlich sind. Die benutzerdefinierte Klasse Color ist definiert, um das Farbmanagement bei der QR-Code-Generierung zu erleichtern. Sie überschreibt die Standardklasse System.Drawing.Color, um die Kompatibilität mit den Anforderungen von IronQR sicherzustellen.

:path=/static-assets/qr/content-code-examples/tutorials/csharp-qr-code-generator-application-4.cs
using IronQr;
using IronSoftware.Drawing;
using Color = IronSoftware.Drawing.Color;

Imports IronQr
Imports IronSoftware.Drawing
Imports Color = IronSoftware.Drawing.Color
VB   C#

Der Konstruktor für die Klasse QR_Generator spielt eine entscheidende Rolle bei der Vorbereitung der Anwendung für den Einsatz. Hier werden die Komponenten der Anwendung initialisiert, was ein Standardschritt in Windows Forms-Anwendungen ist, um die UI-Elemente des Formulars einzurichten.

:path=/static-assets/qr/content-code-examples/tutorials/csharp-qr-code-generator-application-5.cs
public QR_Generator()
{
    InitializeComponent();
    SetLicenseKey();
    EnsureDirectoryExists(qrCodesDirectory);
}
'INSTANT VB WARNING: The following constructor is declared outside of its associated class:
'ORIGINAL LINE: public QR_Generator()
Public Sub New()
	InitializeComponent()
	SetLicenseKey()
	EnsureDirectoryExists(qrCodesDirectory)
End Sub
VB   C#

SetLicenseKey: Diese Methode wird aufgerufen, um einen gültigen Lizenzschlüssel für die IronQR-Bibliothek anzuwenden. Die Verwendung eines Lizenzschlüssels ist für kommerzielle Anwendungen und zur Freischaltung des vollen Funktionsumfangs der IronQR-Bibliothek erforderlich.

EnsureDirectoryExists: Da die generierten QR-Codes gespeichert werden müssen, stellt diese Methode sicher, dass ein entsprechendes Verzeichnis vorhanden ist. Es prüft, ob das Verzeichnis "QR Codes" im Startpfad der Anwendung vorhanden ist, und erstellt es, wenn dies nicht der Fall ist.

4.2 Lizenzschlüssel-Konfiguration

Um sicherzustellen, dass IronQR ohne Einschränkungen funktioniert, muss ein gültiger Lizenzschlüssel verwendet werden. Dies wird durch die Methode SetLicenseKey erreicht, die eine statische Methode ist, um die Bibliothek mit Ihrem gekauften oder Testlizenzschlüssel zu konfigurieren. Das folgende Codeschnipsel veranschaulicht, wie Sie den Lizenzschlüssel festlegen:

:path=/static-assets/qr/content-code-examples/tutorials/csharp-qr-code-generator-application-6.cs
private static void SetLicenseKey()
{
    IronQr.License.LicenseKey = "YOUR_LICENSE_KEY";
}
Private Shared Sub SetLicenseKey()
	IronQr.License.LicenseKey = "YOUR_LICENSE_KEY"
End Sub
VB   C#

Ersetzen Sie "IHR_LIZENZSCHLÜSSEL" durch den tatsächlichen Lizenzschlüssel, den Sie von Iron Software erhalten haben. Die Methode wird im Konstruktor der Klasse QR_Generator aufgerufen, um sicherzustellen, dass die Lizenz angewendet wird, sobald die Anwendung startet und bevor ein QR-Code erzeugt wird.

4.3 Verzeichnisverwaltung

Die Anwendung verwendet die Methode EnsureDirectoryExists, um zu prüfen, ob das angegebene Verzeichnis zum Speichern von QR-Codes existiert. Wenn nicht, wird das Verzeichnis erstellt. Diese Methode benötigt einen String-Parameter, der den Pfad des zu prüfenden oder zu erstellenden Verzeichnisses angibt. So wird es umgesetzt:

:path=/static-assets/qr/content-code-examples/tutorials/csharp-qr-code-generator-application-7.cs
private static void EnsureDirectoryExists(string path)
{
    if (!System.IO.Directory.Exists(path))
    {
        System.IO.Directory.CreateDirectory(path);
    }
}
Private Shared Sub EnsureDirectoryExists(ByVal path As String)
	If Not System.IO.Directory.Exists(path) Then
		System.IO.Directory.CreateDirectory(path)
	End If
End Sub
VB   C#

Diese Methode verwendet den System.IO-Namensraum zur Interaktion mit dem Dateisystem. Zunächst wird mit Directory.Exists geprüft, ob das Verzeichnis unter dem angegebenen Pfad existiert. Wenn das Verzeichnis nicht existiert(false wird zurückgegeben)wird das Verzeichnis mit Directory.CreateDirectory erstellt.

Der Pfad zum QR-Codes-Verzeichnis wird im Konstruktor der Klasse QR_Generator als qrCodesDirectory definiert, der den Startpfad der Anwendung mit einem "QR-Codes"-Ordnernamen kombiniert:

:path=/static-assets/qr/content-code-examples/tutorials/csharp-qr-code-generator-application-8.cs
string qrCodesDirectory = System.IO.Path.Combine(Application.StartupPath, "QR Codes");
Dim qrCodesDirectory As String = System.IO.Path.Combine(Application.StartupPath, "QR Codes")
VB   C#

4.4 Farbauswahl

Die Anwendung bietet zwei Schaltflächen auf der Benutzeroberfläche, die jeweils mit einer Methode zur Farbauswahl verbunden sind: btn_color_Click für die QR-Code-Farbe und btn_background_Click für die Hintergrundfarbe. Diese Methoden nutzen ein Farbdialogfeld, in dem der Benutzer Farben auswählen kann.

Wenn eine Farbe über das Farbdialogfeld ausgewählt wird, wird die gewählte Farbe in ein hexadezimales String-Format umgewandelt. Dies ist notwendig, da die IronQR-Bibliothek die Angabe von Farben im Hexadezimalformat verlangt. Die Umwandlung erfolgt mit der Methode ColorToHex:

:path=/static-assets/qr/content-code-examples/tutorials/csharp-qr-code-generator-application-9.cs
private string ColorToHex(System.Drawing.Color color)
{
    return $"#{color.R:X2}{color.G:X2}{color.B:X2}";
}
Private Function ColorToHex(ByVal color As System.Drawing.Color) As String
	Return $"#{color.R:X2}{color.G:X2}{color.B:X2}"
End Function
VB   C#

Die UpdateColor-Methode nimmt die ausgewählte Farbe und konvertiert sie in das IronSoftware.Drawing.Color-Format unter Verwendung der hexadezimalen Zeichenkette und aktualisiert entweder die Vorder- oder Hintergrundfarbe des QR-Codes, je nach Auswahl. Außerdem wird die Benutzeroberfläche aktualisiert, um die neue Farbauswahl widerzuspiegeln:

:path=/static-assets/qr/content-code-examples/tutorials/csharp-qr-code-generator-application-10.cs
private void UpdateColor(ref Color targetColor, Control display, bool isBackground)
{
    if (select_color.ShowDialog() == DialogResult.OK)
    {
        var hexColor = ColorToHex(select_color.Color);
        targetColor = new Color(hexColor);
        display.BackColor = select_color.Color;
    }
}
Private Sub UpdateColor(ByRef targetColor As Color, ByVal display As Control, ByVal isBackground As Boolean)
	If select_color.ShowDialog() = DialogResult.OK Then
		Dim hexColor = ColorToHex(select_color.Color)
		targetColor = New Color(hexColor)
		display.BackColor = select_color.Color
	End If
End Sub
VB   C#

4.5 Hinzufügen eines Logos

Die Anwendung enthält eine Schaltfläche(btn_logo_Klick) die, wenn sie angeklickt wird, ein Dateidialogfeld öffnet, in dem der Benutzer eine Bilddatei auswählen kann, die als Logo verwendet werden soll. Diese Funktion ist entscheidend für Unternehmen oder Privatpersonen, die ihre QR-Codes mit einem Markenzeichen versehen wollen. So wird der Prozess der Logoauswahl und -integration gehandhabt:

:path=/static-assets/qr/content-code-examples/tutorials/csharp-qr-code-generator-application-11.cs
private void btn_logo_Click(object sender, EventArgs e)
{
    if (select_logo.ShowDialog() == DialogResult.OK)
    {
        try
        {
            logoBmp = new AnyBitmap(select_logo.FileName);
            selected_logo.Image = Image.FromFile(select_logo.FileName);
        }
        catch (Exception ex)
        {
            ShowError("An error occurred while loading the logo", ex.Message);
        }
    }
}
Private Sub btn_logo_Click(ByVal sender As Object, ByVal e As EventArgs)
	If select_logo.ShowDialog() = DialogResult.OK Then
		Try
			logoBmp = New AnyBitmap(select_logo.FileName)
			selected_logo.Image = Image.FromFile(select_logo.FileName)
		Catch ex As Exception
			ShowError("An error occurred while loading the logo", ex.Message)
		End Try
	End If
End Sub
VB   C#

Nach erfolgreicher Auswahl eines Bildes versucht die Anwendung, es zu laden und eine Vorschau anzuzeigen. Das AnyBitmap-Objekt logoBmp wird dann mit dem ausgewählten Bild versehen, das die Logik der QR-Generierung später verwendet.

4.6 QR-Code-Erzeugung

Der Erzeugungsprozess beginnt, wenn der Benutzer auf die Schaltfläche "Erzeugen" klickt, die mit der Methode btn_generate_Click verknüpft ist. Diese Methode fungiert als Auslöser und ruft die Funktion GenerateQRCode auf, in der sich die eigentliche Generierungslogik befindet.

:path=/static-assets/qr/content-code-examples/tutorials/csharp-qr-code-generator-application-12.cs
private void btn_generate_Click(object sender, EventArgs e)
{
    GenerateQRCode();
}
Private Sub btn_generate_Click(ByVal sender As Object, ByVal e As EventArgs)
	GenerateQRCode()
End Sub
VB   C#

In der Methode GenerateQRCode konstruiert die Anwendung einen QR-Code auf der Grundlage der angegebenen Parameter, einschließlich des Eingabetextes und der Stiloptionen. Die Methode umfasst die Erstellung eines QR-Codes unter Anwendung der ausgewählten Farben, Abmessungen, Ränder und optional eines Logos.

:path=/static-assets/qr/content-code-examples/tutorials/csharp-qr-code-generator-application-13.cs
private void GenerateQRCode()
{
    try
    {
        var options = new QrOptions(QrErrorCorrectionLevel.High);
        var myQr = QrWriter.Write(txt_QR.Text, options);
        var style = CreateStyleOptions();
        var qrImage = myQr.Save(style);
        var fileName = $"{DateTime.Now:yyyyMMddHHmmssfff}_QR.png";
        var fullPath = System.IO.Path.Combine(qrCodesDirectory, fileName);
        qrImage.SaveAs(fullPath);
        pictureBox.Image = Image.FromFile(fullPath);
    }
    catch (Exception ex)
    {
        ShowError("An error occurred during QR code generation or saving", ex.Message);
    }
}
Private Sub GenerateQRCode()
	Try
		Dim options = New QrOptions(QrErrorCorrectionLevel.High)
		Dim myQr = QrWriter.Write(txt_QR.Text, options)
		Dim style = CreateStyleOptions()
		Dim qrImage = myQr.Save(style)
		Dim fileName = $"{DateTime.Now:yyyyMMddHHmmssfff}_QR.png"
		Dim fullPath = System.IO.Path.Combine(qrCodesDirectory, fileName)
		qrImage.SaveAs(fullPath)
		pictureBox.Image = Image.FromFile(fullPath)
	Catch ex As Exception
		ShowError("An error occurred during QR code generation or saving", ex.Message)
	End Try
End Sub
VB   C#

Das QrOptions-Objekt definiert die Fehlerkorrekturstufe, die die Widerstandsfähigkeit des QR-Codes gegenüber Beschädigungen oder Unklarheiten erhöht. Die Methode CreateStyleOptions erzeugt ein QrStyleOptions-Objekt, das die benutzerdefinierten Einstellungen wie Farben, Abmessungen und das Logo enthält. Hier ist die Methode im Detail:

:path=/static-assets/qr/content-code-examples/tutorials/csharp-qr-code-generator-application-14.cs
private QrStyleOptions CreateStyleOptions()
{
    return new QrStyleOptions
    {
        BackgroundColor = bgColor,
        Color = color,
        Dimensions = txt_dimension.Value > 0 ? Convert.ToInt32(txt_dimension.Value) : throw new ArgumentException("Please select valid dimensions!"),
        Margins = Convert.ToInt32(txt_margin.Value),
        Logo = logoBmp != null ? new QrLogo { Bitmap = logoBmp, Width = 50, Height = 50, CornerRadius = 5 } : null
    };
}
Private Function CreateStyleOptions() As QrStyleOptions
'INSTANT VB TODO TASK: Throw expressions are not converted by Instant VB:
'ORIGINAL LINE: return new QrStyleOptions { BackgroundColor = bgColor, Color = color, Dimensions = txt_dimension.Value > 0 ? Convert.ToInt32(txt_dimension.Value) : throw new ArgumentException("Please select valid dimensions!"), Margins = Convert.ToInt32(txt_margin.Value), Logo = logoBmp != null ? new QrLogo { Bitmap = logoBmp, Width = 50, Height = 50, CornerRadius = 5 } : null };
	Return New QrStyleOptions With {
		.BackgroundColor = bgColor,
		.Color = color,
		.Dimensions = If(txt_dimension.Value > 0, Convert.ToInt32(txt_dimension.Value), throw New ArgumentException("Please select valid dimensions!")),
		.Margins = Convert.ToInt32(txt_margin.Value),
		.Logo = If(logoBmp IsNot Nothing, New QrLogo With {
			.Bitmap = logoBmp,
			.Width = 50,
			.Height = 50,
			.CornerRadius = 5
		}, Nothing)
	}
End Function
VB   C#

Diese Methode erstellt ein QrStyleOptions-Objekt, das dann von der Logik der QR-Code-Generierung verwendet wird, um die Präferenzen des Benutzers anzuwenden. Die Optionen umfassen:

  • BackgroundColor und Color: Diese Eigenschaften legen die Hintergrund- und Vordergrundfarben des QR-Codes fest und ermöglichen so ein individuelles Aussehen, das dem Branding oder ästhetischen Vorlieben entspricht.
  • Abmessungen: Diese Eigenschaft bestimmt die Größe des QR-Codes und bietet Flexibilität bei der Anpassung des QR-Codes an verschiedene Kontexte oder Medien.
  • Ränder: Diese Eigenschaft legt die Größe des Randes um den QR-Code fest und stellt sicher, dass er von den umgebenden Elementen isoliert ist, was für die Skalierbarkeit entscheidend sein kann.
  • Logo: Wenn der Benutzer ein Logo ausgewählt hat, wird es hier mit bestimmten Abmessungen und einem Eckenradius konfiguriert, um ein ansprechendes Aussehen zu erzielen.

4.7 Speichern des QR-Codes

Die Speicherfunktion wird durch die Schaltfläche "Speichern" ausgelöst, die mit der Methode btn_save_Click verknüpft ist. Diese Methode ruft SaveQRCode auf, der die Speicherlogik implementiert. Dabei wird ein Dialogfeld zum Speichern der Datei angezeigt, in dem der Benutzer das Dateiformat und den Speicherort für den QR-Code auswählen kann.

:path=/static-assets/qr/content-code-examples/tutorials/csharp-qr-code-generator-application-15.cs
private void btn_save_Click(object sender, EventArgs e)
{
    SaveQRCode();
}

private void SaveQRCode()
{
    if (pictureBox.Image == null)
    {
        MessageBox.Show("There is no QR code to save.", "Error");
        return;
    }

    saveFileDialog.Filter = "PNG Files|*.png|JPEG Files|*.jpg";
    saveFileDialog.Title = "Save QR Code";
    saveFileDialog.FileName = "QRCode";

    if (saveFileDialog.ShowDialog() == DialogResult.OK)
    {
        try
        {
            pictureBox.Image.Save(saveFileDialog.FileName, DetermineImageFormat(saveFileDialog.FileName));
            MessageBox.Show("QR Code has been saved!", "Success");
        }
        catch (Exception ex)
        {
            ShowError("An error occurred while saving the QR code", ex.Message);
        }
    }
}
Private Sub btn_save_Click(ByVal sender As Object, ByVal e As EventArgs)
	SaveQRCode()
End Sub

Private Sub SaveQRCode()
	If pictureBox.Image Is Nothing Then
		MessageBox.Show("There is no QR code to save.", "Error")
		Return
	End If

	saveFileDialog.Filter = "PNG Files|*.png|JPEG Files|*.jpg"
	saveFileDialog.Title = "Save QR Code"
	saveFileDialog.FileName = "QRCode"

	If saveFileDialog.ShowDialog() = DialogResult.OK Then
		Try
			pictureBox.Image.Save(saveFileDialog.FileName, DetermineImageFormat(saveFileDialog.FileName))
			MessageBox.Show("QR Code has been saved!", "Success")
		Catch ex As Exception
			ShowError("An error occurred while saving the QR code", ex.Message)
		End Try
	End If
End Sub
VB   C#

Diese Methode prüft, ob ein generierter QR-Code vorhanden ist. Ist dies der Fall, wird dem Benutzer die Möglichkeit geboten, die Datei im PNG- oder JPEG-Format zu speichern. Die Funktion DetermineImageFormat stellt sicher, dass das Bild im richtigen Format gespeichert wird, das auf der vom Benutzer gewählten Dateierweiterung basiert.

:path=/static-assets/qr/content-code-examples/tutorials/csharp-qr-code-generator-application-16.cs
private System.Drawing.Imaging.ImageFormat DetermineImageFormat(string filePath)
{
    return System.IO.Path.GetExtension(filePath).ToLower() == ".jpg" ? System.Drawing.Imaging.ImageFormat.Jpeg : System.Drawing.Imaging.ImageFormat.Png;
}
Private Function DetermineImageFormat(ByVal filePath As String) As System.Drawing.Imaging.ImageFormat
	Return If(System.IO.Path.GetExtension(filePath).ToLower() = ".jpg", System.Drawing.Imaging.ImageFormat.Jpeg, System.Drawing.Imaging.ImageFormat.Png)
End Function
VB   C#

Diese Flexibilität ermöglicht es den Nutzern, das Format zu wählen, das ihren Bedürfnissen am besten entspricht, unabhängig davon, ob die Qualität im Vordergrund steht(PNG) oder Dateigröße(JPEG).

4.8 Zurücksetzen der Anwendung

Die Rücksetzfunktion ist mit einer Schaltfläche "Reset" verknüpft, die die Methode btn_reset_Click aufruft. Diese Methode ruft wiederum ResetFields auf, eine Funktion, die alle Benutzereingaben löscht und die Standardwerte für alle Einstellungen wiederherstellt, einschließlich Textfelder, Farbauswahl und das ausgewählte Logo.

:path=/static-assets/qr/content-code-examples/tutorials/csharp-qr-code-generator-application-17.cs
private void btn_reset_Click(object sender, EventArgs e)
{
    ResetFields();
}

private void ResetFields()
{
    txt_QR.Text = string.Empty;
    txt_dimension.Value = 200;
    txt_margin.Value = 0;
    bgColor = Color.White;
    color = Color.Black;
    txt_selected_color.BackColor = System.Drawing.Color.White;
    txt_selected_bgcolor.BackColor = System.Drawing.Color.Black;
    logoBmp = null;
    selected_logo.Image = null;
    pictureBox.Image = null;
}
Private Sub btn_reset_Click(ByVal sender As Object, ByVal e As EventArgs)
	ResetFields()
End Sub

Private Sub ResetFields()
	txt_QR.Text = String.Empty
	txt_dimension.Value = 200
	txt_margin.Value = 0
	bgColor = Color.White
	color = Color.Black
	txt_selected_color.BackColor = System.Drawing.Color.White
	txt_selected_bgcolor.BackColor = System.Drawing.Color.Black
	logoBmp = Nothing
	selected_logo.Image = Nothing
	pictureBox.Image = Nothing
End Sub
VB   C#

Diese Methode setzt alle an der QR-Code-Generierung beteiligten Komponenten zurück. So wird beispielsweise der QR-Code-Text gelöscht, die Abmessungen und Ränder werden auf Standardwerte gesetzt, und ausgewählte Farben oder Logos werden entfernt.

4.9 Fehlerbehandlung

Die Anwendung verwendet die ShowError-Methode, um Fehlermeldungen auf benutzerfreundliche Weise anzuzeigen. Diese Methode nimmt zwei Parameter entgegen: einen Titel und eine Meldung, die dem Benutzer den Kontext des Fehlers mitteilen. So wird es umgesetzt:

:path=/static-assets/qr/content-code-examples/tutorials/csharp-qr-code-generator-application-18.cs
private static void ShowError(string title, string message)
{
    MessageBox.Show($"{title}: {message}", "Error");
}
Private Shared Sub ShowError(ByVal title As String, ByVal message As String)
	MessageBox.Show($"{title}: {message}", "Error")
End Sub
VB   C#

Diese Methode wird in verschiedenen Teilen der Anwendung eingesetzt, um sicherzustellen, dass der Benutzer beim Auftreten eines Fehlers sofort mit einer klaren und präzisen Meldung informiert wird. Wenn beispielsweise beim Laden des Logos oder bei der QR-Code-Generierung ein Fehler auftritt, ruft die Anwendung ShowError auf, um Details zu dem Problem anzuzeigen.

4.10 Vollständiges Code-Beispiel

Hier ist der vollständige Code, der Ihnen helfen wird, den Code viel leichter zu verstehen:

:path=/static-assets/qr/content-code-examples/tutorials/csharp-qr-code-generator-application-19.cs
using IronQr;
using IronSoftware.Drawing;
using Color = IronSoftware.Drawing.Color;

namespace IronQR_QR_Generator_WinForms
{
    public partial class QR_Generator : Form
    {
        string qrCodesDirectory = System.IO.Path.Combine(Application.StartupPath, "QR Codes");
        Color bgColor = Color.White;
        Color color = Color.Black;
        AnyBitmap? logoBmp = null;

        public QR_Generator()
        {
            InitializeComponent();
            SetLicenseKey();
            EnsureDirectoryExists(qrCodesDirectory);
        }

        private static void SetLicenseKey()
        {
            IronQr.License.LicenseKey = "License-Key";
        }

        private static void EnsureDirectoryExists(string path)
        {
            if (!System.IO.Directory.Exists(path))
            {
                System.IO.Directory.CreateDirectory(path);
            }
        }

        private void btn_color_Click(object sender, EventArgs e)
        {
            UpdateColor(ref color, txt_selected_color, false);
        }

        private void btn_background_Click(object sender, EventArgs e)
        {
            UpdateColor(ref bgColor, txt_selected_bgcolor, true);
        }

        private string ColorToHex(System.Drawing.Color color)
        {
            return $"#{color.R:X2}{color.G:X2}{color.B:X2}";
        }
        private void UpdateColor(ref Color targetColor, Control display, bool isBackground)
        {
            if (select_color.ShowDialog() == DialogResult.OK)
            {

                var hexColor = ColorToHex(select_color.Color);
                targetColor = new Color(hexColor);
                display.BackColor = select_color.Color;
            }
        }

        private void btn_logo_Click(object sender, EventArgs e)
        {
            if (select_logo.ShowDialog() == DialogResult.OK)
            {
                try
                {
                    logoBmp = new AnyBitmap(select_logo.FileName);
                    selected_logo.Image = Image.FromFile(select_logo.FileName);
                }
                catch (Exception ex)
                {
                    ShowError("An error occurred while loading the logo", ex.Message);
                }
            }
        }

        private void btn_generate_Click(object sender, EventArgs e)
        {
            GenerateQRCode();
        }

        private void GenerateQRCode()
        {
            try
            {
                var options = new QrOptions(QrErrorCorrectionLevel.High);
                var myQr = QrWriter.Write(txt_QR.Text, options);
                var style = CreateStyleOptions();
                var qrImage = myQr.Save(style);
                var fileName = $"{DateTime.Now:yyyyMMddHHmmssfff}_QR.png";
                var fullPath = System.IO.Path.Combine(qrCodesDirectory, fileName);
                qrImage.SaveAs(fullPath);
                pictureBox.Image = Image.FromFile(fullPath);
            }
            catch (Exception ex)
            {
                ShowError("An error occurred during QR code generation or saving", ex.Message);
            }
        }

        private QrStyleOptions CreateStyleOptions()
        {
            return new QrStyleOptions
            {
                BackgroundColor = bgColor,
                Color = color,
                Dimensions = txt_dimension.Value > 0 ? Convert.ToInt32(txt_dimension.Value) : throw new ArgumentException("Please select valid dimensions!"),
                Margins = Convert.ToInt32(txt_margin.Value),
                Logo = logoBmp != null ? new QrLogo { Bitmap = logoBmp, Width = 50, Height = 50, CornerRadius = 5 } : null
            };
        }

        private void btn_save_Click(object sender, EventArgs e)
        {
            SaveQRCode();
        }

        private void SaveQRCode()
        {
            if (pictureBox.Image == null)
            {
                MessageBox.Show("There is no QR code to save.", "Error");
                return;
            }

            saveFileDialog.Filter = "PNG Files|*.png|JPEG Files|*.jpg";
            saveFileDialog.Title = "Save QR Code";
            saveFileDialog.FileName = "QRCode";

            if (saveFileDialog.ShowDialog() == DialogResult.OK)
            {
                try
                {
                    pictureBox.Image.Save(saveFileDialog.FileName, DetermineImageFormat(saveFileDialog.FileName));
                    MessageBox.Show("QR Code has been saved!", "Success");
                }
                catch (Exception ex)
                {
                    ShowError("An error occurred while saving the QR code", ex.Message);
                }
            }
        }

        private System.Drawing.Imaging.ImageFormat DetermineImageFormat(string filePath)
        {
            return System.IO.Path.GetExtension(filePath).ToLower() == ".jpg" ? System.Drawing.Imaging.ImageFormat.Jpeg : System.Drawing.Imaging.ImageFormat.Png;
        }

        private void btn_reset_Click(object sender, EventArgs e)
        {
            ResetFields();
        }

        private void ResetFields()
        {
            txt_QR.Text = string.Empty;
            txt_dimension.Value = 200;
            txt_margin.Value = 0;
            bgColor = Color.White;
            color = Color.Black;
            txt_selected_color.BackColor = bgColor;
            txt_selected_bgcolor.BackColor = color;
            logoBmp = null;
            selected_logo.Image = null;
            pictureBox.Image = null;
        }

        private static void ShowError(string title, string message)
        {
            MessageBox.Show($"{title}: {message}", "Error");
        }
    }
}
Imports IronQr
Imports IronSoftware.Drawing
Imports Color = IronSoftware.Drawing.Color

Namespace IronQR_QR_Generator_WinForms
	Partial Public Class QR_Generator
		Inherits Form

		Private qrCodesDirectory As String = System.IO.Path.Combine(Application.StartupPath, "QR Codes")
		Private bgColor As Color = Color.White
		Private color As Color = Color.Black
		Private logoBmp? As AnyBitmap = Nothing

		Public Sub New()
			InitializeComponent()
			SetLicenseKey()
			EnsureDirectoryExists(qrCodesDirectory)
		End Sub

		Private Shared Sub SetLicenseKey()
			IronQr.License.LicenseKey = "License-Key"
		End Sub

		Private Shared Sub EnsureDirectoryExists(ByVal path As String)
			If Not System.IO.Directory.Exists(path) Then
				System.IO.Directory.CreateDirectory(path)
			End If
		End Sub

		Private Sub btn_color_Click(ByVal sender As Object, ByVal e As EventArgs)
			UpdateColor(color, txt_selected_color, False)
		End Sub

		Private Sub btn_background_Click(ByVal sender As Object, ByVal e As EventArgs)
			UpdateColor(bgColor, txt_selected_bgcolor, True)
		End Sub

		Private Function ColorToHex(ByVal color As System.Drawing.Color) As String
			Return $"#{color.R:X2}{color.G:X2}{color.B:X2}"
		End Function
		Private Sub UpdateColor(ByRef targetColor As Color, ByVal display As Control, ByVal isBackground As Boolean)
			If select_color.ShowDialog() = System.Windows.Forms.DialogResult.OK Then

				Dim hexColor = ColorToHex(select_color.Color)
				targetColor = New Color(hexColor)
				display.BackColor = select_color.Color
			End If
		End Sub

		Private Sub btn_logo_Click(ByVal sender As Object, ByVal e As EventArgs)
			If select_logo.ShowDialog() = System.Windows.Forms.DialogResult.OK Then
				Try
					logoBmp = New AnyBitmap(select_logo.FileName)
					selected_logo.Image = Image.FromFile(select_logo.FileName)
				Catch ex As Exception
					ShowError("An error occurred while loading the logo", ex.Message)
				End Try
			End If
		End Sub

		Private Sub btn_generate_Click(ByVal sender As Object, ByVal e As EventArgs)
			GenerateQRCode()
		End Sub

		Private Sub GenerateQRCode()
			Try
				Dim options = New QrOptions(QrErrorCorrectionLevel.High)
				Dim myQr = QrWriter.Write(txt_QR.Text, options)
				Dim style = CreateStyleOptions()
				Dim qrImage = myQr.Save(style)
				Dim fileName = $"{DateTime.Now:yyyyMMddHHmmssfff}_QR.png"
				Dim fullPath = System.IO.Path.Combine(qrCodesDirectory, fileName)
				qrImage.SaveAs(fullPath)
				pictureBox.Image = Image.FromFile(fullPath)
			Catch ex As Exception
				ShowError("An error occurred during QR code generation or saving", ex.Message)
			End Try
		End Sub

		Private Function CreateStyleOptions() As QrStyleOptions
'INSTANT VB TODO TASK: Throw expressions are not converted by Instant VB:
'ORIGINAL LINE: return new QrStyleOptions { BackgroundColor = bgColor, Color = color, Dimensions = txt_dimension.Value > 0 ? Convert.ToInt32(txt_dimension.Value) : throw new ArgumentException("Please select valid dimensions!"), Margins = Convert.ToInt32(txt_margin.Value), Logo = logoBmp != null ? new QrLogo { Bitmap = logoBmp, Width = 50, Height = 50, CornerRadius = 5 } : null };
			Return New QrStyleOptions With {
				.BackgroundColor = bgColor,
				.Color = color,
				.Dimensions = If(txt_dimension.Value > 0, Convert.ToInt32(txt_dimension.Value), throw New ArgumentException("Please select valid dimensions!")),
				.Margins = Convert.ToInt32(txt_margin.Value),
				.Logo = If(logoBmp IsNot Nothing, New QrLogo With {
					.Bitmap = logoBmp,
					.Width = 50,
					.Height = 50,
					.CornerRadius = 5
				}, Nothing)
			}
		End Function

		Private Sub btn_save_Click(ByVal sender As Object, ByVal e As EventArgs)
			SaveQRCode()
		End Sub

		Private Sub SaveQRCode()
			If pictureBox.Image Is Nothing Then
				MessageBox.Show("There is no QR code to save.", "Error")
				Return
			End If

			saveFileDialog.Filter = "PNG Files|*.png|JPEG Files|*.jpg"
			saveFileDialog.Title = "Save QR Code"
			saveFileDialog.FileName = "QRCode"

			If saveFileDialog.ShowDialog() = System.Windows.Forms.DialogResult.OK Then
				Try
					pictureBox.Image.Save(saveFileDialog.FileName, DetermineImageFormat(saveFileDialog.FileName))
					MessageBox.Show("QR Code has been saved!", "Success")
				Catch ex As Exception
					ShowError("An error occurred while saving the QR code", ex.Message)
				End Try
			End If
		End Sub

		Private Function DetermineImageFormat(ByVal filePath As String) As System.Drawing.Imaging.ImageFormat
			Return If(System.IO.Path.GetExtension(filePath).ToLower() = ".jpg", System.Drawing.Imaging.ImageFormat.Jpeg, System.Drawing.Imaging.ImageFormat.Png)
		End Function

		Private Sub btn_reset_Click(ByVal sender As Object, ByVal e As EventArgs)
			ResetFields()
		End Sub

		Private Sub ResetFields()
			txt_QR.Text = String.Empty
			txt_dimension.Value = 200
			txt_margin.Value = 0
			bgColor = Color.White
			color = Color.Black
			txt_selected_color.BackColor = bgColor
			txt_selected_bgcolor.BackColor = color
			logoBmp = Nothing
			selected_logo.Image = Nothing
			pictureBox.Image = Nothing
		End Sub

		Private Shared Sub ShowError(ByVal title As String, ByVal message As String)
			MessageBox.Show($"{title}: {message}", "Error")
		End Sub
	End Class
End Namespace
VB   C#

Schritt 5: Anwendung ausführen

Wenn die Anwendung ausgeführt wird, erscheint das Hauptfenster wie in der Abbildung gezeigt. Das Layout ist übersichtlich in Abschnitte für Eingabe, Styling, Ausgabe und Aktionen gegliedert.

Anwendung Ausgabe

Der erste Schritt des Prozesses besteht in der Eingabe von Daten in das Feld "Input QR Text". Diese Daten bilden den Inhalt des QR-Codes, z. B. eine URL oder Textinformationen. Um den QR-Code zu personalisieren, wählen wir ein Logo aus, indem wir auf die Schaltfläche "Logo auswählen" klicken. Nach der Auswahl wird das Logo sichtbar im Vorschaufeld neben der Schaltfläche platziert, um seine Einbindung in das QR-Code-Design zu bestätigen.

Logo

Nach der Auswahl des Logos wählen wir die Vorder- und Hintergrundfarben des QR-Codes. Nach dem Anklicken der entsprechenden Schaltflächen werden die gewählten Farben in den Farbanzeigefeldern neben den einzelnen Schaltflächen angezeigt, so dass wir eine sofortige visuelle Bestätigung unserer Auswahl erhalten.

Farbwähler

Für diesen speziellen QR-Code haben wir die Abmessungen auf 500 gesetzt, um sicherzustellen, dass der Code eine für unsere Bedürfnisse geeignete Größe hat, und die Ränder auf 20 eingestellt, was einen Puffer um den QR-Code herum bietet, um Probleme beim Scannen zu vermeiden.

Abmessungen

Nachdem alle Eingaben und Gestaltungsoptionen festgelegt wurden, wird der QR-Code durch Klicken auf die Schaltfläche "QR-Code generieren" erstellt. Die Anwendung verarbeitet unsere Eingaben und zeigt den frisch erstellten QR-Code in der Ausgabebildbox an.

QR-Codes lesen Ausgabe

Um den generierten QR-Code zu speichern, klicken wir einfach auf die Schaltfläche "QR speichern". Diese Aktion öffnet einen Speicherdialog, in dem wir das Ziel und das Dateiformat für unser QR-Code-Bild auswählen können.

Dialog speichern

Nach dem Speichern bestätigt eine Erfolgsmeldung, dass der QR-Code erfolgreich gespeichert wurde.

Erfolgsmeldung

Wenn wir von vorne beginnen oder einen neuen QR-Code erstellen müssen, können wir durch Klicken auf die Schaltfläche "Formular zurücksetzen" das Formular in seinen ursprünglichen Zustand zurückversetzen und alle Felder und Auswahlen löschen, damit wir den nächsten QR-Code erstellen können.

Formular zurücksetzen

Hier ist der gespeicherte QR-Code, der von IronQR generiert wurde:

QR-Code-Ausgabe

Schlussfolgerung

Abschließend haben wir Sie in dieser Anleitung durch den Prozess der Erzeugung von QR-Codes mit der IronQR-Bibliothek in einer C#-Anwendung geführt. Indem wir die Schritte vom Einrichten Ihres Projekts in Visual Studio über das Integrieren der IronQR-Bibliothek und das Entwerfen einer benutzerfreundlichen Oberfläche bis hin zum Schreiben der Backend-Logik aufgeschlüsselt haben, haben wir gezeigt, wie einfach es ist, QR-Code-Funktionen zu Ihren Anwendungen hinzuzufügen.

Für diejenigen, die die Möglichkeiten von IronQR weiter erforschen möchten, ist es erwähnenswert, dass IronQR eine kostenloser Test um Ihnen den Einstieg zu erleichtern. Sollten Sie sich entscheiden, IronQR in Ihre Projekte zu integrieren, beginnen die Lizenzen bei $749 und bieten eine kostengünstige Lösung für die professionelle QR-Code-Generierung.