AnnotationTypes.vb
  1. ''
  2. '' This code is part of Document Solutions for PDF demos.
  3. '' Copyright (c) MESCIUS inc. All rights reserved.
  4. ''
  5. Imports System.IO
  6. Imports System.Drawing
  7. Imports GrapeCity.Documents.Pdf
  8. Imports GrapeCity.Documents.Pdf.Annotations
  9. Imports GrapeCity.Documents.Text
  10. Imports GrapeCity.Documents.Drawing
  11.  
  12. '' Shows how to add annotations to a PDF document.
  13. Public Class AnnotationTypes
  14. Function CreatePDF(ByVal stream As Stream) As Integer
  15. Dim doc = New GcPdfDocument()
  16. Dim page = doc.NewPage()
  17. '' User names for annotations' authors:
  18. Dim user1 = "Jaime Smith"
  19. Dim user2 = "Jane Donahue"
  20.  
  21. Dim tf = New TextFormat() With {.Font = StandardFonts.Helvetica, .FontSize = 10}
  22. Dim noteWidth = 72 * 4
  23. Dim gap = 8
  24.  
  25. Dim rc = Util.AddNote(
  26. "This sample demonstrates some types of annotations that can be created with DsPdf." + vbLf +
  27. "Note that some annotation types may not display in certain viewers (such as built-in browser viewers)." +
  28. "To see all annotations on this page, open it in Acrobat Reader or other full-featured PDF viewer.",
  29. page)
  30.  
  31. '' Text annotation:
  32. Dim ip = New PointF(rc.X, rc.Bottom + gap)
  33. rc = Util.AddNote(
  34. "A red text annotation is placed to the right of this note.",
  35. page, New RectangleF(ip.X, ip.Y, noteWidth, 100))
  36. Dim textAnnot = New TextAnnotation() With {
  37. .UserName = user1,
  38. .Contents = "This is annotation 1, a red one.",
  39. .Rect = New RectangleF(rc.Right, rc.Top, 72 * 2, 72),
  40. .Color = Color.Red
  41. }
  42. page.Annotations.Add(textAnnot)
  43. '' A reply to previous annotation:
  44. Dim textAnnotReply = New TextAnnotation() With {
  45. .UserName = user2,
  46. .Contents = "This is a reply to the first annotation.",
  47. .Rect = New RectangleF(rc.Right, rc.Top, 72 * 2, 72),
  48. .ReferenceAnnotation = textAnnot,
  49. .ReferenceType = AnnotationReferenceType.Reply
  50. }
  51. page.Annotations.Add(textAnnotReply)
  52.  
  53. '' An initially open text annotation:
  54. ip = New PointF(rc.X, rc.Bottom + gap)
  55. rc = Util.AddNote(
  56. "A green text annotation that is initially open is placed to the right of this note.",
  57. page, New RectangleF(ip.X, ip.Y, noteWidth, 100))
  58. Dim textAnnotOpen = New TextAnnotation() With {
  59. .Open = True,
  60. .UserName = user1,
  61. .Contents = "This is an initially open annotation (green).",
  62. .Rect = New RectangleF(rc.Right, rc.Top, 72 * 2, 72),
  63. .Color = Color.Green
  64. }
  65. page.Annotations.Add(textAnnotOpen)
  66.  
  67. '' A free text annotation (shows directly on page):
  68. ip = New PointF(rc.X, rc.Bottom + gap)
  69. rc = Util.AddNote(
  70. "A blue free text annotation is placed below and to the right, with a callout going from it to this note.",
  71. page, New RectangleF(ip.X, ip.Y, noteWidth, 100))
  72. Dim freeAnnot = New FreeTextAnnotation() With {
  73. .Rect = New RectangleF(rc.Right + 18, rc.Bottom + 9, 72 * 2, 72),
  74. .CalloutLine = {
  75. New PointF(rc.Left + rc.Width / 2, rc.Bottom),
  76. New PointF(rc.Left + rc.Width / 2, rc.Bottom + 9 + 36),
  77. New PointF(rc.Right + 18, rc.Bottom + 9 + 36)
  78. },
  79. .LineWidth = 1,
  80. .LineEndStyle = LineEndingStyle.OpenArrow,
  81. .LineDashPattern = New Single() {8, 4},
  82. .Contents = "This is a free text annotation with a callout line going to the note on the left.",
  83. .Color = Color.LightSkyBlue
  84. }
  85. page.Annotations.Add(freeAnnot)
  86.  
  87. '' Another free text annotation, with some rich text inside:
  88. ip = New PointF(rc.X, freeAnnot.Rect.Bottom + gap)
  89. Dim freeRichAnnot = New FreeTextAnnotation() With {
  90. .Rect = New RectangleF(ip.X - 144, ip.Y, 72 * 5, 72),
  91. .LineWidth = 1,
  92. .Color = Color.LightSalmon,
  93. .RichText =
  94. "<body><p>This is another <i>free text annotation</i>, with <b><i>Rich Text</i></b> content.</p>" +
  95. "<p>Even though a <b>free text</b> annotation displays text directly on a page, " +
  96. "as other annotations it can be placed outside the page's bounds.</p></body>"
  97. }
  98. page.Annotations.Add(freeRichAnnot)
  99.  
  100. '' A square annotatou around a note:
  101. ip = New PointF(rc.X, freeRichAnnot.Rect.Bottom + gap * 2)
  102. rc = Util.AddNote(
  103. "A square annotation drawn with a 3pt wide orange line around this note has a rich text associated with it.",
  104. page, New RectangleF(ip.X, ip.Y, noteWidth, 100))
  105.  
  106. rc.Inflate(8, 8)
  107. Dim squareAnnot = New SquareAnnotation() With {
  108. .UserName = user2,
  109. .Rect = rc,
  110. .LineWidth = 3,
  111. .Color = Color.Orange,
  112. .RichText =
  113. "<body><p>This <b><i>rich text</i></b> is associated with the square annotation around a text note.</p></body>"
  114. }
  115. page.Annotations.Add(squareAnnot)
  116. ''
  117. '' Done:
  118. doc.Save(stream)
  119. Return doc.Pages.Count
  120. End Function
  121. End Class
  122.