Class: GeoRuby::SimpleFeatures::MultiLineString

Inherits:
GeometryCollection show all
Defined in:
lib/geo_ruby/simple_features/multi_line_string.rb

Overview

Represents a group of line strings (see LineString).

Instance Attribute Summary

Attributes inherited from GeometryCollection

#geometries

Attributes inherited from Geometry

#srid, #with_m, #with_z

Class Method Summary collapse

Instance Method Summary collapse

Methods inherited from GeometryCollection

#==, #binary_representation, #bounding_box, from_geometries, #georss_gml_representation, #georss_simple_representation, #georss_w3cgeo_representation, #kml_representation, #m_range, #method_missing

Methods inherited from Geometry

#as_ewkb, #as_ewkt, #as_georss, #as_hex_ewkb, #as_hex_wkb, #as_kml, #as_wkb, #as_wkt, #bounding_box, #envelope, from_ewkb, from_ewkt, from_geojson, from_georss, from_georss_with_tags, from_hex_ewkb, from_kml, #m_range, #to_json

Constructor Details

#initialize(srid = DEFAULT_SRID, _with_z = false, _with_m = false) ⇒ MultiLineString

Returns a new instance of MultiLineString.



7
8
9
# File 'lib/geo_ruby/simple_features/multi_line_string.rb', line 7

def initialize(srid = DEFAULT_SRID, _with_z = false, _with_m = false)
  super(srid)
end

Dynamic Method Handling

This class handles dynamic methods through the method_missing method in the class GeoRuby::SimpleFeatures::GeometryCollection

Class Method Details

.from_coordinates(point_sequences, srid = DEFAULT_SRID, with_z = false, with_m = false) ⇒ Object

Creates a new multi line string from sequences of points : (((x,y)…(x,y)),((x,y)…(x,y)))



49
50
51
52
53
# File 'lib/geo_ruby/simple_features/multi_line_string.rb', line 49

def self.from_coordinates(point_sequences, srid = DEFAULT_SRID, with_z = false, with_m = false)
  multi_line_string = new(srid, with_z, with_m)
  multi_line_string.concat(point_sequences.collect { |points| LineString.from_coordinates(points, srid, with_z, with_m) })
  multi_line_string
end

.from_line_strings(line_strings, srid = DEFAULT_SRID, with_z = false, with_m = false) ⇒ Object

Creates a new multi line string from an array of line strings



42
43
44
45
46
# File 'lib/geo_ruby/simple_features/multi_line_string.rb', line 42

def self.from_line_strings(line_strings, srid = DEFAULT_SRID, with_z = false, with_m = false)
  multi_line_string = new(srid, with_z, with_m)
  multi_line_string.concat(line_strings)
  multi_line_string
end

Instance Method Details

#as_json(_options = {}) ⇒ Object



37
38
39
# File 'lib/geo_ruby/simple_features/multi_line_string.rb', line 37

def as_json(_options = {})
  { type: 'MultiLineString', coordinates: to_coordinates }
end

#binary_geometry_typeObject

:nodoc:



11
12
13
# File 'lib/geo_ruby/simple_features/multi_line_string.rb', line 11

def binary_geometry_type #:nodoc:
  5
end

#pointsObject



15
16
17
# File 'lib/geo_ruby/simple_features/multi_line_string.rb', line 15

def points
  geometries.map(&:points).flatten
end

#text_geometry_typeObject

WKT geometry type



25
26
27
# File 'lib/geo_ruby/simple_features/multi_line_string.rb', line 25

def text_geometry_type #:nodoc:
  'MULTILINESTRING'
end

#text_representation(allow_z = true, allow_m = true) ⇒ Object

Text representation of a multi line string



20
21
22
# File 'lib/geo_ruby/simple_features/multi_line_string.rb', line 20

def text_representation(allow_z = true, allow_m = true) #:nodoc:
  @geometries.collect { |line_string| '(' + line_string.text_representation(allow_z, allow_m) + ')' }.join(',')
end

#to_coordinatesObject



33
34
35
# File 'lib/geo_ruby/simple_features/multi_line_string.rb', line 33

def to_coordinates
  geometries.map(&:to_coordinates)
end

#to_line_string(_join = true) ⇒ Object



29
30
31
# File 'lib/geo_ruby/simple_features/multi_line_string.rb', line 29

def to_line_string(_join = true)
  LineString.from_points(points)
end