// Copyright 2014 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef MEDIA_CAST_LOGGING_RECEIVER_TIME_OFFSET_ESTIMATOR_H_ #define MEDIA_CAST_LOGGING_RECEIVER_TIME_OFFSET_ESTIMATOR_H_ #include "base/time/time.h" #include "media/cast/logging/raw_event_subscriber.h" namespace media { namespace cast { // Estimates receiver time offset based on raw events received. // In most cases, the sender and receiver run on different time lines. // In order to convert receiver time back to sender time (or vice versa) // a certain time offset has to be applied. // An implementation of this interface listens to raw events to figure out // the bounds for the offset value (assuming the true offset value is constant // over the lifetime of a cast session). // The offset values provided here should be used as follows: // - Convert from sender to receiver time: add offset value to sender timestamp. // - Convert from receiver to sender time: subtract offset value from receiver // timestamp. class ReceiverTimeOffsetEstimator : public RawEventSubscriber { public: ~ReceiverTimeOffsetEstimator() override {} // If bounds are known, assigns |lower_bound| and |upper_bound| with the // lower bound and upper bound for the offset value, respectively. // Returns true if bounds are known. virtual bool GetReceiverOffsetBounds(base::TimeDelta* lower_bound, base::TimeDelta* upper_bound) = 0; }; } // namespace cast } // namespace media #endif // MEDIA_CAST_LOGGING_RECEIVER_TIME_OFFSET_ESTIMATOR_H_