Class: Axlsx::Pic

Inherits:
Object
  • Object
show all
Includes:
OptionsParser
Defined in:
lib/axlsx/drawing/pic.rb

Overview

a Pic object represents an image in your worksheet Worksheet#add_image is the recommended way to manage images in your sheets

Constant Summary collapse

ALLOWED_MIME_TYPES =

allowed mime types

%w(image/jpeg image/png image/gif).freeze

Instance Attribute Summary collapse

Instance Method Summary collapse

Methods included from OptionsParser

#parse_options

Constructor Details

#initialize(anchor, options = {}) {|_self| ... } ⇒ Pic

Creates a new Pic(ture) object

Parameters:

  • anchor (Anchor)

    the anchor that holds this image

  • options (Hash) (defaults to: {})

    a customizable set of options

Options Hash (options):

  • :remote (Boolean)

    indicates if image_src is a remote URI

  • :name (String)
  • :descr (String)
  • :image_src (String)
  • :start_at (Array)
  • :width (Integer)
  • :height (Integer)
  • :opacity (Float)
    • set the picture opacity, accepts a value between 0.0 and 1.0

Yields:

  • (_self)

Yield Parameters:

  • _self (Axlsx::Pic)

    the object that the method was called on



20
21
22
23
24
25
26
27
28
29
30
# File 'lib/axlsx/drawing/pic.rb', line 20

def initialize(anchor, options = {})
  @anchor = anchor
  @hyperlink = nil
  @anchor.drawing.worksheet.workbook.images << self
  @remote = options[:remote]
  parse_options options
  start_at(*options[:start_at]) if options[:start_at]
  yield self if block_given?
  @picture_locking = PictureLocking.new(options)
  @opacity = (options[:opacity] * 100000).round if options[:opacity]
end

Instance Attribute Details

#anchorOneCellAnchor (readonly)

The anchor for this image

Returns:



50
51
52
# File 'lib/axlsx/drawing/pic.rb', line 50

def anchor
  @anchor
end

#descrString

A description of the picture

Returns:

  • (String)


41
42
43
# File 'lib/axlsx/drawing/pic.rb', line 41

def descr
  @descr
end

Returns the value of attribute hyperlink.



55
56
57
# File 'lib/axlsx/drawing/pic.rb', line 55

def hyperlink
  @hyperlink
end

#image_srcString

The path to the image you want to include Only local images are supported at this time.

Returns:

  • (String)


46
47
48
# File 'lib/axlsx/drawing/pic.rb', line 46

def image_src
  @image_src
end

#nameString

The name to use for this picture

Returns:

  • (String)


37
38
39
# File 'lib/axlsx/drawing/pic.rb', line 37

def name
  @name
end

#opacityInteger (readonly)

Picture opacity

Returns:

  • (Integer)


59
60
61
# File 'lib/axlsx/drawing/pic.rb', line 59

def opacity
  @opacity
end

#picture_lockingObject (readonly)

The picture locking attributes for this picture



53
54
55
# File 'lib/axlsx/drawing/pic.rb', line 53

def picture_locking
  @picture_locking
end

#remoteBoolean

Flag for remote picture (from URI)

Returns:

  • (Boolean)


63
64
65
# File 'lib/axlsx/drawing/pic.rb', line 63

def remote
  @remote
end

Instance Method Details

#end_at(x, y = nil) ⇒ Marker

noop if not using a two cell anchor

Parameters:

  • x (Integer)

    The column

  • y (Integer) (defaults to: nil)

    The row

Returns:



192
193
194
195
196
# File 'lib/axlsx/drawing/pic.rb', line 192

def end_at(x, y = nil)
  use_two_cell_anchor unless @anchor.is_a?(TwoCellAnchor)
  @anchor.end_at x, y
  @anchor.to
end

#extnameString

returns the extension of image_src without the preceeding '.'

Returns:

  • (String)


123
124
125
# File 'lib/axlsx/drawing/pic.rb', line 123

def extname
  File.extname(image_src).delete('.') unless image_src.nil?
end

#file_nameString

The file name of image_src without any path information

