using IronQr;
using IronSoftware.Drawing;
// Create a QR Code object
QrCode myQr = QrWriter.Write("hello world");
// Save QR Code as a Bitmap
AnyBitmap qrImage = myQr.Save();
// Save QR Code Bitmap as File
qrImage.SaveAs("qr.png");
Willkommen zu unserem Leitfaden über die Erstellung von QR-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 diesem Leitfaden zeigen wir Ihnen, wie Sie mithilfe von IronQR effizient QR-Codes erstellen können, damit Sie QR-Codes nach Ihren Bedürfnissen erstellen können. 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.
Wie man einen QR Code Generator in C# erstellt;
Erstellen einer Windows Forms-Anwendung in Visual Studio
QR-Bibliothek mit NuGet installieren
Gestaltung der Frontend-Elemente des Formulars
Schreiben Sie die Logik der QR-Generierung5. Starten Sie die Anwendung und beginnen Sie mit der Erstellung von QR-Codes
IronQR: C# QR-Bibliothek
IronQR ist eine C# QR-Code-Bibliothek zur Integration von QR-Code-Funktionalität 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 erweiterten Funktionen aus, darunter die Möglichkeit, QR-Codes zu lesen und QR-Codes zu erstellen, Unterstützung für mehrere Bildformate sowie Anpassungsoptionen wie Größenänderung, Stilgebung und das 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.
using IronQr;
using IronSoftware.Drawing;
using Color = IronSoftware.Drawing.Color;
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
}
using IronQr;
using IronSoftware.Drawing;
using Color = IronSoftware.Drawing.Color;
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
}
IRON VB CONVERTER ERROR developers@ironsoftware.com
$vbLabelText $csharpLabel
Wir verwenden den folgenden QR-Code zum Scannen:
Und wir erhielten diese Ausgabe:
Der Prozess beginnt mit der Einbindung der notwendigen Namespaces, IronQr und IronSoftware.Drawing, mit einer speziellen Erwähnung von Color aus dem IronSoftware.Drawing Namespace, um Bildbearbeitungen durchzuführen.
Bevor Sie mit dem QR-Code-Leseprozess beginnen, ist es wichtig, die Software mit Ihrem Lizenzschlüssel zu aktivieren, indem Sie ihn IronQr.License.LicenseKey zuweisen. Der Code fährt dann fort, das QR-Code-Bild aus einer Datei mit AnyBitmap.FromFile("QRCode.png") zu laden.
Nachdem das Bild geladen wurde, muss es im nächsten Schritt für die QR-Code-Erkennung vorbereitet werden. Diese Vorbereitung erfolgt durch Erstellen eines QrImageInput-Objekts, das als Container für das Bild dient.
Der Kern dieser Funktion liegt in der QrReader-Klasse, die instanziiert und verwendet wird, um die QR-Code-Leseoperation durchzuführen. Der Reader analysiert das vorbereitete Bild, qrInput, und sucht nach QR-Codes, die es enthält. Das Ergebnis dieser Operation ist eine Sammlung von QrResult-Objekten, von denen jedes einen erkannten QR-Code innerhalb des Bildes repräsentiert.
Um auf die in den QR-Codes kodierten Daten zuzugreifen und diese 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 Mixed Scan Mode, der Geschwindigkeit und Genauigkeit ausbalanciert und nützlich ist, wenn QR-Codes nicht klar oder teilweise versteckt sind.
Ein weiteres Merkmal ist der Machine Learning (ML) Scan-Modus, der intelligente Technologie nutzt, um QR-Codes zu lesen, die beschädigt oder normalerweise schwer lesbar sind. Dieser Modus ist ideal für schwierige Situationen, in denen QR-Codes schwer zu erkennen sind.
Zuletzt gibt es den Basic Scan Mode, der die schnellste und einfachste Methode ist, um klare und unkomplizierte QR-Codes zu scannen. Es ist am besten, wenn Sie schnelle Ergebnisse benötigen und die QR-Codes leicht zu lesen sind.
using IronQr;
using IronQr.Enum;
using IronSoftware.Drawing;
using Color = IronSoftware.Drawing.Color;
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);
using IronQr;
using IronQr.Enum;
using IronSoftware.Drawing;
using Color = IronSoftware.Drawing.Color;
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 Color = IronSoftware.Drawing.Color
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)
$vbLabelText $csharpLabel
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.
using IronQr;
using IronQr.Enum;
using IronSoftware.Drawing;
using Color = IronSoftware.Drawing.Color;
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}");
}
}
using IronQr;
using IronQr.Enum;
using IronSoftware.Drawing;
using Color = IronSoftware.Drawing.Color;
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 IronQr.Enum
Imports IronSoftware.Drawing
Imports Color = IronSoftware.Drawing.Color
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
$vbLabelText $csharpLabel
Dies ist die Ausgabe, wenn wir den QR-Code mit IronQR scannen:
Wir verwenden den folgenden QR-Code:
Jedes QrResult-Objekt ermöglicht den Zugriff auf die dekodierten Daten (Value), eingebettete URLs (Url) und die räumlichen Koordinaten (Points) 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. Darüber hinaus bietet die Bibliothek die genauen Koordinaten der Ecken des QR-Codes im Bild (über die Points-Eigenschaft).
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 Windows Forms App als Projekttyp aus. Stellen Sie sicher, dass Sie C# als Sprache wählen.
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. Dann klicken Sie auf Erstellen.
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.
Finden Sie IronQR in der Liste und klicken Sie auf Installieren daneben.
Installation über die NuGet-Paketmanager-Konsole
Gehe zu Tools > NuGet-Paket-Manager > Paket-Manager-Konsole.
Geben Sie Install-Package IronQR ein und drücken Sie die Eingabetaste.
Schritt 3: Frontend gestalten
3.1 Titel Kopfzeile
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
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
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
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
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
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
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
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
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
Zuerst beginnt die Anwendung mit der Einbindung 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 Color-Klasse wird definiert, um das Farbmanagement bei der QR-Code-Erstellung zu erleichtern, indem sie die Standardklasse System.Drawing.Color überschreibt, um die Kompatibilität mit den Anforderungen von IronQR sicherzustellen.
using IronQr;
using IronSoftware.Drawing;
using Color = IronSoftware.Drawing.Color;
using IronQr;
using IronSoftware.Drawing;
using Color = IronSoftware.Drawing.Color;
Imports IronQr
Imports IronSoftware.Drawing
Imports Color = IronSoftware.Drawing.Color
$vbLabelText $csharpLabel
Der Konstruktor der QR_Generator-Klasse 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.
public QR_Generator()
{
InitializeComponent();
SetLicenseKey();
EnsureDirectoryExists(qrCodesDirectory);
}
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
$vbLabelText $csharpLabel
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: Angesichts der Notwendigkeit, generierte QR-Codes zu speichern, stellt diese Methode sicher, dass ein dediziertes Verzeichnis verfügbar 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 SetLicenseKey-Methode erreicht, eine statische Methode, die dazu dient, die Bibliothek mit Ihrem gekauften oder Testlizenzschlüssel zu konfigurieren. Das folgende Codeschnipsel veranschaulicht, wie Sie den Lizenzschlüssel festlegen:
Private Shared Sub SetLicenseKey()
IronQr.License.LicenseKey = "YOUR_LICENSE_KEY"
End Sub
$vbLabelText $csharpLabel
Ersetzen Sie "YOUR\_LICENSE\_KEY" durch den tatsächlichen Lizenzschlüssel, den Sie von Iron Software erhalten haben. Die Methode wird im Konstruktor der QR_Generator-Klasse aufgerufen, um sicherzustellen, dass die Lizenz angewendet wird, sobald die Anwendung startet und bevor eine QR-Code-Generierung stattfindet.
4.3 Verzeichnisverwaltung
Die Anwendung verwendet die EnsureDirectoryExists-Methode, um zu überprüfen, ob das angegebene Verzeichnis zum Speichern von QR-Codes existiert. Wenn nicht, wird das Verzeichnis erstellt. Diese Methode nimmt einen string-Parameter entgegen, der den Pfad des Verzeichnisses darstellt, das überprüft oder erstellt werden soll. So wird es umgesetzt:
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
$vbLabelText $csharpLabel
Diese Methode verwendet den System.IO-Namensraum, um mit dem Dateisystem zu interagieren. Zuerst wird überprüft, ob das Verzeichnis am angegebenen Pfad existiert, indem Directory.Exists verwendet wird. Falls das Verzeichnis nicht existiert (false wird zurückgegeben), wird das Verzeichnis mit Directory.CreateDirectory erstellt.
Der Pfad zum Verzeichnis der QR-Codes wird im Konstruktor der QR_Generator-Klasse als qrCodesDirectory definiert, welcher den Startpfad der Anwendung mit dem Ordnernamen "QR Codes" kombiniert:
Dim qrCodesDirectory As String = System.IO.Path.Combine(Application.StartupPath, "QR Codes")
$vbLabelText $csharpLabel
4.4 Farbauswahl
Die Anwendung bietet zwei Schaltflächen in 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 über die ColorToHex-Methode:
Private Function ColorToHex(ByVal color As System.Drawing.Color) As String
Return $"#{color.R:X2}{color.G:X2}{color.B:X2}"
End Function
$vbLabelText $csharpLabel
Die UpdateColor-Methode nimmt die ausgewählte Farbe und konvertiert sie in das IronSoftware.Drawing.Color-Format unter Verwendung des hexadezimalen Strings und aktualisiert je nach Auswahl entweder die Vordergrund- oder Hintergrundfarbe des QR-Codes. Außerdem wird die Benutzeroberfläche aktualisiert, um die neue Farbauswahl widerzuspiegeln:
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 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
$vbLabelText $csharpLabel
4.5 Hinzufügen eines Logos
Die Anwendung enthält eine Schaltfläche (btn_logo_Click), die, wenn sie angeklickt wird, einen Dateidialog öffnet, der es dem Benutzer ermöglicht, eine Bilddatei auszuwählen, 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:
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_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
$vbLabelText $csharpLabel
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 QR-Generierungslogik später verwendet.
4.6 QR-Code-Erzeugung
Der Generierungsprozess beginnt, wenn der Benutzer auf die Schaltfläche „Generate“ klickt, die mit der Methode btn\_generate\_Click verknüpft ist. Diese Methode fungiert als Auslöser, indem sie die GenerateQRCode-Funktion aufruft, in der die eigentliche Generierungslogik steckt.
Private Sub btn_generate_Click(ByVal sender As Object, ByVal e As EventArgs)
GenerateQRCode()
End Sub
$vbLabelText $csharpLabel
Innerhalb der GenerateQRCode-Methode konstruiert die Anwendung einen QR-Code basierend auf den angegebenen Parametern, 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.
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 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
$vbLabelText $csharpLabel
Das QrOptions-Objekt definiert das Fehlertoleranzlevel und verbessert dadurch die Widerstandsfähigkeit des QR-Codes gegenüber Beschädigungen oder Verdeckung. Die CreateStyleOptions-Methode generiert ein QrStyleOptions-Objekt, das die benutzerdefinierten Einstellungen wie Farben, Abmessungen und das Logo enthält. Hier ist die Methode im Detail:
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
$vbLabelText $csharpLabel
Diese Methode erstellt ein QrStyleOptions-Objekt, das dann von der QR-Code-Generierungslogik verwendet wird, um die Benutzerpräferenzen anzuwenden. Die Optionen umfassen:
BackgroundColor und Color: Diese Eigenschaften legen die Hintergrund- und Vordergrundfarben des QR-Codes fest und ermöglichen ein personalisiertes Aussehen, das zu Marken oder ästhetischen Vorlieben passt.
Dimensions: Diese Eigenschaft bestimmt die Größe des QR-Codes und bietet Flexibilität in Bezug darauf, wie der QR-Code in verschiedenen Kontexten oder Medien passt.
Margins: Diese Eigenschaft legt die Randgröße um den QR-Code fest und stellt sicher, dass er von umliegenden Elementen isoliert ist, was für die Skalierbarkeit entscheidend sein kann.
Logo: Wenn der Benutzer sich entschieden hat, ein Logo einzufügen, wird es hier mit spezifischen Abmessungen und einem Eckradius für ein gepflegtes Aussehen konfiguriert.
4.7 Speichern des QR-Codes
Die Speicherfunktion wird durch die "Speichern"-Schaltfläche ausgelöst, die mit der btn\_save\_Click-Methode verknüpft ist. Diese Methode ruft SaveQRCode auf, das 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.
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 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
$vbLabelText $csharpLabel
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, basierend auf der vom Benutzer gewählten Dateierweiterung.
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
$vbLabelText $csharpLabel
Diese Flexibilität ermöglicht es den Nutzern, das Format zu wählen, das am besten zu ihren Bedürfnissen passt, sei es die Priorisierung der Qualität (PNG) oder der Dateigröße (JPEG).
4.8 Zurücksetzen der Anwendung
Die Zurücksetzfunktion ist mit einem "Reset"-Button verbunden, der die btn\_reset\_Click-Methode aufruft. Diese Methode ruft wiederum ResetFields auf, eine Funktion, die dazu dient, alle Benutzereingaben zu löschen und Standardwerte für alle Einstellungen wiederherzustellen, einschließlich Textfeldern, Farbauswahlen und dem ausgewählten Logo.
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
$vbLabelText $csharpLabel
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 benutzerfreundlich anzuzeigen. Diese Methode nimmt zwei Parameter entgegen: einen Titel und eine Meldung, die dem Benutzer den Kontext des Fehlers mitteilen. So wird es umgesetzt:
Private Shared Sub ShowError(ByVal title As String, ByVal message As String)
MessageBox.Show($"{title}: {message}", "Error")
End Sub
$vbLabelText $csharpLabel
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. Beispielsweise ruft die Anwendung ShowError auf, um Details zum Problem anzuzeigen, wenn ein Fehler beim Laden des Logos oder während des QR-Code-Generierungsprozesses auftritt.
4.10 Vollständiges Code-Beispiel
Hier ist der vollständige Code, der Ihnen helfen wird, den Code viel leichter zu verstehen:
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");
}
}
}
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
$vbLabelText $csharpLabel
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.
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.
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.
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.
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.
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.
Nach dem Speichern bestätigt eine Erfolgsmeldung, dass der QR-Code erfolgreich gespeichert wurde.
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.
Hier ist der gespeicherte QR-Code, der von IronQR generiert wurde:
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 daran interessiert sind, die Fähigkeiten von IronQR weiter zu erkunden, ist es erwähnenswert, dass IronQR eine kostenlose Testversion anbietet, um Ihnen den Einstieg zu erleichtern. Wenn Sie sich entscheiden, IronQR in Ihre Projekte zu integrieren, beginnen die Lizenzen bei $749 und bieten eine kosteneffektive Lösung für die professionelle QR-Code-Generierung.
Jordi beherrscht vor allem Python, C# und C++. Wenn er seine Fähigkeiten bei Iron Software nicht einsetzt, programmiert er Spiele. Durch seine Mitverantwortung für Produkttests, Produktentwicklung und Forschung trägt Jordi wesentlich zur kontinuierlichen Produktverbesserung bei. Die vielseitigen Erfahrungen, die er sammelt, bieten ihm immer wieder neue Herausforderungen, und er sagt, dass dies einer seiner Lieblingsaspekte bei Iron Software ist. Jordi wuchs in Miami, Florida, auf und studierte Informatik und Statistik an der University of Florida.