mirror of
https://github.com/flutter/flutter.git
synced 2026-02-20 02:29:02 +08:00
fixes https://github.com/flutter/flutter/issues/146990 ## Pre-launch Checklist - [x] I read the [Contributor Guide] and followed the process outlined there for submitting PRs. - [x] I read the [Tree Hygiene] wiki page, which explains my responsibilities. - [x] I read and followed the [Flutter Style Guide] and the [C++, Objective-C, Java style guides]. - [x] I listed at least one issue that this PR fixes in the description above. - [x] I added new tests to check the change I am making or feature I am adding, or the PR is [test-exempt]. See [testing the engine] for instructions on writing and running engine tests. - [x] I updated/added relevant documentation (doc comments with `///`). - [x] I signed the [CLA]. - [x] All existing and new tests are passing. If you need help, consider asking for advice on the #hackers-new channel on [Discord]. <!-- Links --> [Contributor Guide]: https://github.com/flutter/flutter/wiki/Tree-hygiene#overview [Tree Hygiene]: https://github.com/flutter/flutter/wiki/Tree-hygiene [test-exempt]: https://github.com/flutter/flutter/wiki/Tree-hygiene#tests [Flutter Style Guide]: https://github.com/flutter/flutter/wiki/Style-guide-for-Flutter-repo [C++, Objective-C, Java style guides]: https://github.com/flutter/engine/blob/main/CONTRIBUTING.md#style [testing the engine]: https://github.com/flutter/flutter/wiki/Testing-the-engine [CLA]: https://cla.developers.google.com/ [flutter/tests]: https://github.com/flutter/tests [breaking change policy]: https://github.com/flutter/flutter/wiki/Tree-hygiene#handling-breaking-changes [Discord]: https://github.com/flutter/flutter/wiki/Chat
68 lines
2.2 KiB
C++
68 lines
2.2 KiB
C++
// Copyright 2013 The Flutter 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 FLUTTER_SHELL_COMMON_SNAPSHOT_CONTROLLER_H_
|
|
#define FLUTTER_SHELL_COMMON_SNAPSHOT_CONTROLLER_H_
|
|
|
|
#include "flutter/common/settings.h"
|
|
#include "flutter/display_list/image/dl_image.h"
|
|
#include "flutter/flow/surface.h"
|
|
#include "flutter/fml/synchronization/sync_switch.h"
|
|
#include "flutter/lib/ui/snapshot_delegate.h"
|
|
#include "flutter/shell/common/snapshot_surface_producer.h"
|
|
|
|
namespace impeller {
|
|
class AiksContext;
|
|
}
|
|
|
|
namespace flutter {
|
|
|
|
class SnapshotController {
|
|
public:
|
|
class Delegate {
|
|
public:
|
|
virtual ~Delegate() = default;
|
|
virtual const std::unique_ptr<Surface>& GetSurface() const = 0;
|
|
virtual std::shared_ptr<impeller::AiksContext> GetAiksContext() const = 0;
|
|
virtual const std::unique_ptr<SnapshotSurfaceProducer>&
|
|
GetSnapshotSurfaceProducer() const = 0;
|
|
virtual std::shared_ptr<const fml::SyncSwitch> GetIsGpuDisabledSyncSwitch()
|
|
const = 0;
|
|
};
|
|
|
|
static std::unique_ptr<SnapshotController> Make(const Delegate& delegate,
|
|
const Settings& settings);
|
|
|
|
virtual ~SnapshotController() = default;
|
|
|
|
virtual void MakeRasterSnapshot(
|
|
sk_sp<DisplayList> display_list,
|
|
SkISize picture_size,
|
|
std::function<void(const sk_sp<DlImage>&)> callback) = 0;
|
|
|
|
// Note that this image is not guaranteed to be UIThreadSafe and must
|
|
// be converted to a DlImageGPU if it is to be handed back to the UI
|
|
// thread.
|
|
virtual sk_sp<DlImage> MakeRasterSnapshotSync(sk_sp<DisplayList> display_list,
|
|
SkISize picture_size) = 0;
|
|
|
|
virtual sk_sp<SkImage> ConvertToRasterImage(sk_sp<SkImage> image) = 0;
|
|
|
|
virtual void CacheRuntimeStage(
|
|
const std::shared_ptr<impeller::RuntimeStage>& runtime_stage) = 0;
|
|
|
|
protected:
|
|
explicit SnapshotController(const Delegate& delegate);
|
|
const Delegate& GetDelegate() { return delegate_; }
|
|
|
|
private:
|
|
const Delegate& delegate_;
|
|
|
|
FML_DISALLOW_COPY_AND_ASSIGN(SnapshotController);
|
|
};
|
|
|
|
} // namespace flutter
|
|
|
|
#endif // FLUTTER_SHELL_COMMON_SNAPSHOT_CONTROLLER_H_
|