Platforms to show: All Mac Windows Linux Cross-Platform
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/Show Annotations
This example is the version from Fri, 6th Nov 2014.
Project "Show Annotations.xojo_binary_project"
Class App Inherits Application
Const kEditClear = "&Löschen"
Const kFileQuit = "Beenden"
Const kFileQuitShortcut = ""
EventHandler Sub NewDocument()
dim f as FolderItem = GetOpenFolderItem(FileTypes1.Pdf)
if f<>Nil then
OpenDocument f
end if
End EventHandler
EventHandler Sub OpenDocument(item As FolderItem)
dim w as new MainWindow
w.run item
w.show
End EventHandler
End Class
Class MainWindow Inherits Window
Control List Inherits Listbox
ControlInstance List Inherits Listbox
End Control
Sub run(file as FolderItem)
Title = file.DisplayName
dim p as new MyDynapdfMBS
p.SetLicenseKey "Lite" // For this example you can use Lite, Pro or Enterprise License
call p.CreateNewPDF(nil)
// Skip anything that is not required
call p.SetImportFlags p.kifImportAll+p.kifImportAsPage
// From which PDF file do you want to extract the images?
call p.OpenImportFile(file, p.kptOpen, "")
// import pages
call p.ImportPDFFile(1, 1.0, 1.0)
call p.CloseImportFile
// lookup all links
dim u as integer = p.GetAnnotCount-1
Title = str(p.GetAnnotCount)+" annotations"
for i as integer = 0 to u
dim b as DynaPDFAnnotationExMBS = p.GetAnnotEx(i)
dim bbox as DynaPDFRectMBS = b.BBox
List.AddRow ""
Select case b.Type
case p.kat3D
List.Cell(List.LastIndex,0) = "3D"
case p.katCaret
List.Cell(List.LastIndex,0) = "Caret"
case p.katCircle
List.Cell(List.LastIndex,0) = "Circle"
case p.katFileAttach
List.Cell(List.LastIndex,0) = "FileAttach"
case p.katFileLink
List.Cell(List.LastIndex,0) = "FileLink"
case p.katFreeText
List.Cell(List.LastIndex,0) = "FreeText"
case p.katHighlight
List.Cell(List.LastIndex,0) = "Highlight"
case p.katInk
List.Cell(List.LastIndex,0) = "Ink"
case p.katLine
List.Cell(List.LastIndex,0) = "Line"
case p.katMovieAnnot
List.Cell(List.LastIndex,0) = "MovieAnnot"
case p.katPageLink
List.Cell(List.LastIndex,0) = "PageLink"
case p.katPolygon
List.Cell(List.LastIndex,0) = "Polygon"
case p.katPolyLine
List.Cell(List.LastIndex,0) = "PolyLine"
case p.katPopUp
List.Cell(List.LastIndex,0) = "PopUp"
case p.katPrinterMark
List.Cell(List.LastIndex,0) = "PrinterMark"
case p.katProjection
List.Cell(List.LastIndex,0) = "Projection"
case p.katRedact
List.Cell(List.LastIndex,0) = "Redact"
case p.katRichMedia
List.Cell(List.LastIndex,0) = "RichMedia"
case p.katScreen
List.Cell(List.LastIndex,0) = "Screen"
case p.katSoundAnnot
List.Cell(List.LastIndex,0) = "SoundAnnot"
case p.katSquare
List.Cell(List.LastIndex,0) = "Square"
case p.katSquiggly
List.Cell(List.LastIndex,0) = "Squiggly"
case p.katStamp
List.Cell(List.LastIndex,0) = "Stamp"
case p.katStrikeOut
List.Cell(List.LastIndex,0) = "StrikeOut"
case p.katText
List.Cell(List.LastIndex,0) = "Text"
case p.katTrapNet
List.Cell(List.LastIndex,0) = "TrapNet"
case p.katUnderline
List.Cell(List.LastIndex,0) = "Underline"
case p.katUnknown
List.Cell(List.LastIndex,0) = "Unknown"
case p.katWatermark
List.Cell(List.LastIndex,0) = "Watermark"
case p.katWebLink
List.Cell(List.LastIndex,0) = "WebLink"
case p.katWidget
List.Cell(List.LastIndex,0) = "Widget"
else
List.Cell(List.LastIndex,0) = str(b.Type)
end Select
list.Cell(List.LastIndex,1) = b.Subtype
list.Cell(List.LastIndex,2) = b.name
list.Cell(List.LastIndex,3) = b.Content
List.Cell(List.LastIndex,4) = Format(BBox.Left,"0")+"/"+Format(BBox.top,"0")+" "+Format(BBox.Right,"0")+"/"+Format(BBox.Bottom,"0")
list.Cell(List.LastIndex,5) = b.DestFile
list.Cell(List.LastIndex,6) = str(b.DestPage)
list.Cell(List.LastIndex,7) = b.Subject
list.Cell(List.LastIndex,8) = b.Author
list.Cell(List.LastIndex,9) = b.State
next
End Sub
Property bookmarkChildren As Dictionary
Property bookmarks As Dictionary
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
FileTypes1
Filetype application/pdf
End FileTypes1
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.