/* -*- Mode: C++; tab-width: 2; 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_IMAGELIB_IMAGEOPS_H_ #define MOZILLA_IMAGELIB_IMAGEOPS_H_ #include "nsCOMPtr.h" class gfxDrawable; class imgIContainer; struct nsIntRect; namespace mozilla { namespace image { class Image; struct Orientation; class ImageOps { public: /** * Creates a version of an existing image which does not animate and is frozen * at the first frame. * * @param aImage The existing image. */ static already_AddRefed Freeze(Image* aImage); static already_AddRefed Freeze(imgIContainer* aImage); /** * Creates a clipped version of an existing image. Animation is unaffected. * * @param aImage The existing image. * @param aClip The rectangle to clip the image against. */ static already_AddRefed Clip(Image* aImage, nsIntRect aClip); static already_AddRefed Clip(imgIContainer* aImage, nsIntRect aClip); /** * Creates a version of an existing image which is rotated and/or flipped to * the specified orientation. * * @param aImage The existing image. * @param aOrientation The desired orientation. */ static already_AddRefed Orient(Image* aImage, Orientation aOrientation); static already_AddRefed Orient(imgIContainer* aImage, Orientation aOrientation); /** * Creates an image from a gfxDrawable. * * @param aDrawable The gfxDrawable. */ static already_AddRefed CreateFromDrawable(gfxDrawable* aDrawable); private: // This is a static utility class, so disallow instantiation. virtual ~ImageOps() = 0; }; } // namespace image } // namespace mozilla #endif // MOZILLA_IMAGELIB_IMAGEOPS_H_