velocity_tracker_bench.dart 1.13 KB
Newer Older
Ian Hickson's avatar
Ian Hickson committed
1
// Copyright 2014 The Flutter Authors. All rights reserved.
2 3 4 5 6
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

import 'package:flutter/gestures.dart';

7
import '../common.dart';
8
import 'data/velocity_tracker_data.dart';
9

10 11 12
const int _kNumIters = 10000;

void main() {
13
  assert(false, "Don't run benchmarks in checked mode! Use 'flutter run --release'.");
14 15
  final VelocityTracker tracker = VelocityTracker();
  final Stopwatch watch = Stopwatch();
16 17 18
  print('Velocity tracker benchmark...');
  watch.start();
  for (int i = 0; i < _kNumIters; i += 1) {
19
    for (final PointerEvent event in velocityEventData) {
20 21 22 23 24 25 26
      if (event is PointerDownEvent || event is PointerMoveEvent)
        tracker.addPosition(event.timeStamp, event.position);
      if (event is PointerUpEvent)
        tracker.getVelocity();
    }
  }
  watch.stop();
27

28
  final BenchmarkResultPrinter printer = BenchmarkResultPrinter();
29 30 31 32 33 34 35
  printer.addResult(
    description: 'Velocity tracker',
    value: watch.elapsedMicroseconds / _kNumIters,
    unit: 'µs per iteration',
    name: 'velocity_tracker_iteration',
  );
  printer.printToStdout();
36
}