зеркало из https://github.com/mozilla/gecko-dev.git
96 строки
2.8 KiB
C++
96 строки
2.8 KiB
C++
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
/* vim: set ts=8 sts=2 et sw=2 tw=80: */
|
|
/* 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 __NS_SVGFILTERFRAME_H__
|
|
#define __NS_SVGFILTERFRAME_H__
|
|
|
|
#include "mozilla/Attributes.h"
|
|
#include "nsIFrame.h"
|
|
#include "nsQueryFrame.h"
|
|
#include "nsSVGContainerFrame.h"
|
|
#include "nsSVGUtils.h"
|
|
|
|
class nsAtom;
|
|
class nsIContent;
|
|
class nsIFrame;
|
|
|
|
struct nsRect;
|
|
|
|
namespace mozilla {
|
|
class SVGAnimatedLength;
|
|
class SVGFilterInstance;
|
|
class PresShell;
|
|
|
|
namespace dom {
|
|
class SVGFilterElement;
|
|
} // namespace dom
|
|
} // namespace mozilla
|
|
|
|
nsIFrame* NS_NewSVGFilterFrame(mozilla::PresShell* aPresShell,
|
|
mozilla::ComputedStyle* aStyle);
|
|
|
|
namespace mozilla {
|
|
|
|
class SVGFilterFrame final : public nsSVGContainerFrame {
|
|
friend nsIFrame* ::NS_NewSVGFilterFrame(mozilla::PresShell* aPresShell,
|
|
ComputedStyle* aStyle);
|
|
|
|
protected:
|
|
explicit SVGFilterFrame(ComputedStyle* aStyle, nsPresContext* aPresContext)
|
|
: nsSVGContainerFrame(aStyle, aPresContext, kClassID),
|
|
mLoopFlag(false),
|
|
mNoHRefURI(false) {
|
|
AddStateBits(NS_FRAME_IS_NONDISPLAY);
|
|
}
|
|
|
|
public:
|
|
NS_DECL_FRAMEARENA_HELPERS(SVGFilterFrame)
|
|
|
|
// nsIFrame methods:
|
|
virtual void BuildDisplayList(nsDisplayListBuilder* aBuilder,
|
|
const nsDisplayListSet& aLists) override {}
|
|
|
|
virtual nsresult AttributeChanged(int32_t aNameSpaceID, nsAtom* aAttribute,
|
|
int32_t aModType) override;
|
|
|
|
#ifdef DEBUG
|
|
virtual void Init(nsIContent* aContent, nsContainerFrame* aParent,
|
|
nsIFrame* aPrevInFlow) override;
|
|
#endif
|
|
|
|
private:
|
|
friend class SVGFilterInstance;
|
|
|
|
/**
|
|
* Parses this frame's href and - if it references another filter - returns
|
|
* it. It also makes this frame a rendering observer of the specified ID.
|
|
*/
|
|
SVGFilterFrame* GetReferencedFilter();
|
|
|
|
// Accessors to lookup filter attributes
|
|
uint16_t GetEnumValue(uint32_t aIndex, nsIContent* aDefault);
|
|
uint16_t GetEnumValue(uint32_t aIndex) {
|
|
return GetEnumValue(aIndex, mContent);
|
|
}
|
|
const mozilla::SVGAnimatedLength* GetLengthValue(uint32_t aIndex,
|
|
nsIContent* aDefault);
|
|
const mozilla::SVGAnimatedLength* GetLengthValue(uint32_t aIndex) {
|
|
return GetLengthValue(aIndex, mContent);
|
|
}
|
|
const mozilla::dom::SVGFilterElement* GetFilterContent(nsIContent* aDefault);
|
|
const mozilla::dom::SVGFilterElement* GetFilterContent() {
|
|
return GetFilterContent(mContent);
|
|
}
|
|
|
|
// This flag is used to detect loops in xlink:href processing
|
|
bool mLoopFlag;
|
|
bool mNoHRefURI;
|
|
};
|
|
|
|
} // namespace mozilla
|
|
|
|
#endif
|