зеркало из https://github.com/mozilla/gecko-dev.git
170 строки
5.3 KiB
C++
170 строки
5.3 KiB
C++
/* -*- Mode: C++; tab-width: 20; indent-tabs-mode: nil; c-basic-offset: 2 -*-
|
|
* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
|
|
|
#ifndef MOZILLA_GFX_WEBRENDERCOMPOSITABLE_HOLDER_H
|
|
#define MOZILLA_GFX_WEBRENDERCOMPOSITABLE_HOLDER_H
|
|
|
|
#include <queue>
|
|
|
|
#include "CompositableHost.h"
|
|
#include "mozilla/gfx/Point.h"
|
|
#include "mozilla/layers/TextureHost.h"
|
|
#include "mozilla/Maybe.h"
|
|
#include "mozilla/webrender/WebRenderAPI.h"
|
|
#include "mozilla/webrender/WebRenderTypes.h"
|
|
#include "nsClassHashtable.h"
|
|
|
|
namespace mozilla {
|
|
|
|
namespace wr {
|
|
class DisplayListBuilder;
|
|
class WebRenderAPI;
|
|
}
|
|
|
|
namespace layers {
|
|
|
|
class CompositableHost;
|
|
class CompositorVsyncScheduler;
|
|
class WebRenderImageHost;
|
|
class WebRenderTextureHost;
|
|
|
|
class AsyncImagePipelineManager final
|
|
{
|
|
public:
|
|
NS_INLINE_DECL_THREADSAFE_REFCOUNTING(AsyncImagePipelineManager)
|
|
|
|
explicit AsyncImagePipelineManager(already_AddRefed<wr::WebRenderAPI>&& aApi);
|
|
|
|
protected:
|
|
~AsyncImagePipelineManager();
|
|
|
|
public:
|
|
void Destroy();
|
|
|
|
void AddPipeline(const wr::PipelineId& aPipelineId);
|
|
void RemovePipeline(const wr::PipelineId& aPipelineId, const wr::Epoch& aEpoch);
|
|
|
|
void HoldExternalImage(const wr::PipelineId& aPipelineId, const wr::Epoch& aEpoch, WebRenderTextureHost* aTexture);
|
|
void Update(const wr::PipelineId& aPipelineId, const wr::Epoch& aEpoch);
|
|
|
|
TimeStamp GetCompositionTime() const {
|
|
return mCompositionTime;
|
|
}
|
|
void SetCompositionTime(TimeStamp aTimeStamp) {
|
|
mCompositionTime = aTimeStamp;
|
|
if (!mCompositionTime.IsNull() && !mCompositeUntilTime.IsNull() &&
|
|
mCompositionTime >= mCompositeUntilTime) {
|
|
mCompositeUntilTime = TimeStamp();
|
|
}
|
|
}
|
|
void CompositeUntil(TimeStamp aTimeStamp) {
|
|
if (mCompositeUntilTime.IsNull() ||
|
|
mCompositeUntilTime < aTimeStamp) {
|
|
mCompositeUntilTime = aTimeStamp;
|
|
}
|
|
}
|
|
TimeStamp GetCompositeUntilTime() const {
|
|
return mCompositeUntilTime;
|
|
}
|
|
|
|
void AddAsyncImagePipeline(const wr::PipelineId& aPipelineId, WebRenderImageHost* aImageHost);
|
|
void RemoveAsyncImagePipeline(const wr::PipelineId& aPipelineId);
|
|
|
|
void UpdateAsyncImagePipeline(const wr::PipelineId& aPipelineId,
|
|
const LayerRect& aScBounds,
|
|
const gfx::Matrix4x4& aScTransform,
|
|
const gfx::MaybeIntSize& aScaleToSize,
|
|
const wr::ImageRendering& aFilter,
|
|
const wr::MixBlendMode& aMixBlendMode);
|
|
void ApplyAsyncImages();
|
|
|
|
void AppendImageCompositeNotification(const ImageCompositeNotificationInfo& aNotification)
|
|
{
|
|
mImageCompositeNotifications.AppendElement(aNotification);
|
|
}
|
|
|
|
void FlushImageNotifications(nsTArray<ImageCompositeNotificationInfo>* aNotifications)
|
|
{
|
|
aNotifications->AppendElements(Move(mImageCompositeNotifications));
|
|
}
|
|
|
|
private:
|
|
|
|
uint32_t GetNextResourceId() { return ++mResourceId; }
|
|
wr::IdNamespace GetNamespace() { return mIdNamespace; }
|
|
wr::ImageKey GenerateImageKey()
|
|
{
|
|
wr::ImageKey key;
|
|
key.mNamespace = GetNamespace();
|
|
key.mHandle = GetNextResourceId();
|
|
return key;
|
|
}
|
|
|
|
struct ForwardingTextureHost {
|
|
ForwardingTextureHost(const wr::Epoch& aEpoch, TextureHost* aTexture)
|
|
: mEpoch(aEpoch)
|
|
, mTexture(aTexture)
|
|
{}
|
|
wr::Epoch mEpoch;
|
|
CompositableTextureHostRef mTexture;
|
|
};
|
|
|
|
struct PipelineTexturesHolder {
|
|
// Holds forwarding WebRenderTextureHosts.
|
|
std::queue<ForwardingTextureHost> mTextureHosts;
|
|
Maybe<wr::Epoch> mDestroyedEpoch;
|
|
};
|
|
|
|
struct AsyncImagePipeline {
|
|
AsyncImagePipeline();
|
|
|
|
bool mInitialised;
|
|
bool mIsChanged;
|
|
bool mUseExternalImage;
|
|
LayerRect mScBounds;
|
|
gfx::Matrix4x4 mScTransform;
|
|
gfx::MaybeIntSize mScaleToSize;
|
|
wr::ImageRendering mFilter;
|
|
wr::MixBlendMode mMixBlendMode;
|
|
RefPtr<WebRenderImageHost> mImageHost;
|
|
CompositableTextureHostRef mCurrentTexture;
|
|
nsTArray<wr::ImageKey> mKeys;
|
|
};
|
|
|
|
Maybe<TextureHost::ResourceUpdateOp>
|
|
UpdateImageKeys(wr::ResourceUpdateQueue& aResourceUpdates,
|
|
AsyncImagePipeline* aPipeline,
|
|
nsTArray<wr::ImageKey>& aKeys);
|
|
Maybe<TextureHost::ResourceUpdateOp>
|
|
UpdateWithoutExternalImage(wr::ResourceUpdateQueue& aResources,
|
|
TextureHost* aTexture,
|
|
wr::ImageKey aKey,
|
|
TextureHost::ResourceUpdateOp);
|
|
|
|
RefPtr<wr::WebRenderAPI> mApi;
|
|
wr::IdNamespace mIdNamespace;
|
|
uint32_t mResourceId;
|
|
|
|
nsClassHashtable<nsUint64HashKey, PipelineTexturesHolder> mPipelineTexturesHolders;
|
|
nsClassHashtable<nsUint64HashKey, AsyncImagePipeline> mAsyncImagePipelines;
|
|
uint32_t mAsyncImageEpoch;
|
|
bool mDestroyed;
|
|
|
|
// Render time for the current composition.
|
|
TimeStamp mCompositionTime;
|
|
|
|
// When nonnull, during rendering, some compositable indicated that it will
|
|
// change its rendering at this time. In order not to miss it, we composite
|
|
// on every vsync until this time occurs (this is the latest such time).
|
|
TimeStamp mCompositeUntilTime;
|
|
|
|
nsTArray<ImageCompositeNotificationInfo> mImageCompositeNotifications;
|
|
};
|
|
|
|
} // namespace layers
|
|
} // namespace mozilla
|
|
|
|
#endif /* MOZILLA_GFX_WEBRENDERCOMPOSITABLE_HOLDER_H */
|