Class: DICOM::Element
- Inherits:
-
Object
- Object
- DICOM::Element
- Includes:
- Elemental
- Defined in:
- lib/dicom/element.rb
Overview
The Element class handles information related to ordinary (non-parent) elementals (data elements).
Instance Attribute Summary
Attributes included from Elemental
#bin, #length, #name, #parent, #tag, #vr
Instance Method Summary collapse
-
#==(other) ⇒ Boolean
(also: #eql?)
Checks for equality.
-
#bin=(new_bin) ⇒ Object
Sets the binary string of a Element.
-
#children? ⇒ FalseClass
Checks if the Element actually has any child elementals.
-
#endian ⇒ Boolean
Gives the endianness of the encoded binary value of this element.
-
#hash ⇒ Integer
Computes a hash code for this object.
-
#initialize(tag, value, options = {}) ⇒ Element
constructor
Creates an Element instance.
-
#inspect ⇒ String
Gives a string containing a human-readable hash representation of the Element.
-
#is_parent? ⇒ FalseClass
Checks if the Element is a parent.
-
#to_element ⇒ Element
Returns self.
-
#to_hash ⇒ Hash
Creates a hash representation of the element instance.
-
#to_json ⇒ String
Gives a json string containing a human-readable representation of the Element.
-
#to_yaml ⇒ String
Gives a yaml string containing a human-readable representation of the Element.
-
#value ⇒ String, ...
Gives the (decoded) value of the data element.
-
#value=(new_value) ⇒ Object
Sets the value of the Element instance.
Methods included from Elemental
#name_as_method, #parents, #set_parent, #stream, #top_parent
Constructor Details
#initialize(tag, value, options = {}) ⇒ Element
In the case where the Element is given a binary instead of value, the Element will not have a formatted value (value = nil).
Private data elements are named as ‘Private’.
Non-private data elements that are not found in the dictionary are named as ‘Unknown’.
Creates an Element instance.
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 |
# File 'lib/dicom/element.rb', line 34 def initialize(tag, value, ={}) raise ArgumentError, "The supplied tag (#{tag}) is not valid. The tag must be a string of the form 'GGGG,EEEE'." unless tag.is_a?(String) && tag.tag? # Set instance variables: @tag = tag.upcase # We may need to retrieve name and vr from the library: if [:name] and [:vr] @name = [:name] @vr = [:vr].upcase else name, vr = LIBRARY.name_and_vr(tag) @name = [:name] || name @vr = ([:vr] ? [:vr].upcase : vr) end # Manage the parent relation if specified: if [:parent] @parent = [:parent] # FIXME: Because of some implementation problems, attaching the special # Data Set Trailing Padding element to a parent is not supported yet! @parent.add(self, :no_follow => true) unless @tag == 'FFFC,FFFC' && @parent.is_a?(Sequence) end # Value may in some cases be the binary string: unless [:encoded] # The Data Element may have a value, have no value and no binary, or have no value and only binary: if value # Is binary value provided or do we need to encode it? if [:bin] @value = value @bin = [:bin] else if value == '' @value = value @bin = '' else # Set the value with our custom setter method to get proper encoding: self.value = value end end else # When no value is present, we set the binary as an empty string, unless the binary is specified: @bin = [:bin] || '' end else @bin = value end # Let the binary decide the length: @length = @bin.length end |
Instance Method Details
#==(other) ⇒ Boolean Also known as: eql?
Checks for equality.
Other and self are considered equivalent if they are of compatible types and their attributes are equivalent.
90 91 92 93 94 |
# File 'lib/dicom/element.rb', line 90 def ==(other) if other.respond_to?(:to_element) other.send(:state) == state end end |
#bin=(new_bin) ⇒ Object
if the specified binary has an odd length, a proper pad byte will automatically be appended to give it an even length (which is needed to conform with the DICOM standard).
Sets the binary string of a Element.
105 106 107 108 109 110 111 112 113 114 115 |
# File 'lib/dicom/element.rb', line 105 def bin=(new_bin) raise ArgumentError, "Expected String, got #{new_bin.class}." unless new_bin.is_a?(String) # Add a zero byte at the end if the length of the binary is odd: if new_bin.length.odd? @bin = new_bin + stream.pad_byte[@vr] else @bin = new_bin end @value = nil @length = @bin.length end |
#children? ⇒ FalseClass
Checks if the Element actually has any child elementals.
121 122 123 |
# File 'lib/dicom/element.rb', line 121 def children? return false end |
#endian ⇒ Boolean
Gives the endianness of the encoded binary value of this element.
129 130 131 |
# File 'lib/dicom/element.rb', line 129 def endian return stream.str_endian end |
#hash ⇒ Integer
Two objects with the same attributes will have the same hash code.
Computes a hash code for this object.
139 140 141 |
# File 'lib/dicom/element.rb', line 139 def hash state.hash end |
#inspect ⇒ String
Gives a string containing a human-readable hash representation of the Element.
147 148 149 |
# File 'lib/dicom/element.rb', line 147 def inspect to_hash.inspect end |
#is_parent? ⇒ FalseClass
Checks if the Element is a parent.
155 156 157 |
# File 'lib/dicom/element.rb', line 155 def is_parent? return false end |
#to_element ⇒ Element
Returns self.
173 174 175 |
# File 'lib/dicom/element.rb', line 173 def to_element self end |
#to_hash ⇒ Hash
The key representation in this hash is configurable (refer to the DICOM module methods documentation for more details).
Creates a hash representation of the element instance.
165 166 167 |
# File 'lib/dicom/element.rb', line 165 def to_hash return {self.send(DICOM.key_representation) => value} end |
#to_json ⇒ String
Gives a json string containing a human-readable representation of the Element.
181 182 183 |
# File 'lib/dicom/element.rb', line 181 def to_json to_hash.to_json end |
#to_yaml ⇒ String
Gives a yaml string containing a human-readable representation of the Element.
189 190 191 |
# File 'lib/dicom/element.rb', line 189 def to_yaml to_hash.to_yaml end |
#value ⇒ String, ...
Returned string values are automatically converted from their originally encoding (e.g. ISO8859-1 or ASCII-8BIT) to UTF-8 for convenience reasons. If the value string is wanted in its original encoding, extract the data element’s bin attribute instead.
Note that according to the DICOM Standard PS 3.5 C.12.1.1.2, the Character Set only applies
Gives the (decoded) value of the data element.
to values of data elements of type SH, LO, ST, PN, LT or UT. Currently in ruby-dicom, all string values are encoding converted regardless of VR, but whether this causes any problems is uknown.
206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 |
# File 'lib/dicom/element.rb', line 206 def value if @value.is_a?(String) # Unless this is actually the Character Set data element, # get the character set (note that it may not be available): character_set = (@tag != '0008,0005' && top_parent.is_a?(DObject)) ? top_parent.value('0008,0005') : nil # Convert to UTF-8 from [original encoding]: # In most cases the original encoding is IS0-8859-1 (ISO_IR 100), but if # it is not specified in the DICOM object, or if the specified string # is not recognized, ASCII-8BIT is assumed. @value.encode('UTF-8', ENCODING_NAME[character_set]) # If unpleasant encoding exceptions occur, the below version may be considered: #@value.encode('UTF-8', ENCODING_NAME[character_set], :invalid => :replace, :undef => :replace) else @value end end |
#value=(new_value) ⇒ Object
The specified value must be of a type that is compatible with the Element’s value representation (vr).
Sets the value of the Element instance.
In addition to updating the value attribute, the specified value is encoded to binary and used to update the Element’s bin and length attributes too.
231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 |
# File 'lib/dicom/element.rb', line 231 def value=(new_value) if VALUE_CONVERSION[@vr] == :to_s # Unless this is actually the Character Set data element, # get the character set (note that it may not be available): character_set = (@tag != '0008,0005' && top_parent.is_a?(DObject)) ? top_parent.value('0008,0005') : nil # Convert to [DObject encoding] from [input string encoding]: # In most cases the DObject encoding is IS0-8859-1 (ISO_IR 100), but if # it is not specified in the DICOM object, or if the specified string # is not recognized, ASCII-8BIT is assumed. @value = new_value.to_s.encode(ENCODING_NAME[character_set], new_value.to_s.encoding.name) @bin = encode(@value) else # We may have an array (of numbers) which needs to be passed directly to # the encode method instead of being forced into a numerical: if new_value.is_a?(Array) @value = new_value @bin = encode(@value) else @value = new_value.send(VALUE_CONVERSION[@vr]) @bin = encode(@value) end end @length = @bin.length end |