Class: Contrek::Reducers::VisvalingamReducer

Inherits:
Reducer
  • Object
show all
Defined in:
lib/contrek/reducers/visvalingam_reducer.rb

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(points: list_of_points, options: {}) ⇒ VisvalingamReducer

Returns a new instance of VisvalingamReducer.



7
8
9
10
# File 'lib/contrek/reducers/visvalingam_reducer.rb', line 7

def initialize(points: list_of_points, options: {})
  @pts = points
  @tolerance = options[:tolerance] * options[:tolerance]
end

Class Method Details

.simplify(pts, distance_tolerance) ⇒ Object



16
17
18
19
# File 'lib/contrek/reducers/visvalingam_reducer.rb', line 16

def self.simplify(pts, distance_tolerance)
  simp = Polygon::Reducers::VisvalingamReducer.new(pts, distance_tolerance)
  simp.simplify
end

Instance Method Details

#reduce!Object



12
13
14
# File 'lib/contrek/reducers/visvalingam_reducer.rb', line 12

def reduce!
  @pts.replace simplify
end

#simplifyObject



21
22
23
24
25
26
27
28
29
# File 'lib/contrek/reducers/visvalingam_reducer.rb', line 21

def simplify
  vw_line = Vertex.build_line(@pts)
  min_area = @tolerance
  loop do
    min_area = simplify_vertex(vw_line)
    break if min_area >= @tolerance
  end
  vw_line.get_coordinates
end