Returns:

  • (String)


117
118
119
# File 'lib/axlsx/drawing/pic.rb', line 117

def file_name
  File.basename(image_src) unless remote? || image_src.nil?
end

#heightObject

Note:

this is a noop if you are using a TwoCellAnchor

providing access to update the anchor's height attribute



166
167
168
# File 'lib/axlsx/drawing/pic.rb', line 166

def height
  @anchor.height
end

#height=(v) ⇒ Object

Note:

This is a noop if you are using a TwoCellAnchor

See Also:



172
173
174
175
# File 'lib/axlsx/drawing/pic.rb', line 172

def height=(v)
  use_one_cell_anchor unless @anchor.is_a?(OneCellAnchor)
  @anchor.height = v
end

#indexIndex

The index of this image in the workbooks images collections

Returns:

  • (Index)


129
130
131
# File 'lib/axlsx/drawing/pic.rb', line 129

def index
  @anchor.drawing.worksheet.workbook.images.index(self)
end

#pnString

The part name for this image used in serialization and relationship building

Returns:

  • (String)


135
136
137
# File 'lib/axlsx/drawing/pic.rb', line 135

def pn
  format(IMAGE_PN, index + 1, extname)
end

#relationshipRelationship

The relationship object for this pic.

Returns:



141
142
143
144
145
146
147
# File 'lib/axlsx/drawing/pic.rb', line 141

def relationship
  if remote?
    Relationship.new(self, IMAGE_R, image_src.to_s, target_mode: :External)
  else
    Relationship.new(self, IMAGE_R, "../#{pn}")
  end
end

#remote?Boolean

Returns:

  • (Boolean)


111
112
113
# File 'lib/axlsx/drawing/pic.rb', line 111

def remote?
  remote == 1 || remote.to_s == 'true'
end

#start_at(x, y = nil) ⇒ Marker

This is a short cut method to set the start anchor position If you need finer granularity in positioning use graphic_frame.anchor.from.colOff / rowOff

Parameters:

  • x (Integer)

    The column

  • y (Integer) (defaults to: nil)

    The row

Returns:



183
184
185
186
# File 'lib/axlsx/drawing/pic.rb', line 183

def start_at(x, y = nil)
  @anchor.start_at x, y
  @anchor.from
end

#to_xml_string(str = +'')) ⇒ String

Serializes the object

Parameters:

  • str (String) (defaults to: +''))

Returns:

  • (String)


201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
# File 'lib/axlsx/drawing/pic.rb', line 201

def to_xml_string(str = +'')
  str << '<xdr:pic>'
  str << '<xdr:nvPicPr>'
  str << '<xdr:cNvPr id="2" name="' << name.to_s << '" descr="' << descr.to_s << '">'
  hyperlink.to_xml_string(str) if hyperlink.is_a?(Hyperlink)
  str << '</xdr:cNvPr><xdr:cNvPicPr>'
  picture_locking.to_xml_string(str)
  str << '</xdr:cNvPicPr></xdr:nvPicPr>'
  str << '<xdr:blipFill>'
  str << relationship_xml_portion
  if opacity
    str << "<a:alphaModFix amt=\"#{opacity}\"/>"
  end
  str << '</a:blip>'
  str << '<a:stretch><a:fillRect/></a:stretch></xdr:blipFill><xdr:spPr>'
  str << '<a:xfrm><a:off x="0" y="0"/><a:ext cx="2336800" cy="2161540"/></a:xfrm>'
  str << '<a:prstGeom prst="rect"><a:avLst/></a:prstGeom></xdr:spPr></xdr:pic>'
end

#widthObject

providing access to the anchor's width attribute



151
152
153
154
155
# File 'lib/axlsx/drawing/pic.rb', line 151

def width
  return unless @anchor.is_a?(OneCellAnchor)

  @anchor.width
end

#width=(v) ⇒ Object

See Also:



158
159
160
161
# File 'lib/axlsx/drawing/pic.rb', line 158

def width=(v)
  use_one_cell_anchor unless @anchor.is_a?(OneCellAnchor)
  @anchor.width = v
end