libis-format 1.2.1 → 2.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/.gitignore +0 -1
- data/.travis.yml +19 -23
- data/Gemfile +0 -2
- data/README.md +2 -2
- data/base/Dockerfile +5 -3
- data/base/rework_path +5 -10
- data/data/PDFA_def.ps +3 -3
- data/data/eciRGB_v2.icc +0 -0
- data/lib/libis/format/cli/convert.rb +4 -4
- data/lib/libis/format/config.rb +3 -3
- data/lib/libis/format/converter/audio_converter.rb +6 -38
- data/lib/libis/format/converter/base.rb +21 -8
- data/lib/libis/format/converter/chain.rb +7 -19
- data/lib/libis/format/converter/fop_pdf_converter.rb +2 -0
- data/lib/libis/format/converter/image_assembler.rb +82 -0
- data/lib/libis/format/converter/image_converter.rb +21 -141
- data/lib/libis/format/converter/image_splitter.rb +80 -0
- data/lib/libis/format/converter/image_watermarker.rb +261 -0
- data/lib/libis/format/converter/jp2_converter.rb +4 -4
- data/lib/libis/format/converter/office_converter.rb +5 -3
- data/lib/libis/format/converter/pdf_assembler.rb +66 -0
- data/lib/libis/format/converter/pdf_converter.rb +31 -98
- data/lib/libis/format/converter/pdf_optimizer.rb +70 -0
- data/lib/libis/format/converter/pdf_splitter.rb +65 -0
- data/lib/libis/format/converter/pdf_watermarker.rb +110 -0
- data/lib/libis/format/converter/spreadsheet_converter.rb +5 -3
- data/lib/libis/format/converter/video_converter.rb +3 -6
- data/lib/libis/format/converter/xslt_converter.rb +14 -15
- data/lib/libis/format/identifier.rb +3 -3
- data/lib/libis/format/info.rb +27 -0
- data/lib/libis/format/library.rb +147 -0
- data/lib/libis/format/tool/extension_identification.rb +4 -4
- data/lib/libis/format/tool/{ff_mpeg.rb → ffmpeg.rb} +1 -10
- data/lib/libis/format/tool/fop_pdf.rb +0 -12
- data/lib/libis/format/tool/identification_tool.rb +6 -6
- data/lib/libis/format/tool/office_to_pdf.rb +1 -10
- data/lib/libis/format/tool/pdf_copy.rb +1 -11
- data/lib/libis/format/tool/pdf_merge.rb +1 -11
- data/lib/libis/format/tool/pdf_optimizer.rb +2 -11
- data/lib/libis/format/tool/pdf_split.rb +1 -11
- data/lib/libis/format/tool/pdf_to_pdfa.rb +43 -59
- data/lib/libis/format/tool/pdfa_validator.rb +35 -28
- data/lib/libis/format/tool/spreadsheet_to_ods.rb +2 -10
- data/lib/libis/format/tool.rb +1 -1
- data/lib/libis/format/version.rb +1 -1
- data/lib/libis/format/yaml_loader.rb +71 -0
- data/lib/libis/format.rb +5 -2
- data/libis-format.gemspec +3 -5
- data/tools/fop/fop.bat +75 -75
- data/tools/fop/fop.cmd +31 -31
- data/tools/fop/fop.js +341 -341
- data/tools/fop/lib/avalon-framework.NOTICE.TXT +11 -11
- data/tools/fop/lib/xml-apis.LICENSE-SAX.html +17 -17
- data/tools/fop/lib/xml-apis.LICENSE.DOM-documentation.html +74 -74
- data/tools/fop/lib/xml-apis.LICENSE.DOM-software.html +66 -66
- metadata +19 -29
- data/data/AdobeRGB1998.icc +0 -0
- data/lib/libis/format/converter/email_converter.rb +0 -38
- data/lib/libis/format/tool/email_to_pdf.rb +0 -75
- data/lib/libis/format/type_database.rb +0 -133
- data/lib/libis/format/type_database_impl.rb +0 -120
- data/tools/emailconverter.jar +0 -0
- data/tools/pdf2pdfa +0 -395
- /data/bin/{droid_tool → droid} +0 -0
- /data/bin/{fido_tool → fido} +0 -0
@@ -4,7 +4,6 @@ require_relative 'base'
|
|
4
4
|
require 'libis/format/identifier'
|
5
5
|
|
6
6
|
require 'mini_magick'
|
7
|
-
require 'fileutils'
|
8
7
|
|
9
8
|
MiniMagick.logger.level = ::Logger::UNKNOWN
|
10
9
|
|
@@ -23,11 +22,11 @@ module Libis
|
|
23
22
|
class ImageConverter < Libis::Format::Converter::Base
|
24
23
|
|
25
24
|
def self.input_types
|
26
|
-
[:TIFF, :JPG, :PNG, :BMP, :GIF, :PDF, :JP2]
|
25
|
+
[:TIFF, :JPG, :PNG, :BMP, :GIF, :PDF, :JP2, :PBM, :PGM, :PPM]
|
27
26
|
end
|
28
27
|
|
29
28
|
def self.output_types(format = nil)
|
30
|
-
return [] unless input_types.include?(format)
|
29
|
+
return [] unless input_types.include?(format) if format
|
31
30
|
[:TIFF, :JPG, :PNG, :BMP, :GIF, :PDF, :JP2]
|
32
31
|
end
|
33
32
|
|
@@ -46,109 +45,57 @@ module Libis
|
|
46
45
|
|
47
46
|
def quiet(v)
|
48
47
|
@quiet = !!v
|
48
|
+
self
|
49
49
|
end
|
50
50
|
|
51
51
|
def page(nr)
|
52
52
|
@page = nr
|
53
|
+
self
|
53
54
|
end
|
54
55
|
|
55
56
|
def scale(percent)
|
56
57
|
@options[:scale] = percent
|
58
|
+
self
|
57
59
|
end
|
58
60
|
|
59
61
|
def resize(geometry)
|
60
62
|
@options[:resize] = geometry
|
63
|
+
self
|
61
64
|
end
|
62
65
|
|
63
66
|
def quality(value)
|
64
67
|
@options[:quality] = value
|
68
|
+
self
|
65
69
|
end
|
66
70
|
|
67
71
|
def dpi(value)
|
68
72
|
@options[:density] = value
|
73
|
+
self
|
69
74
|
end
|
70
75
|
|
71
76
|
def resample(value)
|
72
77
|
@options[:resample] = value
|
78
|
+
self
|
73
79
|
end
|
74
80
|
|
75
81
|
def flatten(value = true)
|
76
|
-
@options[:flatten] =
|
82
|
+
@options[:flatten] = value
|
83
|
+
self
|
77
84
|
end
|
78
85
|
|
79
86
|
def colorspace(value)
|
80
87
|
@options[:colorspace] = value
|
88
|
+
self
|
81
89
|
end
|
82
90
|
|
83
91
|
def delete_date(value = true)
|
84
|
-
@delete_date =
|
92
|
+
@delete_date = value
|
93
|
+
self
|
85
94
|
end
|
86
95
|
|
87
96
|
def profile(icc)
|
88
97
|
@profile = icc
|
89
|
-
|
90
|
-
|
91
|
-
# Create or use a watermark image.
|
92
|
-
#
|
93
|
-
# The watermark options are:
|
94
|
-
# - file: watermark image to use
|
95
|
-
# - text: text to create a watermark from
|
96
|
-
# - rotation: rotation of the watermark text (counter clockwise in degrees; integer number) - default 30
|
97
|
-
# - tiles: number of tiles of the watermark - default 4
|
98
|
-
# - 0: no tiling, so only 1 watermark will be placed with the original size
|
99
|
-
# - 1: 1 tile, so the watermark will be scaled up to fill the image
|
100
|
-
# - n > 1: minimum n tiles in both directions
|
101
|
-
# - n < 0: tile without scaling the watermark
|
102
|
-
# - size: same as tiles - for backwards compatibility
|
103
|
-
# - resize: fraction 0.0 - 1.0
|
104
|
-
# - gap: size of the gap between watermark instances. Fractions as percentage of widht/height. - default 0.2
|
105
|
-
# - opacity: opacity of the watermark (fraction 0.0 - 1.0) - default 0.1
|
106
|
-
# - gravity: center point of the overlay - default 'center'
|
107
|
-
# If both options are given, the file will be used as-is if it exists and is a valid image file. Otherwise the
|
108
|
-
# file will be created or overwritten with a newly created watermark image.
|
109
|
-
#
|
110
|
-
# The created watermark file will be a PNG image with transparent background containing the supplied text
|
111
|
-
# slanted by 30 degrees counter-clockwise.
|
112
|
-
#
|
113
|
-
# @param [Hash] options Hash of options for watermark creation.
|
114
|
-
def watermark(options = {})
|
115
|
-
text = options[:text] || '© LIBIS'
|
116
|
-
@wm_tiles = (options[:tiles] || '4').to_i
|
117
|
-
@wm_tiles ||= (options[:size] || '4').to_i
|
118
|
-
@wm_resize = ((options[:resize]).to_f * 100).to_i if options[:resize]
|
119
|
-
@wm_opacity = ((options[:opacity] || 0.1).to_f * 100).to_i
|
120
|
-
@wm_composition = options[:composition] || 'modulate'
|
121
|
-
@wm_gravity = options[:gravity] || 'center'
|
122
|
-
@wm_gap = ((options[:gap] || 0.2).to_f * 100).to_i
|
123
|
-
rotation = 360 - (options[:rotation] || 30).to_i
|
124
|
-
@wm_image = MiniMagick::Image.new(options[:file]) if options[:file]
|
125
|
-
unless @wm_image && @wm_image.valid?
|
126
|
-
image = options[:file] || (Dir::Tmpname.create(%w(wm_image .png)) {|_|})
|
127
|
-
# noinspection RubyResolve
|
128
|
-
MiniMagick::Tool::Convert.new do |convert|
|
129
|
-
# noinspection RubyLiteralArrayInspection
|
130
|
-
convert.quiet
|
131
|
-
convert.background 'transparent'
|
132
|
-
convert.size('2000x2000')
|
133
|
-
convert.gravity 'Center'
|
134
|
-
convert.font('Helvetica').fill('black').pointsize(72) #.stroke('black').strokewidth(1)
|
135
|
-
convert << "label:#{text}"
|
136
|
-
convert.rotate rotation
|
137
|
-
convert.trim.repage.+
|
138
|
-
convert << image
|
139
|
-
end
|
140
|
-
if options[:file]
|
141
|
-
@wm_image = MiniMagick::Image.new(image)
|
142
|
-
else
|
143
|
-
@wm_image = MiniMagick::Image.open(image)
|
144
|
-
File.delete(image)
|
145
|
-
end
|
146
|
-
# noinspection RubyResolve
|
147
|
-
unless @wm_image.valid?
|
148
|
-
error "Problem creating watermark image '#{image}'."
|
149
|
-
@wm_image = nil
|
150
|
-
end
|
151
|
-
end
|
98
|
+
self
|
152
99
|
end
|
153
100
|
|
154
101
|
def convert(source, target, format, opts = {})
|
@@ -156,92 +103,25 @@ module Libis
|
|
156
103
|
|
157
104
|
FileUtils.mkpath(File.dirname(target))
|
158
105
|
|
159
|
-
|
160
|
-
|
161
|
-
assemble_and_convert(source, target, format)
|
162
|
-
|
163
|
-
elsif File.directory?(source)
|
164
|
-
source_list = Dir[File.join(source, '**', '*')].reject {|p| File.directory? p}
|
165
|
-
|
166
|
-
assemble_and_convert(source_list, target, format)
|
167
|
-
|
168
|
-
else
|
169
|
-
|
170
|
-
image = MiniMagick::Image.open(source) { |b| b.quiet }
|
171
|
-
|
172
|
-
if image.pages.size > 1
|
173
|
-
if @page
|
174
|
-
convert_image(image.pages[@page].path, target, format)
|
175
|
-
else
|
176
|
-
# noinspection RubyBlockToMethodReference
|
177
|
-
assemble_and_convert(image.pages.map {|page| page.path}, target, format)
|
178
|
-
end
|
179
|
-
else
|
180
|
-
convert_image(source, target, format)
|
181
|
-
end
|
182
|
-
end
|
183
|
-
|
184
|
-
{
|
185
|
-
files: [target],
|
186
|
-
converter: self.class.name
|
187
|
-
}
|
188
|
-
end
|
106
|
+
convert_image(source, target, format)
|
189
107
|
|
190
|
-
|
108
|
+
target
|
191
109
|
|
192
|
-
warn 'Received multiple images as input and single page format as target.' unless self.class.multipage?(format)
|
193
|
-
converted_pages = sources.inject([]) do |list, path|
|
194
|
-
# noinspection RubyArgCount
|
195
|
-
converted = Tempfile.new(['page-', ".#{Libis::Format::TypeDatabase.type_extentions(format).first}"])
|
196
|
-
convert_image(path, converted.path, format)
|
197
|
-
list << converted
|
198
|
-
end
|
199
|
-
MiniMagick::Tool::Convert.new do |b|
|
200
|
-
b.append unless self.class.multipage?(format)
|
201
|
-
converted_pages.each {|page| b << page.path}
|
202
|
-
b << target
|
203
|
-
end
|
204
|
-
converted_pages.each do |temp_file|
|
205
|
-
temp_file.close
|
206
|
-
temp_file.unlink
|
207
|
-
end
|
208
110
|
end
|
209
111
|
|
210
112
|
protected
|
211
113
|
|
212
114
|
def convert_image(source, target, format)
|
213
115
|
|
214
|
-
|
215
|
-
|
116
|
+
if @page
|
117
|
+
image = MiniMagick::Image.open(source) { |b| b.quiet }
|
118
|
+
source = image.pages[@page].path if image.pages.size > 1
|
119
|
+
end
|
216
120
|
|
217
121
|
MiniMagick::Tool::Convert.new do |convert|
|
218
|
-
convert.quiet if @quiet
|
219
|
-
if @wm_image
|
220
|
-
convert << @wm_image.path
|
221
|
-
convert.bordercolor('transparent').border("#{@wm_gap}%") if @wm_gap > 0
|
222
|
-
convert.filter('Lagrange')
|
223
|
-
convert.resize("#{image_info['width'] / @wm_tiles}x#{image_info['height'] / @wm_tiles}") if @wm_tiles > 0
|
224
|
-
convert.resize("#{@wm_resize}%") if @wm_resize
|
225
|
-
convert.write('mpr:watermark').delete.+
|
226
|
-
end
|
227
|
-
|
228
122
|
convert.quiet if @quiet
|
229
123
|
convert << source
|
230
124
|
convert.flatten if @options[:flatten].nil? && format == :JPG
|
231
|
-
if @wm_image
|
232
|
-
if @wm_tiles >= 0 and @wm_tiles <= 1
|
233
|
-
convert << 'mpr:watermark'
|
234
|
-
else
|
235
|
-
convert.stack do |stack|
|
236
|
-
stack.size("#{image_info['width']}x#{image_info['height']}")
|
237
|
-
stack << 'xc:transparent'
|
238
|
-
stack.tile('mpr:watermark')
|
239
|
-
stack.draw "rectangle 0,0,#{image_info['width']},#{image_info['height']}"
|
240
|
-
end
|
241
|
-
end
|
242
|
-
convert.compose(@wm_composition).gravity(@wm_gravity).define("compose:args=#{@wm_opacity}%").composite
|
243
|
-
end
|
244
|
-
|
245
125
|
@flags.each {|f, v| v.is_a?(TrueClass) ? convert.send(f).+ : convert.send(f)}
|
246
126
|
if @delete_date
|
247
127
|
convert << '+set' << 'modify-date' << '+set' << 'create-date'
|
@@ -0,0 +1,80 @@
|
|
1
|
+
# encoding: utf-8
|
2
|
+
|
3
|
+
require_relative 'base'
|
4
|
+
require 'libis/format/identifier'
|
5
|
+
|
6
|
+
require 'mini_magick'
|
7
|
+
|
8
|
+
MiniMagick.logger.level = ::Logger::UNKNOWN
|
9
|
+
|
10
|
+
MiniMagick.configure do |config|
|
11
|
+
# config.cli = :graphicsmagick
|
12
|
+
config.validate_on_create = false
|
13
|
+
config.validate_on_write = false
|
14
|
+
config.whiny = false
|
15
|
+
end
|
16
|
+
|
17
|
+
module Libis
|
18
|
+
module Format
|
19
|
+
module Converter
|
20
|
+
|
21
|
+
class ImageSplitter < Libis::Format::Converter::Base
|
22
|
+
|
23
|
+
def self.input_types
|
24
|
+
[:PDF, :TIFF, :GIF, :PBM, :PGM, :PPM]
|
25
|
+
end
|
26
|
+
|
27
|
+
def self.output_types(format = nil)
|
28
|
+
return [] unless input_types.include?(format) if format
|
29
|
+
[:TIFF, :JPG, :PNG, :BMP, :GIF, :PDF, :JP2]
|
30
|
+
end
|
31
|
+
|
32
|
+
def self.multipage?(format)
|
33
|
+
[:PDF, :TIFF, :GIF, :PBM, :PGM, :PPM].include?(format)
|
34
|
+
end
|
35
|
+
|
36
|
+
def image_split(_)
|
37
|
+
#force usage of this converter
|
38
|
+
end
|
39
|
+
|
40
|
+
def quiet(v)
|
41
|
+
@quiet = !!v
|
42
|
+
end
|
43
|
+
|
44
|
+
def convert(source, target, format, opts = {})
|
45
|
+
super
|
46
|
+
|
47
|
+
FileUtils.mkpath(File.dirname(target))
|
48
|
+
|
49
|
+
if self.class.multipage?(format)
|
50
|
+
target = File.join(File.dirname(target), "#{File.basename(target, '.*')}-%d#{File.extname(target)}")
|
51
|
+
end
|
52
|
+
|
53
|
+
result = split_image(source, target, format)
|
54
|
+
return nil unless result
|
55
|
+
target
|
56
|
+
|
57
|
+
end
|
58
|
+
|
59
|
+
private
|
60
|
+
|
61
|
+
def split_image(source, target, format)
|
62
|
+
|
63
|
+
MiniMagick::Tool::Convert.new do |convert|
|
64
|
+
convert.quiet if @quiet
|
65
|
+
convert << source
|
66
|
+
convert.format(format)
|
67
|
+
convert << target
|
68
|
+
|
69
|
+
debug "ImageMagick command: '#{convert.command.join(' ')}'"
|
70
|
+
end
|
71
|
+
|
72
|
+
target
|
73
|
+
|
74
|
+
end
|
75
|
+
|
76
|
+
end
|
77
|
+
|
78
|
+
end
|
79
|
+
end
|
80
|
+
end
|
@@ -0,0 +1,261 @@
|
|
1
|
+
# encoding: utf-8
|
2
|
+
|
3
|
+
require_relative 'base'
|
4
|
+
require 'libis/format/identifier'
|
5
|
+
|
6
|
+
require 'mini_magick'
|
7
|
+
# noinspection RubyResolve
|
8
|
+
require 'fileutils'
|
9
|
+
|
10
|
+
MiniMagick.logger.level = ::Logger::UNKNOWN
|
11
|
+
|
12
|
+
MiniMagick.configure do |config|
|
13
|
+
# config.cli = :graphicsmagick
|
14
|
+
config.validate_on_create = false
|
15
|
+
config.validate_on_write = false
|
16
|
+
config.whiny = false
|
17
|
+
end
|
18
|
+
|
19
|
+
module Libis
|
20
|
+
module Format
|
21
|
+
module Converter
|
22
|
+
|
23
|
+
# noinspection RubyTooManyInstanceVariablesInspection
|
24
|
+
class ImageWatermarker < Libis::Format::Converter::Base
|
25
|
+
|
26
|
+
def self.input_types
|
27
|
+
[:TIFF, :JPG, :PNG, :BMP, :GIF, :PDF, :JP2]
|
28
|
+
end
|
29
|
+
|
30
|
+
def self.output_types(format = nil)
|
31
|
+
return [] unless input_types.include?(format) if format
|
32
|
+
[format]
|
33
|
+
end
|
34
|
+
|
35
|
+
def self.multipage?(format)
|
36
|
+
[:PDF, :TIFF, :GIF, :PBM, :PGM, :PPM].include?(format)
|
37
|
+
end
|
38
|
+
|
39
|
+
def initialize
|
40
|
+
super
|
41
|
+
@quiet = true
|
42
|
+
@wm_image = nil
|
43
|
+
@wm_file = nil
|
44
|
+
@wm_text = '© LIBIS'
|
45
|
+
@wm_tiles = 4
|
46
|
+
@wm_resize = nil
|
47
|
+
@wm_gap = 20
|
48
|
+
@wm_gravity = 'Center'
|
49
|
+
@wm_rotation = 30
|
50
|
+
@wm_composition ='modulate'
|
51
|
+
@wm_composition_args = '10'
|
52
|
+
end
|
53
|
+
|
54
|
+
def image_watermark(_)
|
55
|
+
#force usage of this converter
|
56
|
+
self
|
57
|
+
end
|
58
|
+
|
59
|
+
def quiet(v)
|
60
|
+
@quiet = !!v
|
61
|
+
self
|
62
|
+
end
|
63
|
+
|
64
|
+
def page(v)
|
65
|
+
@page = v.to_i
|
66
|
+
self
|
67
|
+
end
|
68
|
+
|
69
|
+
# watermark image to use
|
70
|
+
def file(v)
|
71
|
+
@wm_file = v.blank? ? nil : v
|
72
|
+
self
|
73
|
+
end
|
74
|
+
|
75
|
+
# text to create a watermark from
|
76
|
+
def text(v)
|
77
|
+
@wm_text = v.blank? ? nil : v
|
78
|
+
self
|
79
|
+
end
|
80
|
+
|
81
|
+
# rotation of the watermark text (counter clockwise in degrees; integer number)
|
82
|
+
# default 30
|
83
|
+
def rotation(v)
|
84
|
+
@wm_rotation = v.to_i
|
85
|
+
self
|
86
|
+
end
|
87
|
+
|
88
|
+
# number of tiles of the watermark
|
89
|
+
# default 4
|
90
|
+
# 0: no tiling, so only 1 watermark will be placed with the original size
|
91
|
+
# 1: 1 tile, so the watermark will be scaled up to fill the image
|
92
|
+
# n > 1: minimum n tiles in both directions
|
93
|
+
# n < 0: tile without scaling the watermark
|
94
|
+
def tiles(v)
|
95
|
+
@wm_tiles = v.to_i
|
96
|
+
self
|
97
|
+
end
|
98
|
+
|
99
|
+
# fraction 0.0 - 1.0
|
100
|
+
def resize(v)
|
101
|
+
@wm_resize = (v.to_f * 100).to_i
|
102
|
+
self
|
103
|
+
end
|
104
|
+
|
105
|
+
# size of the gap between watermark instances. Fractions as percentage of widht/height
|
106
|
+
# default 0.2
|
107
|
+
def gap(v)
|
108
|
+
@wm_gap = (v.to_f * 100).to_i
|
109
|
+
self
|
110
|
+
end
|
111
|
+
|
112
|
+
# center point for the watermark overlay
|
113
|
+
# default 'center'
|
114
|
+
def gravity(v)
|
115
|
+
@wm_gravity = v.blank? ? nil : v
|
116
|
+
self
|
117
|
+
end
|
118
|
+
|
119
|
+
# the image composition method for merging the watermark image
|
120
|
+
# default 'modulate'
|
121
|
+
# See https://imagemagick.org/script/compose.php for more information
|
122
|
+
def composition(v)
|
123
|
+
@wm_composition = v.blank? ? nil : v
|
124
|
+
self
|
125
|
+
end
|
126
|
+
|
127
|
+
# arguments for the composition method
|
128
|
+
# default '10'
|
129
|
+
# See https://imagemagick.org/script/compose.php for more information
|
130
|
+
def composition_args(v)
|
131
|
+
@wm_composition_args = v.blank? ? nil : v
|
132
|
+
self
|
133
|
+
end
|
134
|
+
|
135
|
+
|
136
|
+
def convert(source, target, format, opts = {})
|
137
|
+
super
|
138
|
+
|
139
|
+
FileUtils.mkpath(File.dirname(target))
|
140
|
+
|
141
|
+
if source.is_a?(Array) || File.directory?(source)
|
142
|
+
error 'Only a single image file is allowed for input'
|
143
|
+
else
|
144
|
+
image = MiniMagick::Image.open(source) { |b| b.quiet }
|
145
|
+
|
146
|
+
if image.pages.size > 1
|
147
|
+
if @page
|
148
|
+
convert_image(image.pages[@page].path, target, format)
|
149
|
+
else
|
150
|
+
error 'multipage input file detecte; you need to supply a page number'
|
151
|
+
end
|
152
|
+
else
|
153
|
+
convert_image(source, target, format)
|
154
|
+
end
|
155
|
+
end
|
156
|
+
|
157
|
+
target
|
158
|
+
|
159
|
+
end
|
160
|
+
|
161
|
+
protected
|
162
|
+
|
163
|
+
# noinspection DuplicatedCode
|
164
|
+
def convert_image(source, target, format)
|
165
|
+
|
166
|
+
wm_image = watermark_image
|
167
|
+
return nil unless wm_image
|
168
|
+
image_info = MiniMagick::Image::Info.new(source) {|b| b.quiet}
|
169
|
+
|
170
|
+
MiniMagick::Tool::Convert.new do |convert|
|
171
|
+
convert.quiet if @quiet
|
172
|
+
|
173
|
+
# adapt watermark image to tile size and apply gap and resize if necessary
|
174
|
+
convert << @wm_image.path
|
175
|
+
# noinspection RubyResolve
|
176
|
+
convert.bordercolor('transparent').border("#{@wm_gap}%") if @wm_gap > 0
|
177
|
+
convert.filter('Lagrange')
|
178
|
+
convert.resize("#{image_info['width'] / @wm_tiles}x#{image_info['height'] / @wm_tiles}") if @wm_tiles > 0
|
179
|
+
convert.resize("#{@wm_resize}%") if @wm_resize
|
180
|
+
convert.write('mpr:watermark').delete.+
|
181
|
+
|
182
|
+
# convert the source image
|
183
|
+
convert << source
|
184
|
+
if @wm_tiles >= 0 and @wm_tiles <= 1
|
185
|
+
# only 1 watermark required (tiles = 0/1 => scaled no/yes)
|
186
|
+
convert << 'mpr:watermark'
|
187
|
+
else
|
188
|
+
# fill the image size with a pattern of the watermark image
|
189
|
+
convert.stack do |stack|
|
190
|
+
stack.size("#{image_info['width']}x#{image_info['height']}")
|
191
|
+
stack << 'xc:transparent'
|
192
|
+
# noinspection RubyResolve
|
193
|
+
stack.tile('mpr:watermark')
|
194
|
+
# noinspection RubyResolve
|
195
|
+
stack.draw "rectangle 0,0,#{image_info['width']},#{image_info['height']}"
|
196
|
+
end
|
197
|
+
end
|
198
|
+
# perform the blending operation
|
199
|
+
convert.compose(@wm_composition).gravity(@wm_gravity).define("compose:args=#{@wm_composition_args}").composite
|
200
|
+
|
201
|
+
convert.format(format)
|
202
|
+
convert << target
|
203
|
+
|
204
|
+
debug "ImageMagick command: '#{convert.command.join(' ')}'"
|
205
|
+
end
|
206
|
+
|
207
|
+
target
|
208
|
+
|
209
|
+
end
|
210
|
+
|
211
|
+
private
|
212
|
+
|
213
|
+
# Create or use a watermark image.
|
214
|
+
#
|
215
|
+
# If both text and image are set, the file will be used as-is if it exists and is a valid image file. Otherwise the
|
216
|
+
# file will be created or overwritten with a newly created watermark image.
|
217
|
+
#
|
218
|
+
# The created watermark file will be a 2000x2000 pixels PNG image with transparent background
|
219
|
+
#
|
220
|
+
# The text will be slanted by given rotation degrees counter-clockwise
|
221
|
+
def watermark_image
|
222
|
+
rotation = 360 - @wm_rotation
|
223
|
+
@wm_image = MiniMagick::Image.new(@wm_file) if @wm_file
|
224
|
+
# only create image if file is not an image
|
225
|
+
unless @wm_image&.valid?
|
226
|
+
# noinspection RubyResolve
|
227
|
+
# Create image file (as given or temp file)
|
228
|
+
image = @wm_file || (Dir::Tmpname.create(%w(wm_image .png)) {|_|})
|
229
|
+
# noinspection RubyResolve
|
230
|
+
MiniMagick::Tool::Convert.new do |convert|
|
231
|
+
convert.quiet # allways quiet
|
232
|
+
convert.background 'transparent'
|
233
|
+
convert.size('2000x2000')
|
234
|
+
convert.gravity 'Center'
|
235
|
+
convert.font('Helvetica').fill('black').pointsize(72) #.stroke('black').strokewidth(1)
|
236
|
+
convert << "label:#{@wm_text}"
|
237
|
+
convert.rotate rotation
|
238
|
+
convert.trim.repage.+
|
239
|
+
convert << image
|
240
|
+
end
|
241
|
+
if @wm_file
|
242
|
+
@wm_image = MiniMagick::Image.new(image)
|
243
|
+
else # delete temp file
|
244
|
+
@wm_image = MiniMagick::Image.open(image)
|
245
|
+
File.delete(image)
|
246
|
+
end
|
247
|
+
# noinspection RubyResolve
|
248
|
+
unless @wm_image.valid?
|
249
|
+
error "Problem creating watermark image '#{image}'."
|
250
|
+
@wm_image = nil
|
251
|
+
end
|
252
|
+
@wm_image
|
253
|
+
end
|
254
|
+
end
|
255
|
+
|
256
|
+
|
257
|
+
end
|
258
|
+
|
259
|
+
end
|
260
|
+
end
|
261
|
+
end
|
@@ -15,7 +15,7 @@ module Libis
|
|
15
15
|
end
|
16
16
|
|
17
17
|
def self.output_types(format = nil)
|
18
|
-
return [] unless input_types.include?(format)
|
18
|
+
return [] unless input_types.include?(format) if format
|
19
19
|
[:JP2]
|
20
20
|
end
|
21
21
|
|
@@ -90,16 +90,16 @@ module Libis
|
|
90
90
|
end
|
91
91
|
|
92
92
|
|
93
|
-
|
93
|
+
Libis::Tools::Command.run(
|
94
94
|
Libis::Format::Config[:j2k_cmd],
|
95
95
|
'--input-file-name', source,
|
96
96
|
'--set-output-type', 'JP2',
|
97
97
|
*options,
|
98
98
|
'--output-file-name', target,
|
99
|
-
)
|
100
99
|
|
101
|
-
|
100
|
+
)
|
102
101
|
|
102
|
+
target
|
103
103
|
end
|
104
104
|
end
|
105
105
|
end
|
@@ -3,7 +3,7 @@
|
|
3
3
|
require_relative 'base'
|
4
4
|
|
5
5
|
require 'libis/format/tool/office_to_pdf'
|
6
|
-
require 'libis/format/
|
6
|
+
require 'libis/format/library'
|
7
7
|
|
8
8
|
module Libis
|
9
9
|
module Format
|
@@ -32,7 +32,7 @@ module Libis
|
|
32
32
|
end
|
33
33
|
|
34
34
|
def self.output_types(format = nil)
|
35
|
-
return [] unless input_types.include?(format)
|
35
|
+
return [] unless input_types.include?(format) if format
|
36
36
|
[:PDF]
|
37
37
|
end
|
38
38
|
|
@@ -43,7 +43,9 @@ module Libis
|
|
43
43
|
def convert(source, target, format, opts = {})
|
44
44
|
super
|
45
45
|
|
46
|
-
Format::Tool::OfficeToPdf.run(source, target)
|
46
|
+
return nil unless Format::Tool::OfficeToPdf.run(source, target)
|
47
|
+
|
48
|
+
target
|
47
49
|
|
48
50
|
end
|
49
51
|
|
@@ -0,0 +1,66 @@
|
|
1
|
+
# encoding: utf-8
|
2
|
+
|
3
|
+
require_relative 'base'
|
4
|
+
|
5
|
+
require 'libis/format/tool/pdf_merge'
|
6
|
+
|
7
|
+
module Libis
|
8
|
+
module Format
|
9
|
+
module Converter
|
10
|
+
|
11
|
+
# noinspection DuplicatedCode
|
12
|
+
class PdfAssembler < Libis::Format::Converter::Base
|
13
|
+
|
14
|
+
def self.input_types
|
15
|
+
[:PDF]
|
16
|
+
end
|
17
|
+
|
18
|
+
def self.output_types(format = nil)
|
19
|
+
return [] unless input_types.include?(format) if format
|
20
|
+
[:PDF]
|
21
|
+
end
|
22
|
+
|
23
|
+
def self.category
|
24
|
+
:assembler
|
25
|
+
end
|
26
|
+
|
27
|
+
def pdf_assemnble(_)
|
28
|
+
#force usage of this converter
|
29
|
+
end
|
30
|
+
|
31
|
+
def convert(source, target, format, opts = {})
|
32
|
+
super
|
33
|
+
|
34
|
+
result = if source.is_a? Array
|
35
|
+
assemble(source, target)
|
36
|
+
elsif File.directory?(source)
|
37
|
+
source_list = Dir[File.join(source, '**', '*')].reject {|p| File.directory? p}
|
38
|
+
assemble(source_list, target)
|
39
|
+
else
|
40
|
+
assemble([source], target)
|
41
|
+
end
|
42
|
+
return nil unless result
|
43
|
+
|
44
|
+
result
|
45
|
+
end
|
46
|
+
|
47
|
+
private
|
48
|
+
|
49
|
+
def assemble(source, target)
|
50
|
+
|
51
|
+
result = Libis::Format::Tool::PdfMerge.run(source, target)
|
52
|
+
|
53
|
+
unless result[:err].empty?
|
54
|
+
error("PdfMerge encountered errors:\n%s", result[:err].join(join("\n")))
|
55
|
+
return nil
|
56
|
+
end
|
57
|
+
|
58
|
+
target
|
59
|
+
end
|
60
|
+
|
61
|
+
end
|
62
|
+
|
63
|
+
end
|
64
|
+
|
65
|
+
end
|
66
|
+
end
|