Get Jpeg Information : Jpeg « 2D Graphics « VB.Net Tutorial






' Quote from
'Visual Basic 2005 Cookbook Solutions for VB 2005 Programmers
'by Tim Patrick (Author), John Craig (Author)
'# Publisher: O'Reilly Media, Inc. (September 21, 2006)
'# Language: English
'# ISBN-10: 0596101775
'# ISBN-13: 978-0596101770



Imports System.Drawing
Imports System.Drawing.Drawing2D
Imports System.Windows.Forms

Public Class GetJpgInformation
    Public Shared Sub Main
        Console.WriteLine(ProcessJPEG.GetJpgInformation("yourfile.jpg"))
    End Sub
End Class


Public Class ProcessJPEG
    Public Shared Function GetJpgInformation(ByVal whichFile As String) As String
        Dim bytesPropertyID As Byte()
        Dim stringPropertyID As String
        Dim loadedImage As System.Drawing.Bitmap
        Dim propertyIDs() As Integer
        Dim result As New System.Text.StringBuilder
        Dim counter As Integer
        Dim scanProperty As Integer

        loadedImage = New System.Drawing.Bitmap(whichFile)
        propertyIDs = loadedImage.PropertyIdList

        For Each scanProperty In propertyIDs
            bytesPropertyID = loadedImage.GetPropertyItem(scanProperty).Value
            stringPropertyID = System.Text.Encoding.ASCII.GetString(bytesPropertyID)

            For counter = 0 To 255
                If counter < 32 Or counter > 127 Then
                    If (stringPropertyID.IndexOf(Chr(counter)) _
                          <> -1) Then
                        stringPropertyID = Replace(stringPropertyID, _
                           Chr(counter), "")
                    End If
                End If
            Next counter

            ' ----- Display the property if it's reasonable.
            If (stringPropertyID.Length > 0) And _
                  (stringPropertyID.Length < 70) Then
                result.Append(scanProperty.ToString)
                result.Append(":   ")
                result.AppendLine(stringPropertyID)
            End If
        Next scanProperty

        ' ----- Display the results.
        Return result.ToString
    End Function

    Public Shared Function GetString( _
      ByVal sourceBytes As Byte()) As String
        ' ----- Convert a byte array to a string, taking into
        '       account the terminating null character.
        Dim result As String

        result = System.Text.Encoding.ASCII.GetString(sourceBytes)
        If (result.EndsWith(vbNullChar) = True) Then _
           result = result.Substring(0, result.Length - 1)
        Return result
    End Function
End Class








17.70.Jpeg
17.70.1.Create Jpeg File
17.70.2.Get Jpeg Information
17.70.3.JPEG Compression