blob: 87b0a15e38c4fc93d516118ec97e1570d34bf149 [file] [log] [blame]
// Copyright 2013 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 UI_GFX_VSYNC_PROVIDER_H_
#define UI_GFX_VSYNC_PROVIDER_H_
#include "base/callback.h"
#include "base/time/time.h"
#include "ui/gfx/gfx_export.h"
namespace gfx {
class GFX_EXPORT VSyncProvider {
public:
virtual ~VSyncProvider() {}
typedef base::OnceCallback<void(const base::TimeTicks timebase,
const base::TimeDelta interval)>
UpdateVSyncCallback;
// Get the time of the most recent screen refresh, along with the time
// between consecutive refreshes. The callback is called as soon as
// the data is available: it could be immediately from this method,
// later via a PostTask to the current MessageLoop, or never (if we have
// no data source). We provide the strong guarantee that the callback will
// not be called once the instance of this class is destroyed.
virtual void GetVSyncParameters(UpdateVSyncCallback callback) = 0;
// Similar to GetVSyncParameters(). It returns true, if the data is available.
// Otherwise false is returned.
virtual bool GetVSyncParametersIfAvailable(base::TimeTicks* timebase,
base::TimeDelta* interval) = 0;
// Returns true, if GetVSyncParametersIfAvailable is supported.
virtual bool SupportGetVSyncParametersIfAvailable() const = 0;
// Returns true, if VSyncProvider gets VSync timebase from HW.
virtual bool IsHWClock() const = 0;
};
// Provides a constant timebase and interval.
class GFX_EXPORT FixedVSyncProvider : public VSyncProvider {
public:
FixedVSyncProvider(base::TimeTicks timebase, base::TimeDelta interval)
: timebase_(timebase), interval_(interval) {
}
~FixedVSyncProvider() override {}
void GetVSyncParameters(UpdateVSyncCallback callback) override;
bool GetVSyncParametersIfAvailable(base::TimeTicks* timebase,
base::TimeDelta* interval) override;
bool SupportGetVSyncParametersIfAvailable() const override;
bool IsHWClock() const override;
private:
base::TimeTicks timebase_;
base::TimeDelta interval_;
};
} // namespace gfx
#endif // UI_GFX_VSYNC_PROVIDER_H_