File: annotations.rb

package info (click to toggle)
ruby-pdf-core 0.10.0-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 408 kB
  • sloc: ruby: 2,270; makefile: 4
file content (97 lines) | stat: -rw-r--r-- 4,104 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
# frozen_string_literal: true

# annotations.rb : Implements low-level annotation support for PDF
#
# Copyright November 2008, Jamis Buck. All Rights Reserved.
#
# This is free software. Please see the LICENSE and COPYING files for details.
#
module PDF
  module Core
    # Provides very low-level support for annotations.
    #
    # @api private
    module Annotations
      # Adds a new annotation (section *8.4 Annotations* in PDF 1.7 spec) to the
      # current page.
      #
      # @param options [Hash] Annotation options. This is basically an `Annot`
      #   dict as decribed in the PDF spec.
      # @option options [Symbol<:Text, :Link, :FreeText, :Line, :Square,
      #   :Circle, :Polygon, :PolyLine, :Highlight, :Underline, :Squiggly,
      #   :StrikeOut, :Stamp, :Caret, :Ink, :Popup, :FileAttachment, :Sound,
      #   :Movie, :Widget, :Screen, :PrinterMark, :TrapNet, :Watermark, :3D>]
      #   :Subtype The type of annotation
      # @option options [Array<Numeric, 4>] :Rect The annotation rectangle
      # @option options [String] :Contents Text to be displayed for the
      #   annotation or, if this type of annotation does not display text, an
      #   alternate description of the annotation's contents in human-readable
      #   form.
      # @option options [PDF::Core::Reference] :P An indirect reference to the
      #   page object with which this annotation is associated.
      # @option options [String] :NM The annotation name, a text string uniquely
      #   identifying it among all the annotations on its page.
      # @option options [Date, Time, String] :M The date and time when the
      #   annotation was most recently modified
      # @option options [Integer] :F A set of flags specifying various
      #   characteristics of the annotation
      # @option options [Hash] :AP An appearance dictionary specifying how the
      #   annotation is presented visually on the page
      # @option options [Symbol] :AS The annotation's appearance state
      # @option options [Array<(Numeric, Array<Numeric>)>] :Border the
      #   characteristics of the annotation's border
      # @option options [Array<Float>] :C Color
      # @option options [Integer] :StructParent The integer key of the
      #   annotation's entry in the structural parent tree
      # @option options [Hash] :OC An optional content group or optional content
      #   membership dictionary
      #
      # @return [options]
      def annotate(options)
        state.page.dictionary.data[:Annots] ||= []
        options = sanitize_annotation_hash(options)
        state.page.dictionary.data[:Annots] << ref!(options)
        options
      end

      # A convenience method for creating `Text` annotations.
      #
      # @param rect [Array<Numeric>] An array of four numbers,
      #   describing the bounds of the annotation.
      # @param contents [String] Contents of the annotation
      #
      # @return [Hash] Annotation dictionary
      def text_annotation(rect, contents, options = {})
        options = options.merge(Subtype: :Text, Rect: rect, Contents: contents)
        annotate(options)
      end

      # A convenience method for creating `Link` annotations.
      #
      # @param rect [Array<Numeric>] An array of four numbers,
      #   describing the bounds of the annotation.
      # @param options [Hash] Should include either `:Dest` (describing the target
      #   destination, usually as a string that has been recorded in the
      #   document's `Dests` tree), or `:A` (describing an action to perform on
      #   clicking the link), or `:PA` (for describing a URL to link to).
      #
      # @return [Hash] Annotation dictionary
      def link_annotation(rect, options = {})
        options = options.merge(Subtype: :Link, Rect: rect)
        annotate(options)
      end

      private

      def sanitize_annotation_hash(options)
        options = options.merge(Type: :Annot)

        if options[:Dest].is_a?(String)
          options[:Dest] = PDF::Core::LiteralString.new(options[:Dest])
        end

        options
      end
    end
  end
end