10 sk_sp<DlRuntimeEffect> runtime_effect,
11 std::vector<std::shared_ptr<DlColorSource>> samplers,
12 std::shared_ptr<std::vector<uint8_t>> uniform_data) {
13 return std::make_shared<DlRuntimeEffectImageFilter>(
18 const DlRect& input_bounds,
19 DlRect& output_bounds)
const {
20 output_bounds = input_bounds;
21 return &output_bounds;
28 output_bounds = input_bounds;
29 return &output_bounds;
36 input_bounds = output_bounds;
43 if (runtime_effect_ != that->runtime_effect_ ||
44 samplers_.size() != that->samplers().size() ||
45 uniform_data_->size() != that->uniform_data()->size()) {
48 for (
auto i = 0u;
i < samplers_.size();
i++) {
49 if (samplers_[
i] != that->samplers()[
i]) {
53 for (
auto i = 0u;
i < uniform_data_->size();
i++) {
54 if (uniform_data_->at(
i) != that->uniform_data()->at(
i)) {
virtual T type() const =0
bool equals_(const DlImageFilter &other) const override
DlIRect * map_device_bounds(const DlIRect &input_bounds, const DlMatrix &ctm, DlIRect &output_bounds) const override
const sk_sp< DlRuntimeEffect > runtime_effect() const
DlRect * map_local_bounds(const DlRect &input_bounds, DlRect &output_bounds) const override
const std::shared_ptr< std::vector< uint8_t > > & uniform_data() const
const std::vector< std::shared_ptr< DlColorSource > > & samplers() const
DlIRect * get_input_device_bounds(const DlIRect &output_bounds, const DlMatrix &ctm, DlIRect &input_bounds) const override
static std::shared_ptr< DlImageFilter > Make(sk_sp< DlRuntimeEffect > runtime_effect, std::vector< std::shared_ptr< DlColorSource > > samplers, std::shared_ptr< std::vector< uint8_t > > uniform_data)
#define FML_DCHECK(condition)
A 4x4 matrix using column-major storage.