Module: SpatialFeatures::InstanceMethods
- Defined in:
- lib/spatial_features/has_spatial_features.rb
Instance Method Summary collapse
- #acts_like_spatial_features? ⇒ Boolean
- #features? ⇒ Boolean
- #features_area_in_square_meters ⇒ Object
- #features_cache_key ⇒ Object
- #intersects?(other) ⇒ Boolean
- #lines? ⇒ Boolean
- #points? ⇒ Boolean
- #polygons? ⇒ Boolean
- #spatial_cache_for?(other, buffer_in_meters) ⇒ Boolean
- #total_intersection_area_in_square_meters(other) ⇒ Object
- #total_intersection_area_percentage(klass) ⇒ Object
Instance Method Details
#acts_like_spatial_features? ⇒ Boolean
161 162 163 |
# File 'lib/spatial_features/has_spatial_features.rb', line 161 def acts_like_spatial_features? true end |
#features? ⇒ Boolean
181 182 183 |
# File 'lib/spatial_features/has_spatial_features.rb', line 181 def features? features.present? end |
#features_area_in_square_meters ⇒ Object
195 196 197 |
# File 'lib/spatial_features/has_spatial_features.rb', line 195 def features_area_in_square_meters @features_area_in_square_meters ||= features.area end |
#features_cache_key ⇒ Object
165 166 167 |
# File 'lib/spatial_features/has_spatial_features.rb', line 165 def features_cache_key "#{self.class.name}/#{self.id}-#{features.cache_key}" end |
#intersects?(other) ⇒ Boolean
185 186 187 |
# File 'lib/spatial_features/has_spatial_features.rb', line 185 def intersects?(other) self.class.intersecting(other).exists?(self) end |
#lines? ⇒ Boolean
173 174 175 |
# File 'lib/spatial_features/has_spatial_features.rb', line 173 def lines? !features.lines.empty? end |
#points? ⇒ Boolean
177 178 179 |
# File 'lib/spatial_features/has_spatial_features.rb', line 177 def points? !features.points.empty? end |
#polygons? ⇒ Boolean
169 170 171 |
# File 'lib/spatial_features/has_spatial_features.rb', line 169 def polygons? !features.polygons.empty? end |
#spatial_cache_for?(other, buffer_in_meters) ⇒ Boolean
205 206 207 208 209 210 211 212 213 214 215 |
# File 'lib/spatial_features/has_spatial_features.rb', line 205 def spatial_cache_for?(other, buffer_in_meters) if cache = spatial_caches.between(self, Utils.class_of(other)).first return cache.intersection_cache_distance.nil? if buffer_in_meters.nil? # cache must be total if no buffer_in_meters return false if cache.stale? # cache must be for current features return true if cache.intersection_cache_distance.nil? # always good if cache is total return buffer_in_meters <= cache.intersection_cache_distance else return false end end |
#total_intersection_area_in_square_meters(other) ⇒ Object
199 200 201 202 203 |
# File 'lib/spatial_features/has_spatial_features.rb', line 199 def total_intersection_area_in_square_meters(other) other = other.intersecting(self) unless other.is_a?(ActiveRecord::Base) return features.area if spatial_cache_for?(other, 0) && SpatialProximity.between(self, other).where('intersection_area_in_square_meters >= ?', features.area).exists? return features.total_intersection_area_in_square_meters(other.features) end |
#total_intersection_area_percentage(klass) ⇒ Object
189 190 191 192 193 |
# File 'lib/spatial_features/has_spatial_features.rb', line 189 def total_intersection_area_percentage(klass) return 0.0 unless features_area_in_square_meters > 0 ((total_intersection_area_in_square_meters(klass) / features_area_in_square_meters) * 100).round(1) end |