2012-08-29 09:47:18 +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 GFX_LAYER_TREE_INVALIDATION_H
|
|
|
|
#define GFX_LAYER_TREE_INVALIDATION_H
|
|
|
|
|
2013-08-12 03:17:23 +04:00
|
|
|
#include "nsRegion.h" // for nsIntRegion
|
2014-08-25 19:09:39 +04:00
|
|
|
#include "mozilla/UniquePtr.h" // for UniquePtr
|
2012-08-29 09:47:18 +04:00
|
|
|
|
|
|
|
class nsPresContext;
|
2013-08-12 03:17:23 +04:00
|
|
|
struct nsIntPoint;
|
2012-08-29 09:47:18 +04:00
|
|
|
|
|
|
|
namespace mozilla {
|
|
|
|
namespace layers {
|
|
|
|
|
|
|
|
class Layer;
|
|
|
|
class ContainerLayer;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Callback for ContainerLayer invalidations.
|
|
|
|
*
|
|
|
|
* @param aContainer ContainerLayer being invalidated.
|
|
|
|
* @param aRegion Invalidated region in the ContainerLayer's coordinate
|
|
|
|
* space.
|
|
|
|
*/
|
|
|
|
typedef void (*NotifySubDocInvalidationFunc)(ContainerLayer* aLayer,
|
|
|
|
const nsIntRegion& aRegion);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* A set of cached layer properties (including those of child layers),
|
|
|
|
* used for comparing differences in layer trees.
|
|
|
|
*/
|
|
|
|
struct LayerProperties
|
|
|
|
{
|
|
|
|
virtual ~LayerProperties() {}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Copies the current layer tree properties into
|
|
|
|
* a new LayerProperties object.
|
|
|
|
*
|
|
|
|
* @param Layer tree to copy, or nullptr if we have no
|
|
|
|
* initial layer tree.
|
|
|
|
*/
|
2014-08-25 19:09:39 +04:00
|
|
|
static UniquePtr<LayerProperties> CloneFrom(Layer* aRoot);
|
2012-08-29 09:47:18 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Clear all invalidation status from this layer tree.
|
|
|
|
*/
|
|
|
|
static void ClearInvalidations(Layer* aRoot);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Compares a set of existing layer tree properties to the current layer
|
|
|
|
* tree and generates the changed rectangle.
|
|
|
|
*
|
|
|
|
* @param aRoot Root layer of the layer tree to compare against.
|
|
|
|
* @param aCallback If specified, callback to call when ContainerLayers
|
|
|
|
* are invalidated.
|
|
|
|
* @return Painted area changed by the layer tree changes.
|
|
|
|
*/
|
2012-11-12 22:31:15 +04:00
|
|
|
virtual nsIntRegion ComputeDifferences(Layer* aRoot,
|
2014-04-04 05:59:13 +04:00
|
|
|
NotifySubDocInvalidationFunc aCallback,
|
|
|
|
bool* aGeometryChanged = nullptr) = 0;
|
2012-09-17 02:57:22 +04:00
|
|
|
|
|
|
|
|
|
|
|
virtual void MoveBy(const nsIntPoint& aOffset) = 0;
|
2012-08-29 09:47:18 +04:00
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace layers
|
|
|
|
} // namespace mozilla
|
|
|
|
|
|
|
|
#endif /* GFX_LAYER_TREE_INVALIDATON_H */
|