13 const std::shared_ptr<DlImageFilter>& filter) {
14 return std::make_shared<DlLocalMatrixImageFilter>(
matrix, filter);
21 return image_filter_->modifies_transparent_black();
25 const DlRect& input_bounds,
26 DlRect& output_bounds)
const {
28 output_bounds = input_bounds;
29 return &output_bounds;
31 return image_filter_->map_local_bounds(input_bounds, output_bounds);
39 output_bounds = input_bounds;
40 return &output_bounds;
42 return image_filter_->map_device_bounds(input_bounds, ctm * matrix_,
51 input_bounds = output_bounds;
54 return image_filter_->get_input_device_bounds(output_bounds, ctm * matrix_,
61 return (matrix_ == that->matrix_ &&
62 Equals(image_filter_, that->image_filter_));
virtual T type() const =0
bool equals_(const DlImageFilter &other) const override
bool modifies_transparent_black() const override
const DlMatrix & matrix() const
DlIRect * map_device_bounds(const DlIRect &input_bounds, const DlMatrix &ctm, DlIRect &output_bounds) const override
DlIRect * get_input_device_bounds(const DlIRect &output_bounds, const DlMatrix &ctm, DlIRect &input_bounds) const override
static std::shared_ptr< DlImageFilter > Make(const DlMatrix &matrix, const std::shared_ptr< DlImageFilter > &filter)
DlRect * map_local_bounds(const DlRect &input_bounds, DlRect &output_bounds) const override
#define FML_DCHECK(condition)
bool Equals(const T *a, const U *b)
A 4x4 matrix using column-major storage.