|
| |

VB.NET - Fortgeschrittene| Datamatrix (2D-Code) größe an Rahmen anpassen | |  | | Autor: Erichbru | | Datum: 24.07.25 13:49 |
|
so erstelle und speichere ich den Matrix Code (bzw. die Image) dazu verwende ich diese dll
"MessagingToolkit.Barcode.dll"
Private Sub btn_Generieren_Click(sender As Object, e As EventArgs) Handles _
Btn_Generate.Click
If String.IsNullOrEmpty(txtqrcode.Text) Then Return
Dim generate As New MessagingToolkit.Barcode.BarcodeEncoder
generate.BackColor = Color.White
generate.LabelFont = New Font("Arial", 7, FontStyle.Regular)
generate.IncludeLabel = True
generate.CustomLabel = txtqrcode.Text
Try
picqrcode.Image = New Bitmap(generate.Encode( _
MessagingToolkit.Barcode.BarcodeFormat.QRCode, txtqrcode.Text))
picqrcode.SizeMode = PictureBoxSizeMode.CenterImage
'Now to Datatable or Datagridview
If Me.PicturesBindingSource.Current Is Nothing Then _
Me.PicturesBindingSource.AddNew()
Dim rw = DirectCast(DirectCast(Me.PicturesBindingSource.Current, _
DataRowView).Row, PicturesRow)
rw.Picdate = Now.ToShortDateString ' Pfad des Datamatrix in
' Spalte schreiben
rw.Picname = txtqrcode.Text ' Datamatrixname in
' Spalte schreiben
rw.Picpath = String.Concat(datamatrixpath.ToString & "/" & _
txtqrcode.Text & ".png")
Me.PicturesBindingSource.EndEdit()
'Save New datarow
dtsSave()
'Datagridview neu zeichnen
DataGridView1.Refresh()
'Datamatrix ablegen
Save_data()
Catch ex As Exception
picqrcode.Image = Nothing
End Try
End Sub
Private Sub Save_data()
Try
If Me.picqrcode.Image IsNot Nothing Then
Me.picqrcode.Image.Save(IO.Path.Combine(datamatrixpath, _
txtqrcode.Text & ".png"))
End If
Label1.Text = "Data Speicherort:"
txtqrcode.ReadOnly = True
Btn_Generate.Enabled = False
FillGridWithFolderPictures()
PicturesBindingSource.MoveLast()
Datagridview1_SelectRow()
Status_fertig()
PicturesBindingSource.MoveLast()
Catch ex As Exception
End Try
End Subnun gefällt mir der Ausdruck nicht besonders die Matrix Image ist nicht wie ich es wünsche in Rahmengröße
hier versuche ich es mit der SizeMode Methode nur funktioniert es nicht so wie es soll
ist oben im Bild deutlich zu erkennen links und rechts Rahmen
picqrcode.Image = Resize_Image(New Bitmap(Image.FromFile( _
datamatrix_TypRow.Picpath)))
picqrcode.SizeMode = PictureBoxSizeMode.CenterImage andere Einstellung wollen nicht passen, entweder verzerrt es das Bild und der Code kann nicht mehr ordentlich gelesen werden
wer hat da eine erfolgreiche Idee das in den Rahmen rein zu bekommen ?
hier auch noch die Resize_Image Function
Private Function Resize_Image(ByVal _obmp As Bitmap) As Bitmap
Dim _nbmp As New Bitmap(100, 100)
Dim _obmp_width As Single = _obmp.Width
Dim _obmp_height As Single = _obmp.Height
Dim _obmp_factor As Single = _obmp_width / _obmp_height
Do While _obmp_width > 100
_obmp_width -= _obmp_width / 100
_obmp_height = _obmp_width / _obmp_factor
Loop
Do While _obmp_height > 100
_obmp_width -= _obmp_width / 100
_obmp_height = _obmp_width / _obmp_factor
Loop
Dim _xcenter As Integer = CInt((100 - _obmp_width) / 2)
Dim _ycenter As Integer = CInt((100 - _obmp_height) / 2)
Using g As Graphics = Graphics.FromImage(_nbmp)
g.InterpolationMode = Drawing2D.InterpolationMode.Bilinear
g.SmoothingMode = Drawing2D.SmoothingMode.HighQuality
g.DrawImage(_obmp, _xcenter, _ycenter, _obmp_width, _obmp_height)
End Using
Return _nbmp
End Function |  |
 | Sie sind nicht angemeldet! Um auf diesen Beitrag zu antworten oder neue Beiträge schreiben zu können, müssen Sie sich zunächst anmelden.
Einloggen | Neu registrieren |
  |
|
sevGraph (VB/VBA) 
Grafische Auswertungen
Präsentieren Sie Ihre Daten mit wenig Aufwand in grafischer Form. sevGraph unterstützt hierbei Balken-, Linien- und Stapel-Diagramme (Stacked Bars), sowie 2D- und 3D-Tortendiagramme und arbeitet vollständig datenbankunabhängig! Weitere InfosTipp des Monats Access-Tools Vol.1 
Über 400 MByte Inhalt
Mehr als 250 Access-Beispiele, 25 Add-Ins und ActiveX-Komponenten, 16 VB-Projekt inkl. Source, mehr als 320 Tipps & Tricks für Access und VB
Nur 24,95 EURWeitere Infos
|
| |
|
Copyright ©2000-2025 vb@rchiv Dieter Otter Alle Rechte vorbehalten.
Microsoft, Windows und Visual Basic sind entweder eingetragene Marken oder Marken der Microsoft Corporation in den USA und/oder anderen Ländern. Weitere auf dieser Homepage aufgeführten Produkt- und Firmennamen können geschützte Marken ihrer jeweiligen Inhaber sein.
Diese Seiten wurden optimiert für eine Bildschirmauflösung von mind. 1280x1024 Pixel
|
|