annotate .svn/pristine/2b/2b8d3c9c3c263ae7cd6f97cc6dd5f192b92ebd2b.svn-base @ 1327:287f201c2802 redmine-2.2-integration

Add italic
author Chris Cannam <chris.cannam@soundsoftware.ac.uk>
date Wed, 19 Jun 2013 20:56:22 +0100
parents cbb26bc654de
children
rev   line source
Chris@909 1 # The MIT License
Chris@909 2 #
Chris@909 3 # Permission is hereby granted, free of charge, to any person obtaining a copy
Chris@909 4 # of this software and associated documentation files (the "Software"), to deal
Chris@909 5 # in the Software without restriction, including without limitation the rights
Chris@909 6 # to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
Chris@909 7 # copies of the Software, and to permit persons to whom the Software is
Chris@909 8 # furnished to do so, subject to the following conditions:
Chris@909 9 #
Chris@909 10 # The above copyright notice and this permission notice shall be included in
Chris@909 11 # all copies or substantial portions of the Software.
Chris@909 12 #
Chris@909 13 # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
Chris@909 14 # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
Chris@909 15 # FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
Chris@909 16 # AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
Chris@909 17 # LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
Chris@909 18 # OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
Chris@909 19 # THE SOFTWARE.
Chris@909 20 #
Chris@909 21 # This implements native php methods used by tcpdf, which have had to be
Chris@909 22 # reimplemented within Ruby.
Chris@909 23
Chris@909 24 module RFPDF
Chris@909 25
Chris@909 26 # http://uk2.php.net/getimagesize
Chris@909 27 def getimagesize(filename)
Chris@909 28 image = Magick::ImageList.new(filename)
Chris@909 29
Chris@909 30 out = Hash.new
Chris@909 31 out[0] = image.columns
Chris@909 32 out[1] = image.rows
Chris@909 33
Chris@909 34 # These are actually meant to return integer values But I couldn't seem to find anything saying what those values are.
Chris@909 35 # So for now they return strings. The only place that uses this at the moment is the parsejpeg method, so I've changed that too.
Chris@909 36 case image.mime_type
Chris@909 37 when "image/gif"
Chris@909 38 out[2] = "GIF"
Chris@909 39 when "image/jpeg"
Chris@909 40 out[2] = "JPEG"
Chris@909 41 when "image/png"
Chris@909 42 out[2] = "PNG"
Chris@909 43 when " image/vnd.wap.wbmp"
Chris@909 44 out[2] = "WBMP"
Chris@909 45 when "image/x-xpixmap"
Chris@909 46 out[2] = "XPM"
Chris@909 47 end
Chris@909 48 out[3] = "height=\"#{image.rows}\" width=\"#{image.columns}\""
Chris@909 49 out['mime'] = image.mime_type
Chris@909 50
Chris@909 51 # This needs work to cover more situations
Chris@909 52 # I can't see how to just list the number of channels with ImageMagick / rmagick
Chris@909 53 if image.colorspace.to_s == "CMYKColorspace"
Chris@909 54 out['channels'] = 4
Chris@909 55 elsif image.colorspace.to_s == "RGBColorspace"
Chris@909 56 out['channels'] = 3
Chris@909 57 end
Chris@909 58
Chris@909 59 out['bits'] = image.channel_depth
Chris@909 60 File.open( TCPDF.k_path_cache + File::basename(filename), 'w'){|f|
Chris@909 61 f.binmode
Chris@909 62 f.print image.to_blob
Chris@909 63 f.close
Chris@909 64 }
Chris@909 65
Chris@909 66 out
Chris@909 67 end
Chris@909 68
Chris@909 69 end