X-Git-Url: https://git.openstreetmap.org/rails.git/blobdiff_plain/26fb51c86e178a1c5bbe313c4688c623646173f8..565171486f6d90321e0291d5ccc3cf6a1c12e730:/app/models/tracepoint.rb diff --git a/app/models/tracepoint.rb b/app/models/tracepoint.rb index 1d9f1bd6b..d4ba39de3 100644 --- a/app/models/tracepoint.rb +++ b/app/models/tracepoint.rb @@ -1,4 +1,6 @@ class Tracepoint < ActiveRecord::Base + include GeoRecord + set_table_name 'gps_points' validates_numericality_of :trackid, :only_integer => true @@ -8,39 +10,12 @@ class Tracepoint < ActiveRecord::Base validates_presence_of :timestamp belongs_to :trace, :foreign_key => 'gpx_id' - - before_save :update_tile - - def self.find_by_area(minlat, minlon, maxlat, maxlon, options) - self.with_scope(:find => {:conditions => OSM.sql_for_area(minlat, minlon, maxlat, maxlon)}) do - return self.find(:all, options) - end - end - - def update_tile - self.tile = QuadTile.tile_for_point(lat, lon) - end - - def lat=(l) - self.latitude = (l * 10000000).round - end - - def lon=(l) - self.longitude = (l * 10000000).round - end - - def lat - return self.latitude.to_f / 10000000 - end - - def lon - return self.longitude.to_f / 10000000 - end - def to_xml_node + def to_xml_node(print_timestamp = false) el1 = XML::Node.new 'trkpt' el1['lat'] = self.lat.to_s el1['lon'] = self.lon.to_s + el1 << (XML::Node.new("time") << self.timestamp.xmlschema) if print_timestamp return el1 end end