/* * Copyright (C) 2004, 2005, 2006, 2007 Nikolas Zimmermann * Copyright (C) 2004, 2005 Rob Buis * Copyright (C) 2005 Eric Seidel * Copyright (C) 2013 Google Inc. All rights reserved. * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Library General Public * License as published by the Free Software Foundation; either * version 2 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Library General Public License for more details. * * You should have received a copy of the GNU Library General Public License * along with this library; see the file COPYING.LIB. If not, write to * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, * Boston, MA 02110-1301, USA. */ #ifndef FEGaussianBlur_h #define FEGaussianBlur_h #include "platform/graphics/filters/Filter.h" #include "platform/graphics/filters/FilterEffect.h" namespace WebCore { class PLATFORM_EXPORT FEGaussianBlur : public FilterEffect { public: static PassRefPtr create(Filter*, float, float); float stdDeviationX() const; void setStdDeviationX(float); float stdDeviationY() const; void setStdDeviationY(float); virtual FloatRect mapRect(const FloatRect&, bool forward = true) OVERRIDE FINAL; virtual FloatRect determineAbsolutePaintRect(const FloatRect& requestedRect) OVERRIDE; static IntSize calculateKernelSize(Filter*, const FloatPoint& std); static IntSize calculateUnscaledKernelSize(const FloatPoint& std); virtual TextStream& externalRepresentation(TextStream&, int indention) const OVERRIDE; private: static const int s_minimalRectDimension = 100 * 100; // Empirical data limit for parallel jobs template friend class ParallelJobs; struct PlatformApplyParameters { FEGaussianBlur* filter; RefPtr srcPixelArray; RefPtr dstPixelArray; int width; int height; unsigned kernelSizeX; unsigned kernelSizeY; }; FEGaussianBlur(Filter*, float, float); virtual void applySoftware() OVERRIDE; virtual PassRefPtr createImageFilter(SkiaImageFilterBuilder*) OVERRIDE; float m_stdX; float m_stdY; }; } // namespace WebCore #endif // FEGaussianBlur_h