blob: e0418b99c463914a46fcdb6378e8cc3262247fd0 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
|
/* -*- 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/. */
/* code for HTML client-side image maps */
#ifndef nsImageMap_h
#define nsImageMap_h
#include "mozilla/gfx/2D.h"
#include "nsCOMPtr.h"
#include "nsCoord.h"
#include "nsTArray.h"
#include "nsStubMutationObserver.h"
#include "nsIDOMEventListener.h"
class Area;
class nsImageFrame;
class nsIFrame;
class nsIContent;
struct nsRect;
namespace mozilla {
namespace dom {
class HTMLAreaElement;
}
} // namespace mozilla
class nsImageMap final : public nsStubMutationObserver,
public nsIDOMEventListener {
typedef mozilla::gfx::DrawTarget DrawTarget;
typedef mozilla::gfx::ColorPattern ColorPattern;
typedef mozilla::gfx::StrokeOptions StrokeOptions;
public:
nsImageMap();
void Init(nsImageFrame* aImageFrame, nsIContent* aMap);
/**
* Return the first area element (in content order) for the given aX,aY pixel
* coordinate or nullptr if the coordinate is outside all areas.
*/
mozilla::dom::HTMLAreaElement* GetArea(nscoord aX, nscoord aY) const;
/**
* Return area elements count associated with the image map.
*/
uint32_t AreaCount() const { return mAreas.Length(); }
/**
* Return area element at the given index.
*/
mozilla::dom::HTMLAreaElement* GetAreaAt(uint32_t aIndex) const;
void Draw(nsIFrame* aFrame, DrawTarget& aDrawTarget,
const ColorPattern& aColor,
const StrokeOptions& aStrokeOptions = StrokeOptions());
/**
* Called just before the nsImageFrame releases us.
* Used to break the cycle caused by the DOM listener.
*/
void Destroy();
// nsISupports
NS_DECL_ISUPPORTS
// nsIMutationObserver
NS_DECL_NSIMUTATIONOBSERVER_ATTRIBUTECHANGED
NS_DECL_NSIMUTATIONOBSERVER_CONTENTAPPENDED
NS_DECL_NSIMUTATIONOBSERVER_CONTENTINSERTED
NS_DECL_NSIMUTATIONOBSERVER_CONTENTREMOVED
NS_DECL_NSIMUTATIONOBSERVER_PARENTCHAINCHANGED
// nsIDOMEventListener
NS_DECL_NSIDOMEVENTLISTENER
nsresult GetBoundsForAreaContent(nsIContent* aContent, nsRect& aBounds);
using AreaList = AutoTArray<mozilla::UniquePtr<Area>, 8>;
protected:
virtual ~nsImageMap();
void FreeAreas();
void UpdateAreas();
void SearchForAreas(nsIContent* aParent);
void AddArea(mozilla::dom::HTMLAreaElement* aArea);
void AreaRemoved(mozilla::dom::HTMLAreaElement* aArea);
void MaybeUpdateAreas(nsIContent* aContent);
nsImageFrame* mImageFrame; // the frame that owns us
nsCOMPtr<nsIContent> mMap;
// almost always has some entries
AreaList mAreas;
// This is set when we search for all area children and tells us whether we
// should consider the whole subtree or just direct children when we get
// content notifications about changes inside the map subtree.
bool mConsiderWholeSubtree;
};
#endif /* nsImageMap_h */
|