Platforms to show: All Mac Windows Linux Cross-Platform

/DynaPDF/PDF Color Analyze per Page


Required plugins for this example: MBS DynaPDF Plugin

You find this example project in your Plugins Download as a Xojo project file within the examples folder: /DynaPDF/PDF Color Analyze per Page

This example is the version from Sun, 17th Mar 2012.

Project "PDF Color Analyze per Page.xojo_binary_project"
Class App Inherits Application
Const kEditClear = "&Löschen"
Const kFileQuit = "Beenden"
Const kFileQuitShortcut = ""
End Class
FileTypes1
Filetype PDF
End FileTypes1
Class Window1 Inherits Window
Control List Inherits Listbox
ControlInstance List Inherits Listbox
EventHandler Function CellBackgroundPaint(g As Graphics, row As Integer, column As Integer) As Boolean // if _ column <> 1 or _ row > me.ListCount - 1 or _ me.CellTag( row, 0 ) = Nil _ then // Return( False ) end if // g.ForeColor = me.CellTag( row, 0 ) g.FillRect( 0, 0, g.Width, g.Height ) // Return( False ) End EventHandler
End Control
Control PushButton1 Inherits PushButton
ControlInstance PushButton1 Inherits PushButton
EventHandler Sub Action() // dim f As FolderItem = GetOpenFolderItem( FileTypes1.PDF ) // if f = Nil or f.Exists = False then // Return end if // Call Analyze( f ) End EventHandler
End Control
Control Pop_Encoding Inherits PopupMenu
ControlInstance Pop_Encoding Inherits PopupMenu
End Control
Function Analyze(f As FolderItem) As Boolean // List.DeleteAllRows List.ScrollPosition = 0 // if f = Nil or f.Exists = False then // GoTo myReturn_False end if dim PageCount as integer = 1 for iPage As Integer = 1 to PageCount // dim pdf As New MyDynapdfMBS pdf.SetLicenseKey "Pro" // For this example you can use a Pro or Enterprise License if Not pdf.CreateNewPDF( Nil ) then // MsgBox( "ERROR: Out of Memory!" ) // GoTo myReturn_False end if // if pdf.OpenImportFile( f, pdf.kptopen, "" ) <> 0 then // MsgBox( "ERROR: Wrong 'Type / PWD / etc'?" ) // GoTo myReturn_False end if PageCount = pdf.GetInPageCount call pdf.SetImportFlags(pdf.kifImportAll+pdf.kifImportAsPage) // // Call pdf.ImportPage( iPage) // List.AddRow "Page: " + Str( iPage ) List.AddRow "##################################################" // for iCs As Integer = 0 to pdf.GetColorSpaceCount - 1 // dim cp As DynapdfColorSpaceMBS = pdf.GetColorSpaceObj( iCs) // List.AddRow "" List.AddRow "##### New Color: (" +Str( iCs ) + ") ##########" // List.AddRow "Type: " + Str( cp.Type ) + ": " + ColorSpaceType_Get_Name( cp.Type ) List.AddRow " Colorants: " + Colorants_Get( cp ) List.AddRow " Attributes: " + Attributes_Get( cp ) List.AddRow " Alternate: " + Str( cp.AlternateType ) + ": " + ColorSpaceType_Get_Name( cp.AlternateType ) List.AddRow " NumInComponents: " + Str( cp.NumInComponents ) List.AddRow " NumOutComponents: " + Str( cp.NumOutComponents ) // Is separation colorspace if cp.Type = DynapdfMBS.kesSeparation then // dim c1( -1 ) As Double = Array( 1.00 ) dim c2 As Integer = pdf.ConvColor( c1, cp.Handle, DynapdfMBS.kesDeviceCMYK ) List.AddRow " Color Value (CMYK): " + Str( c2 ) // Show the colors List.CellTag( List.LastIndex, 0 ) = CMYK_Color_Get_RbColor( c2 ) // Add the color values dim dColors( -1 ) As Double = CMYK_Color_Get_Values( c2 ) dim sColor( -1 ) As String for iCount As Integer = 0 to UBound( dColors ) sColor.Append Str( dColors( iCount ) ) next List.Cell( List.LastIndex, 0 ) = List.Cell( List.LastIndex, 0 ) + " - " + Join( sColor, ", " ) end if // Has an alternate handle dim cp2 As DynapdfColorSpaceMBS = cp.Alternate if cp2 <> nil then List.AddRow " Type: " + Str( cp2.Type ) + ": " + ColorSpaceType_Get_Name( cp2.type ) List.AddRow " Colorants: " + Colorants_Get( cp2 ) List.AddRow " Attributes: " + Attributes_Get( cp2 ) List.AddRow " Alternate: " + Str( cp2.AlternateType ) + ": " + ColorSpaceType_Get_Name( cp2.AlternateType ) List.AddRow " NumInComponents: " + Str( cp2.NumInComponents ) List.AddRow " NumOutComponents: " + Str( cp2.NumOutComponents ) end if next // Next colorspace // Clean up Call pdf.CloseImportFile Call pdf.CloseFile Call pdf.FreePDF next // Next page // Return( True ) // myReturn_False: // Return( False ) End Function
Function Attributes_Get(cp As DynapdfColorSpaceMBS) As string // dim d As DynaPDFDeviceNAttributesMBS = cp.DeviceNAttributes if d <> Nil then // dim ss( -1 ) As string dim cc As integer = d.SeparationsCount - 1 // for ii As integer = 0 to cc ss.Append Str( d.Separations( ii ) ) next // dim tt( -1 ) As string cc = d.ProcessColorantsCount - 1 // for ii As integer = 0 to cc tt.Append d.ProcessColorants( ii ) next // Return( "Separations: " + Join( ss,", " ) + ", ProcessColorants: " + Join( tt,", " ) ) end if // Return( "none" ) End Function
Function CMYK_Color_Get_RbColor(i As Integer) As Color // dim dFakt As Double = 1 / 255 // dim c, m, y, k As Double // c = dFakt * DynapdfMBS.CofCMYK( i ) m =dFakt * DynapdfMBS.MofCMYK( i ) y = dFakt * DynapdfMBS.YofCMYK( i ) k = dFakt * DynapdfMBS.KofCMYK( i ) // add black 'dirty' c = Min( c + k, 1 ) m = Min( m + k, 1 ) Y = Min( y + k, 1 ) // Return( CMY( c, m, y ) ) End Function
Function CMYK_Color_Get_Values(i As Integer) As Double() // dim d( -1 ) As Double // d.Append DynapdfMBS.CofCMYK( i ) d.Append DynapdfMBS.MofCMYK( i ) d.Append DynapdfMBS.YofCMYK( i ) d.Append DynapdfMBS.KofCMYK( i ) // Return( d ) End Function
Function ColorSpaceType_Get_Name(kesN As integer) As string // dim s As string // Select Case kesN Case DynaPDFMBS.kesDeviceRGB // Device color space s = "DeviceRGB" Case DynaPDFMBS.kesDeviceCMYK // Device color space s = "DeviceCMYK" Case DynaPDFMBS.kesDeviceGray // Device color space s = "DeviceGray" Case DynaPDFMBS.kesCalGray // CIE-based color space s = "CalGray" Case DynaPDFMBS.kesCalRGB // CIE-based color space s = "CalRGB" Case DynaPDFMBS.kesLab // CIE-based color space s = "Lab" Case DynaPDFMBS.kesICCBased // ICC-based color space -> contains an ICC profile s = "ICCBased " Case DynaPDFMBS.kesPattern // Special color space s = "Pattern" Case DynaPDFMBS.kesIndexed // Special color space s = "Indexed " Case DynaPDFMBS.kesSeparation // Special color space s = "Separation" Case DynaPDFMBS.kesDeviceN // Special color space s = "DeviceN" Case DynaPDFMBS.kesNChannel // Special color space s = "NChannel" else s = "?" end Select // Return( s ) End Function
Function Colorants_Clean(s As String) As String // dim sBack As String // Select Case Pop_Encoding.ListIndex Case 0 sBack = DefineEncoding( s, Encodings.UTF8 ) Case 1 sBack = DefineEncoding( s, Encodings.MacRoman ) Case 2 sBack = DefineEncoding( s, Encodings.WindowsANSI ) Case 3 sBack = DefineEncoding( s, Encodings.ASCII ) End Select // for i As Integer = 0 to 31 if InStr( sBack, Chr( i ) ) > 0 then sBack = ReplaceAll( sBack, Chr( i ), "?" ) end if next // Return( sBack ) End Function
Function Colorants_Get(cp As DynapdfColorSpaceMBS) As string // dim c As Integer = cp.ColorantsCount - 1 // dim lines( -1 ) As string // for i As Integer = 0 to c lines.Append Colorants_Clean( cp.Colorants( i ) ) next // Return( Join( lines,", " ) ) End Function
End Class
MenuBar MenuBar1
MenuItem FileMenu = "&Ablage"
MenuItem FileQuit = "#App.kFileQuit"
MenuItem EditMenu = "&Bearbeiten"
MenuItem EditUndo = "&Rückgängig"
MenuItem UntitledMenu1 = "-"
MenuItem EditCut = "&Ausschneiden"
MenuItem EditCopy = "&Kopieren"
MenuItem EditPaste = "&Einfügen"
MenuItem EditClear = "#App.kEditClear"
MenuItem UntitledMenu0 = "-"
MenuItem EditSelectAll = "&Alles auswählen"
End MenuBar
Class MyDynaPDFMBS Inherits DynaPDFMBS
EventHandler Function Error(ErrorCode as integer, ErrorMessage as string, ErrorType as integer) As integer // output all messages on the console: System.DebugLog str(ErrorCode)+": "+ErrorMessage // and display dialog: Dim d as New MessageDialog //declare the MessageDialog object Dim b as MessageDialogButton //for handling the result d.icon=MessageDialog.GraphicCaution //display warning icon d.ActionButton.Caption="Continue" d.CancelButton.Visible=True //show the Cancel button // a warning or an error? if BitAnd(ErrorType, me.kE_WARNING) = me.kE_WARNING then // if user decided to ignore, we'll ignore if IgnoreWarnings then Return 0 d.Message="A warning occurred while processing your PDF code." // we add a third button to display all warnings d.AlternateActionButton.Caption = "Ignore warnings" d.AlternateActionButton.Visible = true else d.Message="An error occurred while processing your PDF code." end if d.Explanation = str(ErrorCode)+": "+ErrorMessage b=d.ShowModal //display the dialog Select Case b //determine which button was pressed. Case d.ActionButton Return 0 // ignore Case d.AlternateActionButton IgnoreWarnings = true Return 0 // ignore Case d.CancelButton Return -1 // stop End select End EventHandler
Property IgnoreWarnings As Boolean
End Class
End Project

See also:

The items on this page are in the following plugins: MBS DynaPDF Plugin.


The biggest plugin in space...