diff options
Diffstat (limited to 'lib')
-rw-r--r-- | lib/postrunner/ChartView.rb | 58 | ||||
-rw-r--r-- | lib/postrunner/DeviceList.rb | 2 |
2 files changed, 48 insertions, 12 deletions
diff --git a/lib/postrunner/ChartView.rb b/lib/postrunner/ChartView.rb index 775c33e..1208511 100644 --- a/lib/postrunner/ChartView.rb +++ b/lib/postrunner/ChartView.rb @@ -177,8 +177,9 @@ EOT else value = (value * 3600.0 * 1000).to_i end + min_value = 0.0 else - min_value = value if value && (min_value.nil? || min_value > value) + min_value = value if (min_value.nil? || min_value > value) end data_set << [ ((r.timestamp.to_i - start_time) * 1000).to_i, value ] end @@ -191,18 +192,19 @@ EOT s << data_set.map do |set| "[ #{set[0]}, #{set[1] ? set[1] : 'null'} ]" end.join(', ') + s << "];\n" + + s << lap_marks(start_time) chart_id = "#{field}_chart" s << <<"EOT" - ]; - - $.plot(\"##{chart_id}\", + var plot = $.plot(\"##{chart_id}\", [ { data: #{field}_data, #{color ? "color: \"#{color}\"," : ''} lines: { show: true#{field == 'pace' ? '' : ', fill: true'} } } ], { xaxis: { mode: "time" }, - grid: { hoverable: true } + grid: { markings: lap_marks, hoverable: true } EOT if field == 'pace' s << ", yaxis: { mode: \"time\",\n" + @@ -213,6 +215,7 @@ EOT s << ", yaxis: { min: #{0.9 * min_value} }" end s << "});\n" + s << lap_mark_labels(chart_id, start_time) s << hover_function(chart_id, y_label, select_unit(unit)) + "\n" end @@ -234,11 +237,11 @@ EOT # Find the right set by looking at the maximum allowed values for each # color. colors.each.with_index do |col_max_value, i| - col, max_value = col_max_value - if max_value.nil? || value < max_value - # A max_value of nil means all values allowed. The value is in the - # allowed range for this set, so add the value as x/y pair to the - # set. + col, range_max_value = col_max_value + if range_max_value.nil? || value < range_max_value + # A range_max_value of nil means all values allowed. The value is + # in the allowed range for this set, so add the value as x/y pair + # to the set. x_val = (r.timestamp.to_i - start_time) * 1000 data_sets[i] << [ x_val, r.get_as(field, select_unit(unit)) ] # Abort the color loop since we've found the right set already. @@ -261,8 +264,10 @@ EOT s << " ];\n" end + s << lap_marks(start_time) + chart_id = "#{field}_chart" - s << "$.plot(\"##{chart_id}\", [\n" + s << "var plot = $.plot(\"##{chart_id}\", [\n" s << data_sets.map do |index, ds| "{ data: #{field}_data_#{index},\n" + " color: \"#{colors[index][0]}\",\n" + @@ -270,7 +275,8 @@ EOT " fill: true, radius: 2 } }" end.join(', ') s << "], { xaxis: { mode: \"time\" }, - grid: { hoverable: true } });\n" + grid: { markings: lap_marks, hoverable: true } });\n" + s << lap_mark_labels(chart_id, start_time) s << hover_function(chart_id, y_label, select_unit(unit)) s @@ -303,6 +309,34 @@ EOT EOT end + def lap_marks(start_time) + # Use vertical lines to mark the end of each lap. + s = "var lap_marks = [\n" + s += @activity.fit_activity.laps.map do |lap| + x = ((lap.timestamp.to_i - start_time) * 1000).to_i + "\n { color: \"#666\", lineWidth: 1, " + + "xaxis: { from: #{x} , to: #{x} } }" + end.join(",\n") + s + "];\n" + end + + def lap_mark_labels(chart_id, start_time) + # Mark the vertical lap marks with the number of the lap right to the + # left at the top end of the line. + s = '' + @activity.fit_activity.laps[0..-2].each do |lap| + x = ((lap.timestamp.to_i - start_time) * 1000).to_i + s += "$(\"##{chart_id}\").append(" + + "\"<div style='position:absolute;" + + "left:\" + (plot.pointOffset({x: #{x}, y: 0}).left - 18) + \"px;" + + "top:7px;width:16px;" + + "text-align:right;" + + "color:#666;font-size:smaller'>" + + "#{lap.message_index + 1}</div>\");\n" + end + s + end + end end diff --git a/lib/postrunner/DeviceList.rb b/lib/postrunner/DeviceList.rb index 20b976c..813501f 100644 --- a/lib/postrunner/DeviceList.rb +++ b/lib/postrunner/DeviceList.rb @@ -66,6 +66,8 @@ module PostRunner end if (type = device.device_type) rename = { 'heart_rate' => 'Heart Rate Sensor', + 'barometric_pressure' => 'Barometer', + 'position' => 'GPS', 'stride_speed_distance' => 'Footpod', 'running_dynamics' => 'Running Dynamics' } type = rename[type] if rename.include?(type) |