File: interpolation_effect.cc

package info (click to toggle)
chromium 138.0.7204.183-1
  • links: PTS, VCS
  • area: main
  • in suites: trixie
  • size: 6,071,908 kB
  • sloc: cpp: 34,937,088; ansic: 7,176,967; javascript: 4,110,704; python: 1,419,953; asm: 946,768; xml: 739,971; pascal: 187,324; sh: 89,623; perl: 88,663; objc: 79,944; sql: 50,304; cs: 41,786; fortran: 24,137; makefile: 21,806; php: 13,980; tcl: 13,166; yacc: 8,925; ruby: 7,485; awk: 3,720; lisp: 3,096; lex: 1,327; ada: 727; jsp: 228; sed: 36
file content (77 lines) | stat: -rw-r--r-- 2,918 bytes parent folder | download | duplicates (8)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
// Copyright 2014 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

#include "third_party/blink/renderer/core/animation/interpolation_effect.h"

namespace blink {

void InterpolationEffect::GetActiveInterpolations(
    double fraction,
    TimingFunction::LimitDirection limit_direction,
    HeapVector<Member<Interpolation>>& result) const {
  wtf_size_t existing_size = result.size();
  wtf_size_t result_index = 0;

  for (const auto& record : interpolations_) {
    Interpolation* interpolation = nullptr;
    if (record->is_static_) {
      // The local fraction is irrelevant since the result is constant valued.
      // The first sample will cache a value, which will be reused in
      // subsequent calls as long as the cache is not invalidated.
      interpolation = record->interpolation_;
      interpolation->Interpolate(0, 0);
    } else {
      if (fraction >= record->apply_from_ && fraction < record->apply_to_) {
        // TODO(kevers): There is room to expand the optimization to allow a
        // non-static property to have static records in the event of keyframe
        // pairs with identical values. We could then skip the local fraction
        // calculation and simply sample at 0. For this, we would still need
        // records for each keyframe pair.
        interpolation = record->interpolation_;
        double record_length = record->end_ - record->start_;
        double local_fraction =
            record_length ? (fraction - record->start_) / record_length : 0.0;
        if (record->easing_) {
          local_fraction =
              record->easing_->Evaluate(local_fraction, limit_direction);
        }
        interpolation->Interpolate(0, local_fraction);
      }
    }
    if (interpolation) {
      if (result_index < existing_size) {
        result[result_index++] = interpolation;
      } else {
        result.push_back(interpolation);
      }
    }
  }
  if (result_index < existing_size) {
    result.Shrink(result_index);
  }
}

void InterpolationEffect::AddInterpolationsFromKeyframes(
    const PropertyHandle& property,
    const Keyframe::PropertySpecificKeyframe& keyframe_a,
    const Keyframe::PropertySpecificKeyframe& keyframe_b,
    double apply_from,
    double apply_to) {
  AddInterpolation(keyframe_a.CreateInterpolation(property, keyframe_b),
                   &keyframe_a.Easing(), keyframe_a.Offset(),
                   keyframe_b.Offset(), apply_from, apply_to);
}

void InterpolationEffect::AddStaticValuedInterpolation(
    const PropertyHandle& property,
    const Keyframe::PropertySpecificKeyframe& keyframe) {
  interpolations_.push_back(MakeGarbageCollected<InterpolationRecord>(
      keyframe.CreateInterpolation(property, keyframe)));
}

void InterpolationEffect::Trace(Visitor* visitor) const {
  visitor->Trace(interpolations_);
}

}  // namespace blink