2014-06-19 04:56:02 +04:00
|
|
|
/* -*- 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 CANVASIMAGECACHE_H_
|
|
|
|
#define CANVASIMAGECACHE_H_
|
|
|
|
|
|
|
|
#include "nsSize.h"
|
|
|
|
|
|
|
|
namespace mozilla {
|
|
|
|
namespace dom {
|
|
|
|
class Element;
|
|
|
|
class HTMLCanvasElement;
|
|
|
|
} // namespace dom
|
|
|
|
namespace gfx {
|
|
|
|
class SourceSurface;
|
|
|
|
} // namespace gfx
|
|
|
|
} // namespace mozilla
|
|
|
|
class imgIRequest;
|
|
|
|
|
|
|
|
namespace mozilla {
|
|
|
|
|
|
|
|
class CanvasImageCache {
|
|
|
|
typedef mozilla::gfx::SourceSurface SourceSurface;
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
* Notify that image element aImage was (or is about to be) drawn to aCanvas
|
|
|
|
* using the first frame of aRequest's image. The data for the surface is
|
|
|
|
* in aSurface, and the image size is in aSize.
|
|
|
|
*/
|
|
|
|
static void NotifyDrawImage(dom::Element* aImage,
|
|
|
|
dom::HTMLCanvasElement* aCanvas,
|
|
|
|
imgIRequest* aRequest,
|
|
|
|
SourceSurface* aSource,
|
2015-11-04 05:12:24 +03:00
|
|
|
const gfx::IntSize& aSize,
|
|
|
|
bool aIsAccelerated);
|
2014-06-19 04:56:02 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Check whether aImage has recently been drawn into aCanvas. If we return
|
|
|
|
* a non-null surface, then the image was recently drawn into the canvas
|
|
|
|
* (with the same image request) and the returned surface contains the image
|
|
|
|
* data, and the image size will be returned in aSize.
|
|
|
|
*/
|
|
|
|
static SourceSurface* Lookup(dom::Element* aImage,
|
|
|
|
dom::HTMLCanvasElement* aCanvas,
|
2015-11-04 05:12:24 +03:00
|
|
|
gfx::IntSize* aSize,
|
|
|
|
bool aIsAccelerated);
|
2014-10-29 18:17:00 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* This is the same as Lookup, except it works on any image recently drawn
|
|
|
|
* into any canvas. Security checks need to be done again if using the
|
|
|
|
* results from this.
|
|
|
|
*/
|
2015-11-04 05:12:24 +03:00
|
|
|
static SourceSurface* SimpleLookup(dom::Element* aImage,
|
|
|
|
bool aIsAccelerated);
|
2014-06-19 04:56:02 +04:00
|
|
|
};
|
|
|
|
|
2015-07-13 18:25:42 +03:00
|
|
|
} // namespace mozilla
|
2014-06-19 04:56:02 +04:00
|
|
|
|
|
|
|
#endif /* CANVASIMAGECACHE_H_ */
|